:root {
  --color-green: #52d047;
  --color-green-bg: #f3fcf2;
  --color-green-title: #245d20;
  --color-green-desc: #328d2a;
  --color-orange: #ff7214;
  --color-secondary: #16004d;
  --color-secondary-bg: #0d002f;
  --color-secondary-light: #dbcff9;
  --color-secondary-light-fade: #78708c;
  --color-cta: #ff7214;
  --color-cta-hover: #e66a12;
  --color-white: #fff;
  --color-border-light: #e9e9e9;
  --color-border-medium: #d0cece;
  --color-gray-light: #f7f7f7;
  --color-gray-dark: #555;
  --color-gray-input: #ddd;
  --color-error: #e9446e;
  --color-bg-code: #f4f4f4;
  --color-border-code: #a0a0a0;
  --color-placeholder: #a4a4a4;
  --color-shadow: rgba(0, 0, 0, 0.1);
}

.is-menu-open {
  .mobile-menu {
    &::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 160px;
      background: var(--color-secondary);
      background: linear-gradient(
        180deg,
        var(--color-secondary) 0%,
        var(--color-secondary) 80%,
        rgba(22, 0, 77, 0) 100%
      );
      z-index: 69;
    }

    .mobile__nav {
      > ul {
        .menu-item-has-children {
          a {
            display: flex;
            align-items: center;
            justify-content: space-between;

            i {
              font-size: 0.9em;
            }
          }
        }
      }
    }
  }
}

.mobile__nav > ul li a body.home section.pageheader p.pageheader__tagline {
  display: none;
}

body.scrolled:not(.is-menu-open) header.header {
  position: fixed;
  background-color: var(--color-white);
  transition: all 0.3s ease-in-out;
  padding-bottom: 1rem;
  box-shadow: 0 1px 20px var(--color-shadow);
  width: 100%;
}

body.scrolled header.header a.logo {
  margin-bottom: 0px;
}

body.scrolled.is-menu-open header.header {
  position: fixed;
  width: 100%;
}

body.scrolled:not(.menu-is-open) header.header .header__top {
  min-height: 0px;
  height: 0px;
  transition: all 0.3s ease-in-out;
  overflow: hidden;
}

a.btn-orange {
  background-color: var(--color-orange) !important;
  color: var(--color-white) !important;
  -webkit-user-select: none;
  user-select: none;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  -moz-transition: all 0.2s ease;
  -ms-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  border-radius: 50px;
  display: inline-block;
  padding: 17px 22px;
  min-height: 48px;
  font-family: "Outfit", sans-serif;
  border: 0;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  font-size: 0.875rem;
  text-decoration: none !important;
  cursor: pointer;
}

a.btn-blue {
  background-color: var(--color-secondary) !important;
  color: var(--color-white) !important;
  color: var(--color-white) !important;
  -webkit-user-select: none;
  user-select: none;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  -moz-transition: all 0.2s ease;
  -ms-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  border-radius: 50px;
  display: inline-block;
  padding: 17px 22px;
  min-height: 48px;
  font-family: "Outfit", sans-serif;
  border: 0;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  font-size: 0.875rem;
  text-decoration: none !important;
  cursor: pointer;
}
a.btn-green {
  background-color: var(--color-green) !important;
  color: var(--color-white) !important;
  -webkit-user-select: none;
  user-select: none;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  -moz-transition: all 0.2s ease;
  -ms-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  border-radius: 50px;
  display: inline-block;
  padding: 17px 22px;
  min-height: 48px;
  font-family: "Outfit", sans-serif;
  border: 0;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  font-size: 0.875rem;
  text-decoration: none !important;
  cursor: pointer;
}

a.btn-orange:hover,
a.btn-blue:hover,
a.btn-green:hover {
  opacity: 0.8;
}

@media only screen and (min-width: 960px) {
  .col--lg-no-margin {
    margin-bottom: 0 !important;
  }
}

body:not(.home) {
  .header {
    position: absolute;
    left: 0;
    width: 100%;
  }

  main {
    padding-top: 160px;
  }
}

span.accent b {
  color: var(--color-green);
}
/**
 * Contact Page CSS
 */

