/* ====== Scroll Animation — shared styles ====== */

html { scroll-behavior: auto !important; }

.scroll-anim { position: relative; }

.scroll-anim__canvas-wrap {
  position: fixed; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 70% 55% at 50% 35%, rgba(34,197,94,.28) 0%, rgba(22,163,74,.10) 35%, transparent 70%),
    radial-gradient(ellipse 55% 45% at 15% 85%, rgba(34,197,94,.18) 0%, transparent 55%),
    radial-gradient(ellipse 55% 45% at 85% 25%, rgba(245,158,11,.08) 0%, transparent 60%),
    linear-gradient(160deg, #0d2916 0%, #08170d 50%, #050d07 100%);
}
.scroll-anim__canvas-wrap canvas {
  width: 100%; height: 100%; object-fit: cover; display: block;
  opacity: 0;
  transition: opacity .5s ease-out;
}
.scroll-anim__canvas-wrap canvas.is-ready { opacity: 1; }

.scroll-anim__vignette {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(6,13,9,.45) 0%, rgba(6,13,9,.02) 18%, transparent 44%, rgba(6,13,9,.08) 80%, rgba(6,13,9,.85) 100%),
    radial-gradient(ellipse 50% 65% at center, transparent 0%, transparent 60%, rgba(6,13,9,.30) 100%);
}
.scroll-anim__sides {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(6,13,9,.50) 0%, rgba(6,13,9,.10) 20%, transparent 36%, transparent 64%, rgba(6,13,9,.10) 80%, rgba(6,13,9,.50) 100%);
}

@keyframes fp-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .55; transform: scale(.85); }
}
.scroll-anim__content { position: relative; z-index: 2; }

.scroll-section {
  min-height: 100vh; display: flex; align-items: center;
  padding: 80px 5vw; position: relative;
}
.scroll-section--hero  { padding-top: 64px; }
.scroll-section--left  { justify-content: flex-start; }
.scroll-section--right { justify-content: flex-end; }
.scroll-section--center { justify-content: center; align-items: flex-start; padding-top: 14vh; }

.scroll-section__inner {
  max-width: 540px; width: 100%; opacity: 0; position: relative;
  padding: 38px 34px; border-radius: 22px;
  background: linear-gradient(135deg, rgba(13,24,16,.58) 0%, rgba(6,13,9,.66) 100%);
  border: 1px solid rgba(255,255,255,.07);
  backdrop-filter: blur(18px) saturate(125%);
  -webkit-backdrop-filter: blur(18px) saturate(125%);
  box-shadow: 0 30px 80px rgba(0,0,0,.45), 0 1px 0 rgba(255,255,255,.04) inset;
  transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
}
.scroll-section__inner--wide { max-width: 600px; }
.scroll-section--left  .scroll-section__inner { transform: translateX(-60px); }
.scroll-section--right .scroll-section__inner {
  transform: translateX(60px);
  background: linear-gradient(225deg, rgba(13,24,16,.58) 0%, rgba(6,13,9,.66) 100%);
}
.scroll-section--center .scroll-section__inner {
  transform: translateY(40px);
  max-width: 640px;
  background: radial-gradient(ellipse at center, rgba(13,24,16,.65) 0%, rgba(6,13,9,.62) 100%);
}
.scroll-section__inner.visible { opacity: 1; transform: translate(0,0); }

.scroll-stagger > * {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1);
  transition-delay: calc(var(--i, 0) * 70ms + 120ms);
}
.scroll-section__inner.visible .scroll-stagger > * {
  opacity: 1; transform: translateY(0);
}

.scroll-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 16px; border-radius: 9999px;
  border: 1px solid rgba(34,197,94,.22);
  background: rgba(34,197,94,.10); color: #4ade80;
  font-size: 12px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: 24px;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 4px 24px rgba(34,197,94,.08);
}
.scroll-eyebrow--gold {
  border-color: rgba(245,158,11,.22);
  background: rgba(245,158,11,.10); color: #fbbf24;
  box-shadow: 0 4px 24px rgba(245,158,11,.08);
}

.scroll-title {
  font-size: clamp(36px, 5.5vw, 56px);
  font-weight: 900; letter-spacing: -.04em; line-height: .95;
  margin: 0 0 20px;
  text-shadow: 0 2px 24px rgba(0,0,0,.7), 0 1px 4px rgba(0,0,0,.4);
}
.scroll-title--sm { font-size: clamp(28px, 4vw, 40px); margin-bottom: 14px; }
.scroll-desc {
  font-size: 16px; color: #ecf0f3; line-height: 1.65;
  margin: 0 0 26px;
  text-shadow: 0 2px 14px rgba(0,0,0,.85), 0 1px 4px rgba(0,0,0,.6);
}

.scroll-cta-row { display: flex; gap: 14px; flex-wrap: wrap; }
.fp-btn:focus-visible {
  outline: 2px solid #4ade80; outline-offset: 3px;
}

