body .benefits-section-alt {
  --benefits-visual-height: clamp(380px, 45vh, 520px);
  --benefits-content-gap: 48px;
  --benefits-sticky-top: max(80px, calc((100vh - var(--benefits-visual-height)) / 2));
  position: relative;
  overflow: visible;
  padding: 80px 0 0;
  background: #111419;
  color: #f4f6fb;
}
body .benefits-section-alt__background {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
body .benefits-section-alt__background-video {
  width: 100%;
  height: 100%;
  object-fit: fill;
}
body .benefits-section-alt.alignfull {
  padding-left: 0;
  padding-right: 0;
}
body .benefits-section-alt .container {
  position: relative;
  z-index: 2;
}
body .benefits-section-alt__title {
  max-width: 640px;
  margin-bottom: 48px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
body .benefits-section-alt__title .tag-line .tag {
  color: #fff;
}
body .benefits-section-alt__title .title-text,
body .benefits-section-alt__title .benefits-section-alt__title-text {
  color: #ffffff;
}
body .benefits-section-alt__title-text {
  margin: 20px 0;
  color: #ffffff;
  text-align: center;
}
body .benefits-section-alt__inner {
  display: flex;
  align-items: flex-start;
  gap: 80px;
  position: relative;
  padding-top: clamp(80px, 14vh, 200px);
  padding-bottom: clamp(120px, 20vh, 240px);
}
body .benefits-section-alt__content {
  flex: 0 0 45%;
  max-width: 520px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--benefits-content-gap);
  min-height: clamp(80vh, 95vh, 1080px);
}
body .benefits-section-alt__display {
  position: sticky;
  top: var(--benefits-sticky-top);
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
  z-index: 2;
  min-height: var(--benefits-visual-height);
}
body .benefits-section-alt__display.is-transitioning {
  opacity: 0;
  transition: opacity 320ms ease;
}
body .benefits-section-alt__display.is-visible {
  opacity: 1;
  transition: opacity 360ms ease;
}
body .benefits-section-alt__display-title, body .benefits-section-alt__display-text {
  transition: opacity 360ms ease;
}
body .benefits-section-alt__display-title.is-hidden, body .benefits-section-alt__display-text.is-hidden {
  opacity: 0;
}
body .benefits-section-alt__display-title.is-visible, body .benefits-section-alt__display-text.is-visible {
  opacity: 1;
}
body .benefits-section-alt__slides {
  display: flex;
  flex-direction: column;
  gap: clamp(160px, 30vh, 320px);
  position: relative;
  padding-top: clamp(180px, 30vh, 360px);
  padding-bottom: clamp(220px, 38vh, 440px);
  pointer-events: none;
}
body .benefits-section-alt__slide {
  position: relative;
  min-height: clamp(60vh, 90vh, 1100px);
}
body .benefits-section-alt__slide-content {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}
body .benefits-section-alt__slide-title {
  margin: 0;
  color: #ffffff;
  transition: color 300ms ease;
}
body .benefits-section-alt__slide-text {
  margin: 0;
  color: rgba(244, 246, 251, 0.75);
  transition: color 300ms ease;
}
body .benefits-section-alt__dots {
  display: none;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
body .benefits-section-alt__dot {
  width: 12px;
  height: 12px;
  aspect-ratio: 1/1;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 0;
  font-size: 0;
  border-radius: 50%;
  border: none;
  background: rgba(129, 165, 255, 0.35);
  transition: transform 180ms ease, background-color 200ms ease;
  cursor: pointer;
}
body .benefits-section-alt__dot.is-active, body .benefits-section-alt__dot:focus-visible {
  transform: scale(1.3);
  background: #81a5ff;
}
body .benefits-section-alt__visual {
  flex: 1;
  position: sticky;
  top: var(--benefits-sticky-top);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--benefits-visual-height);
  z-index: 2;
}
body .benefits-section-alt__visual::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 50%;
  transform: translateX(-50%);
  width: 720px;
  height: 760px;
  background: url("../../assets/images/bg-opacity-lottie-v1.png") bottom right/contain no-repeat;
  z-index: -1;
  pointer-events: none;
}
body .benefits-section-alt__lottie {
  position: relative;
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1/1.1;
  z-index: 2;
}
body .benefits-section-alt__lottie > div {
  width: 100% !important;
  height: 100% !important;
}
body .benefits-section-alt__lottie-poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 280ms ease;
  pointer-events: none;
  z-index: 3;
}
body .benefits-section-alt__lottie-poster.is-hidden {
  opacity: 0;
}
body .benefits-section-alt.has-static-benefits-visual .benefits-section-alt__visual::before {
  opacity: 0.85;
}
body .benefits-section-alt.has-static-benefits-visual .benefits-section-alt__lottie > div {
  display: none !important;
}
body .benefits-section-alt.has-static-benefits-visual .benefits-section-alt__lottie-poster {
  opacity: 1 !important;
  visibility: visible !important;
  position: relative;
  inset: auto;
  width: 100%;
  height: auto;
}
@media (max-width: 991px) {
  body .benefits-section-alt.has-static-benefits-visual .benefits-section-alt__lottie {
    aspect-ratio: auto;
    max-width: 360px;
    margin: 0 auto;
  }
}
@media (max-width: 1600px) {
  body .benefits-section-alt__visual::before {
    right: -160px;
  }
}
@media (max-width: 1400px) {
  body .benefits-section-alt__visual::before {
    right: -120px;
  }
}
@media (max-width: 1200px) {
  body .benefits-section-alt__visual::before {
    right: -80px;
  }
}
@media (max-width: 1199px) {
  body .benefits-section-alt__inner {
    gap: 56px;
  }
  body .benefits-section-alt__slides {
    gap: 96px;
  }
}
@media (max-width: 991px) {
  body .benefits-section-alt {
    --benefits-content-gap: 32px;
    padding: 64px 0 0;
  }
  body .benefits-section-alt__background {
    display: none;
  }
  body .benefits-section-alt__inner {
    flex-direction: column;
    gap: 32px;
    padding-top: 0;
    padding-bottom: 64px;
  }
  body .benefits-section-alt__content {
    flex: 1;
    max-width: none;
    gap: var(--benefits-content-gap);
    min-height: auto;
    padding-top: 0;
    padding-bottom: 0;
  }
  body .benefits-section-alt__display {
    display: none;
  }
  body .benefits-section-alt__slides {
    position: relative;
    gap: 0;
    padding-top: 0;
    padding-bottom: 0;
    min-height: auto;
    pointer-events: auto;
  }
  body .benefits-section-alt__dots {
    display: flex;
  }
  body .benefits-section-alt__slide {
    min-height: 0;
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(24px);
    transition: opacity 320ms ease, transform 320ms ease;
  }
  body .benefits-section-alt__slide.is-active {
    position: relative;
    inset: auto;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  body .benefits-section-alt__slide-content {
    position: static;
    inset: auto;
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
  }
  body .benefits-section-alt__slide-title {
    margin: 0 0 16px;
  }
  body .benefits-section-alt__slide-text {
    margin: 0;
  }
  body .benefits-section-alt__visual {
    order: -1;
    position: relative;
    top: auto;
    min-height: clamp(320px, 45vh, 480px);
    padding-top: 0;
    padding-bottom: 0;
  }
  body .benefits-section-alt__visual::before {
    display: none;
  }
}
@media (max-width: 767px) {
  body .benefits-section-alt {
    padding: 52px 0 0;
  }
  body .benefits-section-alt__title {
    margin-bottom: 40px;
  }
  body .benefits-section-alt__inner {
    gap: 24px;
    padding-bottom: 52px;
  }
  body .benefits-section-alt__visual {
    min-height: 280px;
    padding-top: 0;
    padding-bottom: 0;
  }
  body .benefits-section-alt__slide-title {
    font-size: 24px;
  }
  body .benefits-section-alt__slide-text {
    font-size: 16px;
  }
}

/*# sourceMappingURL=benefits-section.css.map */