/**
 
body.page-id-2,
body.page-id-850 {
  &:not(.scrolled) {
    .header {
      color: var(--color-white);

      .header__nav.header__nav--large
        > ul
        > .menu-item.menu-item-large
        .nav-mega {
        background: var(--color-secondary-bg);

        .nav__title {
          color: var(--color-white);
        }
      }

      .header__mobile .nav-toggle .hamb .ham {
        background: var(--color-white);

        &::before,
        &::after {
          background: var(--color-white);
        }
      }

      #searchToggle {
        color: var(--color-white);
        border-color: var(--color-border-medium);
      }

      .sub-menu {
        color: var(--color-secondary-bg);
      }

      .header__nav.header__nav--large > ul > .menu-item a,
      .header__nav.header__nav--large
        > ul
        > .menu-item.menu-item-has-children
        > a::after,
      .header__cta,
      a,
      .nav-mega .sub-menu {
        color: inherit;
      }

      .logo {
        svg path,
        svg rect {
          fill: var(--color-white);
        }

        .logo__tagline {
          color: var(--color-white);
        }
      }
    }
  }

  main {
    padding-top: 0;
    z-index: 2;

    section.contact-block {
      background: var(--color-secondary-bg);
      color: var(--color-white);
      min-height: 100dvh;
      display: flex;
      height: 100%;
      align-items: center;
      padding-bottom: 6rem;
      padding-top: 160px;
      position: relative;

      &::after {
        content: "";
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='156' height='439' viewBox='0 0 156 439'%3E%3Cdefs%3E%3CclipPath id='clip-path'%3E%3Crect id='Rectangle_1116' data-name='Rectangle 1116' width='156' height='439' transform='translate(1744 368)' fill='%23fff' stroke='%23707070' stroke-width='1'/%3E%3C/clipPath%3E%3C/defs%3E%3Cg id='Mask_Group_16' data-name='Mask Group 16' transform='translate(-1744 -368)' clip-path='url(%23clip-path)'%3E%3Cg id='Group_395' data-name='Group 395' transform='translate(132.218 266.044)'%3E%3Cpath id='Path_476' data-name='Path 476' d='M184.636 346.33A153.789 153.789 0 0 1 229.98 236.867L465.267 1.58H604.494L256.111 349.963c-36.6 36.6-36.269 95.519.233 132.2L229.98 455.8A153.8 153.8 0 0 1 184.636 346.33' transform='translate(1427.281 -25.265)' fill='%2352d047'/%3E%3Cpath id='Path_477' data-name='Path 477' d='M27.3 218.922l43.5-43.466a56.325 56.325 0 0 0 0 79.668l628.67 628.671H560.206L27.529 351.121c-36.5-36.679-36.832-95.6-.233-132.2' transform='translate(1656.099 105.777)' fill='%2316004d'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
        background-position: right bottom;
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        right: 0px;
        top: 150px;
        width: clamp(200px, 20vw, 400px);
        height: 100%;
        z-index: 0;
        pointer-events: none;
      }

      > * {
        z-index: 1;
      }

      & + .layouts {
        padding-top: 6rem;
      }

      h1,
      h2,
      h3,
      h4,
      h5,
      h6,
      span,
      p,
      small {
        color: inherit;
      }

      .container {
        width: 100%;
        padding: 0;
        max-width: 1600px;

        .row > .col:first-of-type {
          margin-bottom: 3rem;
        }

        .contact__info-wrapper {
          display: flex;
          flex-direction: column;
          gap: 3rem;
          padding: 0 20px;

          .contact__info-title {
            > * {
              margin-top: 0;
            }
          }

          .contact__info-desc {
            color: var(--color-secondary-light);

            p {
              margin-bottom: 0;
            }
          }

          .contact__info-contact {
            display: flex;
            flex-direction: column;
            gap: 1rem;

            .contact__info-contact-item {
              display: flex;
              flex-direction: row;
              gap: 2rem;
              align-items: center;

              i,
              a {
                font-size: clamp(1rem, 0.3125rem + 0.9375vw, 1.2rem);
              }

              i {
                color: var(--color-green);
              }

              a {
                color: var(--color-secondary-light);
                text-decoration: none;
                transition: 0.3s ease color;

                &:hover {
                  color: var(--color-green);
                }
              }
            }
          }

          .contact__info-social-proof {
            display: flex;
            flex-direction: column;
            gap: 1rem;

            .contact__info-testimonial {
              .swiper {
                .swiper-wrapper {
                  box-sizing: inherit;

                  .swiper-slide {
                    height: 100%;

                    .testimonial {
                      background: var(--color-white);
                      border-radius: 8px;
                      padding: 1rem;
                      padding-bottom: 3rem;
                      color: var(--color-secondary-bg);
                      height: 100%;
                      display: flex;
                      flex-direction: column;
                      gap: 1.5rem;

                      .testimonial__header {
                        display: flex;
                        flex-direction: column;
                        width: 100%;
                        gap: 0.5rem;
                        justify-content: space-between;
                        text-align: center;

                        .testimonial__author {
                          display: flex;
                          align-items: center;
                          justify-content: center;

                          .testimonial__author-image {
                            display: none;
                            width: 48px;
                            height: 48px;
                            border-radius: 50%;
                            overflow: hidden;
                            margin-right: 1rem;
                            background: var(--color-green);

                            img {
                              width: 100%;
                              height: 100%;
                              object-fit: cover;
                            }
                          }

                          .testimonial__author-info {
                            .testimonial__author-name {
                              font-size: 1.2rem;
                              margin: 0;
                            }

                            .testimonial__author-function {
                              font-size: 0.875rem;
                              color: var(--color-secondary-light-fade);
                              margin: 0;
                              display: flex;
                              align-items: center;
                              gap: 0.5rem;
                              text-decoration: none;
                              transition: color 0.3s ease;

                              svg {
                                margin-bottom: 2px;
                                opacity: 0.5;
                                display: none;
                              }
                            }

                            a {
                              &:hover {
                                color: var(--color-green);
                              }
                            }
                          }
                        }
                      }

                      .testimonial__content {
                        display: -webkit-box;
                        -webkit-line-clamp: 4;
                        -webkit-box-orient: vertical;
                        overflow: hidden;
                        text-overflow: ellipsis;
                      }
                    }
                  }
                }
                .swiper-pagination-bullet {
                  background: var(--color-secondary-light);
                  opacity: 0.5;
                }
                .swiper-pagination-bullet-active {
                  background: var(--color-green);
                }
              }
            }

            .contact__info-social-proof-grid {
              display: grid;
              grid-template-columns: repeat(1, 1fr);
              column-gap: 1rem;
              row-gap: 1rem;

              .contact__info-social-proof-logo {
                background: var(--color-white);
                padding: 1rem;
                border-radius: 8px;
                display: flex;
                justify-content: center;
                height: 120px;

                img {
                  width: 100%;
                  height: auto;
                  object-fit: contain;
                }
              }
            }

            @media only screen and (min-width: 500px) {
              .contact__info-testimonial
                .swiper
                .swiper-wrapper
                .swiper-slide
                .testimonial {
                padding: 2rem;
                padding-bottom: 3rem;

                .testimonial__header {
                  flex-direction: row;
                  gap: 0;
                  text-align: start;
                  justify-content: space-between;
                  align-items: start;

                  .testimonial__author {
                    .testimonial__author-image {
                      display: block;
                    }

                    .testimonial__author-info {
                      .testimonial__author-function {
                        svg {
                          display: block;
                        }
                      }
                    }
                  }
                }
              }
              .contact__info-social-proof-grid {
                grid-template-columns: repeat(3, 1fr);
              }
            }
          }
        }

        .contact__form-wrapper {
          background: var(--color-white);
          border-radius: 8px;
          overflow: hidden;
          color: var(--color-secondary-bg);
          text-align: center;
          padding: 2rem 20px;

          small {
            font-size: 14px;
          }

          .contact__form-title {
            margin-bottom: 3rem;

            > * {
              margin: 0;
            }
          }

          .gform_wrapper {
            padding: 0;

            input,
            select,
            textarea {
              border-radius: 1.5rem;

              &::placeholder {
                color: var(--color-placeholder);
                font-family: "Outfit", sans-serif;
                font-size: 14px;
              }
            }

            .gfield_label {
              font-weight: 400;
            }

            .gfield_required {
              color: var(--color-error);
            }

            select {
              color: var(--color-placeholder);
              font-family: "Outfit", sans-serif;
              font-size: 14px;

              &.selected {
                color: var(--color-secondary);
                font-size: 1rem;
              }
            }

            .gform-footer {
              margin-top: 3rem;

              input.gform_button[type="submit"] {
                width: 100%;
              }
            }
          }
        }
      }
    }

    div.layouts {
      padding-top: 5rem;
    }
  }

  @media only screen and (min-width: 480px) {
    main {
      section.contact-block {
        .container {
          padding: 0 20px;

          .contact__info-wrapper {
            padding: 0;
          }

          .contact__form-wrapper {
            padding: 2.5rem 2rem;
          }
        }
      }
    }
  }

  @media only screen and (min-width: 960px) {
    main {
      section.contact-block {
        padding-top: 0;
        padding-bottom: 0;
        height: 100dvh;
        min-height: 1200px;

        &::after {
          top: 250px;
        }

        .container {
          .row {
            display: flex;
            align-items: center;
          }

          .contact__info-wrapper {
            gap: 3rem;

            .contact__info-contact {
              padding-left: 3rem;
            }
          }
        }
      }
    }
  }
}

*/