.scroll-trust {
  display: flex; flex-wrap: wrap; gap: 14px 20px;
  margin-top: 22px;
  font-size: 13px; color: #d4dde3; font-weight: 600;
}
.scroll-trust__item {
  display: inline-flex; align-items: center; gap: 6px;
  text-shadow: 0 1px 8px rgba(0,0,0,.55);
}
.scroll-trust__check {
  width: 16px; height: 16px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(34,197,94,.18); color: #4ade80;
  font-size: 10px; font-weight: 900;
  border: 1px solid rgba(34,197,94,.35);
}

.scroll-stats {
  display: flex; flex-wrap: wrap; gap: 24px; margin-top: 28px;
}
.scroll-stat { display: flex; align-items: baseline; gap: 8px; }
.scroll-stat__num {
  font-size: 42px; font-weight: 900; color: #4ade80; line-height: 1;
  text-shadow: 0 0 20px rgba(34,197,94,.25), 0 2px 16px rgba(0,0,0,.5);
  font-variant-numeric: tabular-nums;
}
.scroll-stat__label {
  font-size: 12px; color: #c8d0d6; text-transform: uppercase;
  letter-spacing: .08em; font-weight: 700;
  text-shadow: 0 1px 8px rgba(0,0,0,.6);
}

.scroll-features {
  display: flex; flex-direction: column; gap: 18px; margin: 8px 0;
}
.scroll-feature-item {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 4px 0;
  transition: transform .25s;
}
.scroll-feature-item:hover { transform: translateX(6px); }
.scroll-feature-item__icon {
  width: 46px; height: 46px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 22px; line-height: 1; flex-shrink: 0;
  border-radius: 14px;
  background: rgba(34,197,94,.10);
  border: 1px solid rgba(34,197,94,.22);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 24px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.4));
  transition: background .25s, border-color .25s, transform .25s;
}
.scroll-feature-item:hover .scroll-feature-item__icon {
  background: rgba(34,197,94,.18); border-color: rgba(34,197,94,.4);
  transform: scale(1.05);
}
.scroll-feature-item__title {
  font-size: 16px; font-weight: 800; color: #fff; margin: 0 0 4px;
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
}
.scroll-feature-item__desc {
  font-size: 13.5px; color: #cfd6d2; line-height: 1.55; margin: 0;
  text-shadow: 0 2px 10px rgba(0,0,0,.7), 0 1px 3px rgba(0,0,0,.5);
}

.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px;
  background: linear-gradient(90deg, #16a34a, #4ade80, #facc15);
  z-index: 200; width: 0%; transition: width .05s linear;
  box-shadow: 0 0 12px rgba(34,197,94,.5); border-radius: 0 2px 2px 0;
}

.scroll-hint {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: rgba(255,255,255,.35); font-size: 11px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  animation: hintPulse 2.6s ease-in-out infinite; z-index: 3;
}
.scroll-hint__arrow {
  width: 22px; height: 22px;
  border-right: 2px solid rgba(255,255,255,.28);
  border-bottom: 2px solid rgba(255,255,255,.28);
  transform: rotate(45deg);
}
@keyframes hintPulse {
  0%,100% { opacity: .35; transform: translateX(-50%) translateY(0); }
  50%     { opacity: .8;  transform: translateX(-50%) translateY(8px); }
}

.scroll-dots {
  position: fixed; right: 24px; top: 50%; transform: translateY(-50%);
  z-index: 50; display: flex; flex-direction: column; gap: 12px;
}
.scroll-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  border: 1.5px solid rgba(255,255,255,.25);
  cursor: pointer; transition: all .3s; position: relative;
}
.scroll-dot::before {
  content: attr(data-label); position: absolute;
  right: 20px; top: 50%; transform: translateY(-50%);
  white-space: nowrap; font-size: 11px; color: rgba(255,255,255,.5);
  font-weight: 600; opacity: 0; transition: opacity .2s; pointer-events: none;
}
.scroll-dot:hover::before { opacity: 1; }
.scroll-dot.active {
  background: #4ade80; border-color: #4ade80;
  box-shadow: 0 0 10px rgba(74,222,128,.4); transform: scale(1.3);
}

@media (max-width: 980px) {
  .scroll-section, .scroll-section--left, .scroll-section--right {
    justify-content: center; padding: 80px 24px;
  }
  .scroll-section--left .scroll-section__inner,
  .scroll-section--right .scroll-section__inner {
    transform: translateY(40px); max-width: 580px;
  }
}
@media (max-width: 768px) {
  .scroll-section { padding: 60px 18px; }
  .scroll-section__inner { padding: 28px 22px; border-radius: 18px; }
  .scroll-section__inner--wide { max-width: 100%; }
  .scroll-stats { gap: 16px; }
  .scroll-stat__num { font-size: 32px; }
  .scroll-feature-item__icon { width: 42px; height: 42px; font-size: 20px; }
  .scroll-trust { gap: 10px 16px; font-size: 12px; }
  .scroll-dots { display: none; }
}
@media (max-width: 480px) {
  .scroll-stats { flex-direction: column; gap: 12px; }
  .scroll-hint { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .scroll-section__inner,
  .scroll-stagger > *,
  .scroll-feature-item,
  .scroll-feature-item__icon,
  .scroll-hint {
    animation: none !important; transition: none !important;
    transform: none !important; opacity: 1 !important;
  }
}