/**
 * Layout Slider Logos
 */

.layout-logo-slider {
  .layout__pretitle {
    color: var(--color-green);
    text-transform: uppercase;
    margin: 0 0 11px;
    text-align: center;
  }

  .layout__title {
    margin: 0;
    text-align: center;
  }

  .slider__logos--fullwidth {
    width: 100vw;
    margin: 50px 0 20px;
    margin-left: calc(50% - 50vw);

    .swiper-wrapper {
      transition-timing-function: linear !important;

      .swiper-slide {
        width: auto;
        height: auto;
        display: block;

        .logo__container {
          box-sizing: border-box;
          border: 1px solid var(--color-border-light);
          height: 100%;
          display: flex;
          align-items: center;
          justify-content: center;
          transition: border-color ease 0.3s;

          &:hover {
            border-color: var(--color-border-medium);
          }

          img {
            max-width: 75%;
            max-height: 90%;
          }
        }

        a:hover {
          &.logo__container {
            border-color: var(--color-green);
          }
        }

        a[target="_blank"] {
          position: relative;

          &::after {
            content: "";
            position: absolute;
            top: 0.5rem;
            right: 0.5rem;
            width: 24px;
            height: 24px;
            display: inline-block;
            background-color: var(--color-green);
            -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line></svg>')
              no-repeat center / contain;
            mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line></svg>')
              no-repeat center / contain;
            transform: scale(0.8);
            opacity: 0;
            transition: opacity ease-in-out 0.3s;
          }

          &:hover::after {
            opacity: 0.75;
          }
        }
      }
    }
  }
}

section.layout {
  &.layout--gray {
    background: var(--color-gray-light);
  }

  &.layout--secondary {
    background: var(--color-secondary);
    color: var(--color-white);

    a,
    .layout__title {
      color: var(--color-white);
    }
  }

  &.layout--swoop-right {
    position: relative;

    * {
      z-index: 1;
    }

    &::after {
      content: "";
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='156' height='439' viewBox='0 0 156 439'%3E%3Cdefs%3E%3CclipPath id='clip-path'%3E%3Crect id='Rectangle_1116' data-name='Rectangle 1116' width='156' height='439' transform='translate(1744 368)' fill='%23fff' stroke='%23707070' stroke-width='1'/%3E%3C/clipPath%3E%3C/defs%3E%3Cg id='Mask_Group_16' data-name='Mask Group 16' transform='translate(-1744 -368)' clip-path='url(%23clip-path)'%3E%3Cg id='Group_395' data-name='Group 395' transform='translate(132.218 266.044)'%3E%3Cpath id='Path_476' data-name='Path 476' d='M184.636 346.33A153.789 153.789 0 0 1 229.98 236.867L465.267 1.58H604.494L256.111 349.963c-36.6 36.6-36.269 95.519.233 132.2L229.98 455.8A153.8 153.8 0 0 1 184.636 346.33' transform='translate(1427.281 -25.265)' fill='%2352d047'/%3E%3Cpath id='Path_477' data-name='Path 477' d='M27.3 218.922l43.5-43.466a56.325 56.325 0 0 0 0 79.668l628.67 628.671H560.206L27.529 351.121c-36.5-36.679-36.832-95.6-.233-132.2' transform='translate(1656.099 105.777)' fill='%2316004d'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
      background-position: right bottom;
      background-repeat: no-repeat;
      background-size: contain;
      position: absolute;
      inset: 0 0 -18px 0;
      width: clamp(200px, 20vw, 400px);
      height: 100%;
      z-index: 0;
    }
  }

  &.layout--swoop-left {
    position: relative;

    * {
      z-index: 1;
    }

    &::after {
      content: "";
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='156' height='439' viewBox='0 0 156 439'%3E%3Cdefs%3E%3CclipPath id='clip-path'%3E%3Crect id='Rectangle_1116' data-name='Rectangle 1116' width='156' height='439' transform='translate(1744 368)' fill='%23fff' stroke='%23707070' stroke-width='1'/%3E%3C/clipPath%3E%3C/defs%3E%3Cg id='Mask_Group_16' data-name='Mask Group 16' transform='translate(-1744 -368)' clip-path='url(%23clip-path)'%3E%3Cg id='Group_395' data-name='Group 395' transform='translate(132.218 266.044)'%3E%3Cpath id='Path_476' data-name='Path 476' d='M184.636 346.33A153.789 153.789 0 0 1 229.98 236.867L465.267 1.58H604.494L256.111 349.963c-36.6 36.6-36.269 95.519.233 132.2L229.98 455.8A153.8 153.8 0 0 1 184.636 346.33' transform='translate(1427.281 -25.265)' fill='%2352d047'/%3E%3Cpath id='Path_477' data-name='Path 477' d='M27.3 218.922l43.5-43.466a56.325 56.325 0 0 0 0 79.668l628.67 628.671H560.206L27.529 351.121c-36.5-36.679-36.832-95.6-.233-132.2' transform='translate(1656.099 105.777)' fill='%2316004d'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
      background-position: right bottom;
      background-repeat: no-repeat;
      background-size: contain;
      position: absolute;
      inset: 0 0 -18px 0;
      width: clamp(200px, 20vw, 400px);
      height: 100%;
      transform: scaleX(-1);
      z-index: 0;
    }
  }
}

section.layout-text-img {
  .layout__pretitle {
    color: var(--color-green);
    margin: 0 0 11px;
  }

  .layout__title {
    margin-top: 0;
  }

  .layout__wrapper--centered {
    > * {
      text-align: center;
    }
  }

  .row--content {
    row-gap: 2rem;

    .col {
      display: flex;
      align-items: center;

      &.order-1 {
        order: 1;
      }

      &.order-2 {
        order: 2;
      }

      img {
        width: 100%;
      }
    }
  }
}

section.layout-cards {
  .row--gap {
    row-gap: 1.5rem;
  }

  .row--cards-toggle {
    display: flex;
    justify-content: center;
    padding: 1rem 0;
    margin-bottom: 2rem;

    .toggle-switch {
      position: relative;
      display: inline-flex;
      width: 200px;
      height: 40px;
      background-color: var(--color-gray-input);
      border-radius: 50px;
      cursor: pointer;
      user-select: none;
      font-family: "Outfit", sans-serif;
      overflow: hidden;
      box-shadow: inset 0 0 5px var(--color-shadow);

      .toggle-option {
        flex: 1;
        text-align: center;
        line-height: 40px;
        z-index: 2;
        transition: color 0.3s ease;
        color: var(--color-gray-dark);
        font-weight: 600;

        &.active {
          color: var(--color-white);
        }
      }

      .toggle-slider {
        position: absolute;
        top: 0;
        left: 0;
        width: 50%;
        height: 100%;
        background-color: var(--color-green); /* green */
        border-radius: 50px;
        transition: transform 0.3s ease;
        z-index: 1;
      }
    }
  }
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
}

@media only screen and (min-width: 526px) {
  .cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media only screen and (min-width: 768px) {
  .cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1160px) {
  .cards-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

article[data-wx="card"] {
  background: var(--color-secondary-bg);
  color: var(--color-secondary-light);
  border: 1px solid var(--color-secondary-light);
  border-radius: 8px;
  padding: 1.5rem;
  position: relative;
  overflow: hidden;
  z-index: 0;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;

  .card__wrapper {
    text-align: start;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    height: 100%;
    justify-content: space-between;

    .card__title {
      color: var(--color-white);
      font-size: 1.125rem;
      font-weight: bold;
      margin: 0;
      line-height: 1.4;
    }

    .card__description {
      font-size: 0.95rem;
      margin: 0;
      line-height: 1.285em;
    }

    .card__cta {
      background: var(--color-cta);
      color: var(--color-white);
      width: 100%;
      text-align: center;
      text-decoration: none;
      text-transform: uppercase;
      font-weight: 600;
      border-radius: 4px;
      padding: 10px 20px;
      line-height: 1em;
      transition: 0.3s ease-in-out background;

      &:hover {
        background: var(--color-cta-hover);
      }
    }

    .card__head {
      display: flex;
      flex-direction: column;
      gap: 12px;

      .card__head_icon {
        width: 36px;
        height: 36px;
        border-radius: 36px;
        background-color: var(--card-accent, var(--color-green));
        color: white;
        text-align: center;
        overflow: hidden;
        display: flex;
        justify-content: center;
        align-items: center;
      }

      .card__head_content {
        display: flex;
        flex-direction: column;
        gap: 4px;
      }
    }

    .card__body {
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
      margin-top: auto;
    }
  }

  &.type-price {
    &::after {
      content: "";
      position: absolute;
      width: 250px;
      height: 250px;
      border-radius: 50%;
      background-color: var(--card-accent, var(--color-green));
      filter: blur(150px);
      opacity: 1;
      top: 0;
      right: 0;
      transform: translate(50%, -50%);
      z-index: -1;
      pointer-events: none;
    }

    .card__body {
      .card__prices {
        display: flex;
        flex-direction: row;
        gap: 1rem;

        .card__price {
          display: flex;
          align-items: baseline;
          gap: 0.25rem;

          .card__currency,
          .card__term {
            color: var(--color-secondary-light-fade);
            font-size: 0.875rem;
          }

          .card__currency {
            align-self: flex-start;
            margin-top: 0.25rem;
          }

          .card__value {
            color: var(--color-white);
            font-size: 1.5rem;
            font-weight: bold;
            margin: 0;
          }
        }
      }
    }

    &.price-annual {
      .card__price--annual {
        display: inherit;
      }

      .card__price--month {
        position: relative;
        color: var(--color-secondary-light-fade);

        .card__value {
          color: var(--color-secondary-light-fade) !important;
        }

        &::after {
          content: "";
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          width: 100%;
          height: 1.5px;
          background: var(--color-secondary-light-fade);
        }
      }
    }

    &.price-month {
      .card__price--annual {
        display: none !important;
      }

      .card__price-month {
        &::after {
          content: unset;
        }
      }
    }

    .card__footer {
      > span {
        display: flex;
        gap: 10px;

        .card__footer_icon {
          margin-top: 0.25rem;
          width: 1.25rem;
          height: 1.25rem;
          background-color: var(--color-secondary-light-fade);
          mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%2014%2014%22%20xmlns%3D%22http://www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M7%200C10.8659%200.000108657%2014%203.13407%2014%207C14%2010.8659%2010.8659%2013.9999%207%2014C3.13401%2014%200%2010.866%200%207C0%203.13401%203.13401%200%207%200ZM7.32324%203.20605C6.8305%203.21225%206.34349%203.3155%205.89062%203.50977C5.43769%203.70412%205.02669%203.98597%204.68262%204.33887C4.33873%204.69166%204.06753%205.10889%203.88477%205.56641C3.8702%205.60288%203.85715%205.63989%203.84375%205.67676H3.29395C3.0178%205.67676%202.79395%205.90062%202.79395%206.17676C2.7941%206.45277%203.0179%206.67676%203.29395%206.67676H3.62793C3.61984%206.78409%203.616%206.89204%203.61719%207L3.62207%207.19336C3.62423%207.23687%203.62823%207.28011%203.63184%207.32324H3.29395C3.0179%207.32324%202.7941%207.54723%202.79395%207.82324C2.79395%208.09938%203.0178%208.32324%203.29395%208.32324H3.85254C4.37809%209.75764%205.73063%2010.7939%207.3291%2010.7939C8.28989%2010.7939%209.14346%2010.4098%209.7959%209.85059C10.0055%209.67091%2010.0292%209.35517%209.84961%209.14551C9.66988%208.93596%209.35415%208.91115%209.14453%209.09082C8.64408%209.51971%208.01523%209.79395%207.3291%209.79395C6.30609%209.7939%205.40353%209.20002%204.94238%208.32324H7C7.27606%208.32315%207.5%208.09933%207.5%207.82324C7.49985%207.54729%207.27597%207.32334%207%207.32324H4.6377C4.62574%207.21714%204.61719%207.10946%204.61719%207V6.99414C4.61584%206.88799%204.62196%206.78199%204.63281%206.67676H8.23535C8.51129%206.67663%208.7352%206.45269%208.73535%206.17676C8.73535%205.90069%208.51139%205.67688%208.23535%205.67676H4.93457C5.05788%205.4428%205.21411%205.22718%205.39941%205.03711C5.6517%204.77838%205.95211%204.57125%206.28418%204.42871C6.61568%204.28647%206.97233%204.21092%207.33301%204.20605C7.99869%204.20463%208.64089%204.45193%209.13379%204.89941C9.33814%205.08492%209.65517%205.07041%209.84082%204.86621C10.0265%204.66183%2010.011%204.34485%209.80664%204.15918C9.17072%203.58166%208.35365%203.2473%207.49902%203.20996L7.32812%203.20605H7.32324Z%22/%3E%3C/svg%3E")
            no-repeat center;
          -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%2014%2014%22%20xmlns%3D%22http://www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M7%200C10.8659%200.000108657%2014%203.13407%2014%207C14%2010.8659%2010.8659%2013.9999%207%2014C3.13401%2014%200%2010.866%200%207C0%203.13401%203.13401%200%207%200ZM7.32324%203.20605C6.8305%203.21225%206.34349%203.3155%205.89062%203.50977C5.43769%203.70412%205.02669%203.98597%204.68262%204.33887C4.33873%204.69166%204.06753%205.10889%203.88477%205.56641C3.8702%205.60288%203.85715%205.63989%203.84375%205.67676H3.29395C3.0178%205.67676%202.79395%205.90062%202.79395%206.17676C2.7941%206.45277%203.0179%206.67676%203.29395%206.67676H3.62793C3.61984%206.78409%203.616%206.89204%203.61719%207L3.62207%207.19336C3.62423%207.23687%203.62823%207.28011%203.63184%207.32324H3.29395C3.0179%207.32324%202.7941%207.54723%202.79395%207.82324C2.79395%208.09938%203.0178%208.32324%203.29395%208.32324H3.85254C4.37809%209.75764%205.73063%2010.7939%207.3291%2010.7939C8.28989%2010.7939%209.14346%2010.4098%209.7959%209.85059C10.0055%209.67091%2010.0292%209.35517%209.84961%209.14551C9.66988%208.93596%209.35415%208.91115%209.14453%209.09082C8.64408%209.51971%208.01523%209.79395%207.3291%209.79395C6.30609%209.7939%205.40353%209.20002%204.94238%208.32324H7C7.27606%208.32315%207.5%208.09933%207.5%207.82324C7.49985%207.54729%207.27597%207.32334%207%207.32324H4.6377C4.62574%207.21714%204.61719%207.10946%204.61719%207V6.99414C4.61584%206.88799%204.62196%206.78199%204.63281%206.67676H8.23535C8.51129%206.67663%208.7352%206.45269%208.73535%206.17676C8.73535%205.90069%208.51139%205.67688%208.23535%205.67676H4.93457C5.05788%205.4428%205.21411%205.22718%205.39941%205.03711C5.6517%204.77838%205.95211%204.57125%206.28418%204.42871C6.61568%204.28647%206.97233%204.21092%207.33301%204.20605C7.99869%204.20463%208.64089%204.45193%209.13379%204.89941C9.33814%205.08492%209.65517%205.07041%209.84082%204.86621C10.0265%204.66183%2010.011%204.34485%209.80664%204.15918C9.17072%203.58166%208.35365%203.2473%207.49902%203.20996L7.32812%203.20605H7.32324Z%22/%3E%3C/svg%3E")
            no-repeat center;
        }
      }
    }

    .card__saving[data-term="month"] {
      text-decoration: line-through;
      color: var(--color-secondary-light-fade);
    }
  }

  &.type-custom {
    transition: 0.3s ease border-color;
    .card__wrapper {
      display: flex;
      flex-direction: column;

      img {
        margin: auto;
        aspect-ratio: 1;
        object-fit: contain;
        max-height: 250px;
      }
    }

    &.integration-platform,
    &.type-integration-platform {
      background: var(--color-white);
      padding: 0;

      .card__wrapper {
        padding: 1.5rem;

        .card__title {
          color: var(--color-secondary);
          text-align: center;
        }

        img {
          max-height: 100px;
        }
      }
    }

    &:hover {
      border-color: var(--color-green);
    }
  }
}

.filter-search__wrapper {
  position: relative;
  margin-bottom: 3rem;
  transition: ease 0.3s transform;

  .filter-search__icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-secondary-light-fade);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  #integration-search {
    width: 100%;
    padding-left: 42px;
    padding-right: 42px;
    box-sizing: border-box;
    border-color: var(--color-secondary-light);
    border-radius: 8px;

    &:focus {
      border-color: var(--color-secondary-light-fade);
      border-color: var(--color-green);
    }
  }

  &:has(input:focus) {
    transform: scale(1.02);
  }

  .filter-search__clear {
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    background: transparent;
    color: var(--color-error);
    font-size: 18px;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transition: opacity 150ms ease;

    &.is-visible {
      opacity: 1;
      pointer-events: auto;
    }
  }
}

.filter-wrapper {
  #filter-clear {
    display: inline-block;
    margin-bottom: 16px;
    font-size: 0.9rem;
    text-align: right;
    transition:
      opacity 200ms ease,
      transform 150ms ease;

    &.is-disabled {
      opacity: 0.35;
      cursor: not-allowed;

      &:hover,
      &:active,
      &:focus {
        text-decoration: underline;
      }
    }

    &:not(.is-disabled) {
      cursor: pointer;
    }
  }

  .filter-categories {
    margin-bottom: 3rem;

    .filter-head {
      display: flex;
      justify-content: space-between;

      h5 {
        margin-top: 0;
      }
    }

    > ul {
      padding-left: 1rem;
      margin: 0;
    }

    a {
      &:active,
      &:focus {
        text-decoration: underline;
      }

      &.active {
        color: var(--color-green);
        font-weight: 600;
        text-decoration: none;
        position: relative;
        padding-right: 24px;

        &::after {
          content: "×";
          position: absolute;
          right: 8px;
          font-weight: bold;
          opacity: 0;
          color: var(--color-error);
          transition: opacity 0.3s ease;
        }

        &:hover {
          &&:after {
            opacity: 1;
          }
        }
      }
    }
  }

  @media only screen and (min-width: 768px) {
    .filter-categories {
      margin-bottom: 0;
    }
  }
}

.cards-grid.skeleton-loading {
  position: relative;
  overflow: hidden;

  &::after {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    pointer-events: none;
    background: linear-gradient(
      90deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.3) 50%,
      rgba(255, 255, 255, 0) 100%
    );
    animation: shimmer-global 1.5s infinite;
    z-index: 10;
  }
}

.card-skeleton {
  position: relative;
  overflow: hidden;
  background-color: #e0e0e0;
  border-radius: 8px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;

  .card-skeleton-image,
  .card-skeleton-title,
  .card-skeleton-button {
    background-color: #ccc;
    border-radius: 6px;
  }

  .card-skeleton-image {
    width: 100%;
    padding-top: 56%;
  }

  .card-skeleton-title {
    width: 40%;
    height: 16px;
    margin: 10px 0;
  }

  .card-skeleton-button {
    width: 70%;
    height: 20px;
  }
}

@keyframes shimmer-global {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(200%);
  }
}

form.filter-faq {
  .filter__wrapper {
    #faq_search {
      flex: 0 0 100%;
    }

    label {
      display: inline-flex;
      position: relative;
      align-items: center;
      justify-content: flex-start;
      gap: 0.5rem;
      margin: 0.25rem;
      padding: 0.6rem 1.2rem;
      font-family: "Outfit", sans-serif;
      font-size: 0.95rem;
      font-weight: 600;
      color: var(--color-green);
      background-color: var(--color-white);
      border: 2px solid var(--color-green);
      border-radius: 50px;
      cursor: pointer;
      transition: all 0.2s ease;
      user-select: none;

      input[type="checkbox"] {
        position: absolute;
        opacity: 0;
        width: 0;
        height: 0;
      }

      &:hover {
        background-color: #edffeb;
        border-color: #42a035;
      }

      &::before {
        content: "";
        display: inline-block;
        width: 18px;
        height: 18px;
        border: 1.5px solid var(--color-green);
        border-radius: 4px;
        background-color: rgba(0, 0, 0, 0);
        flex-shrink: 0;
      }

      &::after {
        content: "";
        position: absolute;
        top: 52%;
        left: 21.5px;
        width: 14px;
        height: 14px;
        transform: translateY(-50%);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2352d047' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17L4 12'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: 100% 100%;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease;
      }

      &:has(input[type="checkbox"]:checked) {
        background-color: var(--color-green);
        color: var(--color-white);
        border-color: var(--color-green);

        &::before {
          background-color: var(--color-white);
        }

        &::after {
          opacity: 1;
        }
      }

      input[type="checkbox"]:checked + span,
      input[type="checkbox"]:checked {
        background-color: var(--color-green);
        color: var(--color-white);
        border-color: var(--color-green);
      }
    }
  }
}

pre {
  text-align: center;
  border: 1px solid var(--color-border-code);
  background: var(--color-bg-code);
  border-radius: 4px;
  color: var(--color-error);
  padding: 1rem;
  width: 98%;
  max-width: 1200px;
  margin: 3rem auto;
}

.nav__integration-agent {
  margin-top: 3rem;
  position: relative;
  display: flex;
  gap: 0.5rem;
  flex-direction: column;
  padding: 1rem;
  border-radius: 0.5rem;
  border: 1px solid var(--color-green);
  background: var(--color-green-bg);
  text-decoration: none;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;

  > * {
    text-decoration: none;
  }

  .nav__integration-agent-title {
    color: var(--color-green-title);
    font-size: 1.175rem;
    font-weight: 600;
  }

  .nav__integration-agent-text {
    color: var(--color-green-desc);
    margin-bottom: 0;
    font-size: 0.95rem;
  }

  .nav__integration-agent-badge {
    display: block;
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: var(--color-green);
    color: var(--color-green-bg);
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
    border-radius: 1rem;
  }

  &[data-viewport="desktop"] {
    .nav__integration-agent-text[data-viewport="desktop"] {
      display: inline;
    }
    .nav__integration-agent-text[data-viewport="mobile"] {
      display: none;
    }
  }

  &:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 6px rgba(82, 208, 71, 0.3);
  }
}

.nav__integration-agent-wrapper {
  padding: 0 20px;
  margin-bottom: 24px;

  .nav__integration-agent {
    max-width: 1200px;
    margin: 0 auto;
    gap: 0;
    padding: 0.5rem;
  }

  .nav__integration-agent-title {
    font-size: 22px;
    font-weight: 400;
  }

  .nav__integration-agent-text {
    &[data-size="large"] {
      display: none;
    }

    &[data-size="small"] {
      display: inline;
    }
  }

  .nav__integration-agent-badge {
    display: none;
  }

  .nav__integration-agent-arrow {
    position: absolute;
    top: 1rem;
    right: 0.5rem;
    font-size: 19.8px;
    font-weight: 400;
    color: var(--color-green-title);
  }

  @media only screen and (min-width: 641px) {
    .nav__integration-agent {
      padding: 1rem;
      margin-bottom: 3rem;

      .nav__integration-agent-badge {
        display: block;
        position: initial;
        width: fit-content;
      }

      .nav__integration-agent-arrow {
        display: none;
      }

      .nav__integration-agent-title {
        font-weight: 600;
      }

      .nav__integration-agent-text {
        &[data-size="large"] {
          display: inline;
        }

        &[data-size="small"] {
          display: none;
        }
      }
    }
  }
}
