/* ============================================================
   Authority Figures — Client Engine landing page
   Built on the AF VSL / Web design system (base.css tokens).
   Dark editorial · purple is the only loud color · red = problems only.
   ============================================================ */

:root{
  --bg:        #1C1726;
  --bg-2:      #211B2E;                     /* very subtly raised band */
  --text:      #F2EEFB;
  --accent:    #7b5ad9;
  --accent-text:#a589ec;
  --accent-2:  #D8CCF3;
  --muted:     rgba(242,238,251,.84);
  --faint:     rgba(242,238,251,.66);
  --hair:      rgba(242,238,251,.14);
  --card:      rgba(255,255,255,.035);
  --card-line: rgba(216,204,243,.20);
  --card-hi:   rgba(255,255,255,.06);
  --accent-soft:rgba(123,90,217,.12);
  --accent-line:rgba(123,90,217,.34);
  --danger:    #e89090;
  --danger-soft:rgba(176,54,54,.12);
  --danger-line:rgba(217,106,106,.32);
  --radius:    14px;
  --pad-x:     max(7vw,40px);
  --maxw:      1120px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  background:var(--bg);color:var(--text);
  font-family:"Archivo",sans-serif;-webkit-font-smoothing:antialiased;
  font-size:17px;line-height:1.5;overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%;display:block}
strong{color:var(--text);font-weight:700}
::selection{background:rgba(123,90,217,.35);color:#fff}

/* (content-visibility removed — its 900px height estimate broke anchor scrolling) */

/* ---------- layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x)}
.section{padding:clamp(72px,11vw,140px) 0;position:relative}
/* anchored sections: swallow most of the internal top padding so nav links
   land with the eyebrow right under the nav pill, not a screen of dead space */
@media(min-width:761px){
  .section[id]{scroll-margin-top:calc(28px - clamp(72px,11vw,140px))}
}
.section--tight{padding:clamp(56px,8vw,104px) 0}
.band{background:var(--bg-2)}
.band::before,.band::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--hair)}
.band::before{top:0}.band::after{bottom:0}
.center{text-align:center}
.center .af-rule{margin-inline:auto}

/* ---------- type primitives (AF scale) ---------- */
.eyebrow{display:inline-block;font-size:13.5px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-text);margin-bottom:18px}
.display{font-weight:900;font-size:clamp(40px,6.4vw,66px);letter-spacing:-.035em;line-height:1.0}
.h1{font-weight:800;font-size:clamp(32px,4.8vw,46px);letter-spacing:-.03em;line-height:1.06}
.h2{font-weight:800;font-size:clamp(27px,3.5vw,34px);letter-spacing:-.02em;line-height:1.1}
.h3{font-weight:700;font-size:clamp(19px,2vw,23px);letter-spacing:-.01em;line-height:1.18}
.serif{font-family:"Fraunces",serif;font-weight:500;font-style:italic;color:var(--accent-2);letter-spacing:-.01em}
.rule{width:118px;height:2px;background:var(--accent);border:0;margin:22px 0 26px}
.lead{font-size:clamp(18px,1.6vw,21px);line-height:1.5;color:var(--muted);max-width:62ch}
.lead strong{color:var(--text)}
.body{font-size:clamp(16px,1.5vw,18px);line-height:1.55;color:var(--muted);max-width:64ch}
.body strong{color:var(--text)}
.muted{color:var(--muted)}
.kicker-num{font-family:"Anton",sans-serif;color:var(--accent);opacity:.14;
  font-size:clamp(120px,18vw,230px);line-height:.8;letter-spacing:-.02em;
  position:absolute;pointer-events:none;z-index:0}

/* ---------- pill ---------- */
.pill{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--accent-line);
  background:var(--accent-soft);border-radius:40px;padding:9px 18px;
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(123,90,217,.55);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(123,90,217,.5)}70%{box-shadow:0 0 0 9px rgba(123,90,217,0)}100%{box-shadow:0 0 0 0 rgba(123,90,217,0)}}
/* stat pill: numbers emphasized, labels lighter (not all-caps) */
.pill--stat{text-transform:none;letter-spacing:.01em;font-size:14px;font-weight:600;gap:11px;padding:10px 20px;white-space:nowrap;max-width:100%}
.pill--stat b{font-family:"Anton",sans-serif;font-weight:400;letter-spacing:.02em;font-size:19px;color:#fff;margin-right:5px}
.pill--stat .pill__sep{color:var(--accent-2);margin:0 4px}

/* hero guarantee pills (under primary CTA) */
.hero__guard{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;margin-top:20px}
.guard{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--accent-line);
  background:var(--accent-soft);border-radius:40px;padding:9px 16px;
  font-size:13.5px;font-weight:600;letter-spacing:.005em;color:var(--muted);line-height:1;white-space:nowrap}
.guard__ck{flex:0 0 auto;color:var(--accent-2)}
@media(max-width:520px){.guard{white-space:normal;text-align:left}}

/* hero guarantee pills (under primary CTA) */
.hero__guard{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.pill--guard{text-transform:none;letter-spacing:.005em;font-size:13px;font-weight:600;gap:7px;padding:8px 15px;color:var(--muted)}
.pill--guard .tick{color:var(--accent-2);font-weight:800;font-size:13px}

/* ---------- buttons / CTA ---------- */
.cta{display:inline-flex;align-items:center;gap:11px;background:var(--accent);color:#fff !important;
  font-size:18px;font-weight:700;text-decoration:none;border-radius:13px;padding:17px 32px;
  border:1px solid transparent;transition:background .18s ease,transform .18s ease;white-space:nowrap}
.cta:hover{background:#8d6fe4;transform:translateY(-1px)}
.cta .arr{transition:transform .18s ease}
.cta:hover .arr{transform:translateX(4px)}
.cta--lg{font-size:19px;padding:19px 38px}
.cta--sm{font-size:15px;padding:12px 22px}
.skip{display:inline-block;color:var(--muted);font-size:15px;font-weight:600;text-decoration:none;
  border-bottom:1px solid var(--hair);padding-bottom:2px;transition:color .15s}
.skip:hover{color:var(--accent-2)}
.skip b{color:var(--accent-2);font-weight:700}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(28,23,38,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .2s,background .2s}
.nav.is-stuck{border-bottom-color:var(--hair);background:rgba(28,23,38,.9)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:68px}
.wordmark{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:10px}
.wordmark .sq{width:11px;height:11px;background:var(--accent);border-radius:3px;display:inline-block}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a:not(.cta){font-size:14.5px;font-weight:600;color:var(--muted);text-decoration:none;transition:color .15s;white-space:nowrap}
.nav__links a:not(.cta):hover{color:var(--text)}
@media(max-width:860px){.nav__links a:not(.cta){display:none}}

/* ---------- scarcity ribbon ---------- */
.ribbon{background:var(--accent);color:#fff;text-align:center;font-size:14.5px;font-weight:600;
  letter-spacing:.01em;padding:9px 16px}
.ribbon b{font-weight:800}

/* ---------- hero ---------- */
.hero{padding-top:clamp(48px,7vw,86px)}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(34px,5vw,64px);align-items:center}
@media(max-width:940px){.hero__grid{grid-template-columns:1fr;gap:36px}}
.hero__cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:30px}
.hero__trust{margin-top:34px;padding-top:24px;border-top:1px solid var(--hair);
  font-size:15.5px;color:var(--muted);max-width:54ch}
.hero__trust b{color:var(--accent-2)}

/* centered hero variant: everything in one viewport — title → video → CTA */
.hero--center{text-align:center;min-height:calc(100svh - 108px);display:flex;align-items:center;
  padding-top:clamp(14px,2.6vh,34px);padding-bottom:clamp(14px,2.6vh,34px)}
.hero__stack{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:clamp(14px,3.2vh,40px);max-width:1140px;margin-inline:auto;width:100%}
/* neutralize default stack margins — gap owns the spacing now */
.hero--center .mt-s,.hero--center .rule,.hero--center .hero__cta,.hero--center .hero__trust,.hero--center .hero__guard{margin:0}
/* title + video share the same width so they align edge-to-edge */
.hero--center .display{font-size:clamp(34px,5.6vw,70px);line-height:1.04;width:100%;max-width:960px}
.hero--center .rule{margin-inline:auto}
.hero--center .lead{margin-inline:auto;text-align:center;font-size:clamp(15px,1.5vw,18px)}
.hero--center .hero__media{width:100%;max-width:1120px}
/* width-driven, but height-capped to the viewport so it still fits one screen */
.hero--center .vsl{width:min(100%,960px);height:auto;aspect-ratio:16/9;margin-inline:auto}
.hero--center .hero__cta{justify-content:center;padding:0;border:0}
.hero--center .hero__trust{text-align:center;max-width:62ch;padding:0;border:0;font-size:14px}
/* compact 3-step strip under the hero CTA */
.hero__steps{list-style:none;display:flex;justify-content:center;align-items:stretch;
  gap:clamp(10px,1.6vw,20px);width:100%;max-width:900px;margin-inline:auto;padding:0;flex-wrap:wrap;text-align:left}
.hstep{flex:1 1 220px;display:flex;align-items:flex-start;gap:11px;
  font-size:clamp(14.5px,1.1vw,15.5px);line-height:1.45;color:var(--muted)}
.hstep__n{flex:0 0 auto;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:12.5px;font-weight:800;color:var(--accent-2);background:var(--accent-soft);border:1px solid var(--accent-line);margin-top:1px}
.hstep__t{flex:1}
@media(max-width:680px){.hero__steps{flex-direction:column;max-width:420px;gap:12px}}
/* mobile: hero fills the screen minus the ribbon — content stretches across it,
   so the next section stays below the fold instead of peeking in */
@media(max-width:560px){.hero--center{min-height:calc(100svh - 40px);padding-block:18px 26px}}

/* VSL frame */
.vsl{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--card-line);
  background:#100c19;box-shadow:0 30px 80px -30px rgba(0,0,0,.7);aspect-ratio:16/9}
.vsl iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* click-to-play facade — keeps heavy player JS off the initial load */
.vsl__poster{position:absolute;inset:0;z-index:2;width:100%;height:100%;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  padding:24px 28px;border:0;font-family:inherit;color:#fff;
  background:radial-gradient(125% 125% at 50% 32%,#241b37 0%,#15101f 60%,#100c19 100%)}
.vsl__play{width:clamp(60px,7.5vw,84px);height:clamp(60px,7.5vw,84px);border-radius:50%;flex:0 0 auto;
  display:grid;place-items:center;background:var(--accent);
  box-shadow:0 22px 60px -16px rgba(123,90,217,.75),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s}
.vsl__play::after{content:"";width:0;height:0;
  border-style:solid;border-width:13px 0 13px 22px;
  border-color:transparent transparent transparent #fff;margin-left:5px}
.vsl__poster:hover .vsl__play{transform:scale(1.07);box-shadow:0 26px 70px -16px rgba(123,90,217,.9),inset 0 1px 0 rgba(255,255,255,.25)}
.vsl__poster:focus-visible{outline:2px solid var(--accent-2);outline-offset:-4px}
.vsl__dur{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);
  text-align:center;text-wrap:balance;max-width:30ch;line-height:1.4}
@media(max-width:560px){
  .vsl__poster{gap:14px;padding:18px 22px}
  .vsl__dur{font-size:11px;letter-spacing:.1em}
}
.vsl__tag{position:absolute;top:14px;left:14px;z-index:3;font-size:11px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);white-space:nowrap;
  background:rgba(28,23,38,.72);border:1px solid var(--accent-line);border-radius:30px;padding:6px 13px;backdrop-filter:blur(6px)}
.vsl__cap{margin-top:12px;font-size:14.5px;color:var(--faint);text-align:center}

/* ---------- ownership strip ---------- */
.own{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,3vw,42px);align-items:center}
@media(max-width:760px){.own{grid-template-columns:1fr}}
.own__big{font-family:"Anton",sans-serif;font-size:clamp(56px,9vw,120px);line-height:.82;color:var(--accent);opacity:.92;letter-spacing:-.02em}
.own__big small{display:block;font-family:"Archivo";font-weight:800;font-size:.2em;letter-spacing:.04em;color:var(--accent-2);opacity:.85;margin-top:10px}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);
  padding:24px 26px;transition:border-color .18s,background .18s,transform .18s}
.card:hover{border-color:var(--accent-line);background:var(--card-hi);transform:translateY(-2px)}
.card .label{font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-text);margin-bottom:11px}
.card .title{font-weight:700;font-size:clamp(18px,1.9vw,21px);letter-spacing:-.01em;margin-bottom:8px}
.card .sub{font-size:15.5px;line-height:1.5;color:var(--muted)}
.card .sub strong{color:var(--text)}

/* problem (negative) cards */
.neg-card{background:var(--danger-soft);border:1px solid var(--danger-line);border-radius:var(--radius);padding:24px 26px}
.neg-card .label{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--danger);margin-bottom:11px}
.neg-card .title{font-weight:700;font-size:clamp(18px,1.9vw,21px);margin-bottom:8px}
.neg-card .sub{font-size:15.5px;line-height:1.5;color:var(--muted)}
.neg-card .sub strong{color:#f0d9d9}

/* highlight bar */
.bar{border-radius:13px;padding:18px 24px;font-size:clamp(16px,1.7vw,20px);line-height:1.4;font-weight:700;color:var(--text);text-align:center}
.bar.pos{background:var(--accent-soft);border:1px solid var(--accent-line)}
.bar.neg{background:var(--danger-soft);border:1px solid var(--danger-line)}

/* ---------- install meta row (overview) ---------- */
.meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
@media(max-width:760px){.meta-row{grid-template-columns:repeat(2,1fr)}}
.meta{border:1px solid var(--card-line);background:var(--card);border-radius:13px;padding:20px}
.meta .k{font-family:"Anton",sans-serif;font-size:30px;color:var(--accent-2);line-height:1}
.meta .v{font-size:15px;color:var(--muted);margin-top:9px;line-height:1.45}

/* ---------- week timeline ---------- */
.weeks{display:flex;flex-direction:column;gap:14px;margin-top:10px}
.week{display:grid;grid-template-columns:172px 1fr;gap:clamp(18px,3vw,40px);
  border:1px solid var(--card-line);background:var(--card);border-radius:16px;padding:26px 28px;position:relative;overflow:hidden}
@media(max-width:760px){.week{grid-template-columns:1fr;gap:14px}}
.week__side{position:relative}
.week__tag{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-text);margin-bottom:6px}
.week__name{font-weight:800;font-size:21px;letter-spacing:-.02em}
.week__day{display:inline-block;margin-top:12px;font-size:13px;font-weight:700;color:var(--accent-2);
  border:1px solid var(--accent-line);background:var(--accent-soft);border-radius:30px;padding:5px 12px}
.week__live{font-size:15.5px;line-height:1.5;color:var(--text);font-weight:600;margin-bottom:14px}
.week__list{list-style:none;display:flex;flex-direction:column;gap:9px}
.week__list li{position:relative;padding-left:24px;font-size:15px;line-height:1.5;color:var(--muted)}
.week__list li strong{color:var(--text)}
.week__list li::before{content:"";position:absolute;left:2px;top:8px;width:7px;height:7px;border-radius:2px;background:var(--accent);transform:rotate(45deg)}

/* ---------- interactive install timeline ---------- */
.tl__track{position:relative;display:flex;justify-content:space-between;margin:8px 6px 30px;
  padding-top:2px}
.tl__line{position:absolute;left:24px;right:24px;top:9px;height:2px;border-radius:2px;
  background:rgba(216,204,243,.13);overflow:hidden}
.tl__fill{display:block;height:100%;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .45s cubic-bezier(.16,1,.3,1)}
.tl__node{position:relative;display:flex;flex-direction:column;align-items:center;gap:9px;
  background:none;border:0;padding:0;cursor:pointer;font:inherit;color:var(--faint);min-width:48px}
.tl__dot{width:16px;height:16px;border-radius:50%;background:#171221;
  border:2px solid rgba(216,204,243,.3);transition:background .25s,border-color .25s,box-shadow .25s}
.tl__node:hover .tl__dot{border-color:var(--accent-2)}
.tl__node.done .tl__dot{background:var(--accent-2);border-color:var(--accent-2)}
.tl__node.on .tl__dot{background:var(--accent);border-color:var(--accent);
  box-shadow:0 0 0 6px rgba(123,90,217,.18),0 0 24px rgba(123,90,217,.5)}
.tl__wk{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--muted);
  text-transform:uppercase;transition:color .2s;white-space:nowrap}
.tl__node.on .tl__wk{color:var(--text)}
.tl__dy{font-size:12px;color:var(--faint);white-space:nowrap}
.tl__panes{display:grid}
.tl__pane{grid-area:1/1;visibility:hidden;opacity:0;pointer-events:none}
.tl__pane.is-on{visibility:visible;opacity:1;pointer-events:auto}
@media (prefers-reduced-motion: no-preference){
  .tl__pane.is-on{animation:tl-pane .4s cubic-bezier(.16,1,.3,1)}
  @keyframes tl-pane{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:none}}
  .tl__pane.is-on.from-left{animation-name:tl-pane-l}
  @keyframes tl-pane-l{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
}
.tl__nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px}
.tl__arrow{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--card-line);background:var(--card);color:var(--text);
  font-size:18px;line-height:1;cursor:pointer;padding:0;transition:background .18s,border-color .18s,transform .18s}
.tl__arrow:hover:not(:disabled){border-color:var(--accent-line);background:var(--accent-soft);transform:translateY(-1px)}
.tl__arrow:disabled{opacity:.3;cursor:default}
.tl__count{font-size:13.5px;font-weight:600;color:var(--muted);min-width:92px;text-align:center}
@media(max-width:760px){
  .tl__track{margin-inline:0}
  .tl__dy{display:none}
  .tl__wk{font-size:10.5px;letter-spacing:.03em}
  .tl__line{left:14px;right:14px}
  .tl__node{min-width:0}
  .tl__dot{width:14px;height:14px}
  /* no height-lock on mobile — tallest week would leave huge gaps */
  .tl__panes{display:block}
  .tl__pane{display:none;visibility:visible;opacity:1}
  .tl__pane.is-on{display:grid}
}

/* ---------- product screenshot frame ---------- */
.shot{margin:0;border-radius:18px;overflow:hidden;
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#191323,#120d1c) padding-box,
    linear-gradient(180deg,rgba(216,204,243,.28),rgba(216,204,243,.07) 40%,rgba(123,90,217,.18)) border-box;
  box-shadow:0 40px 110px -38px rgba(0,0,0,.85),0 18px 60px -30px rgba(123,90,217,.35)}
.shot__chrome{display:flex;align-items:center;gap:7px;padding:13px 18px;
  border-bottom:1px solid rgba(216,204,243,.1)}
.shot__chrome span{width:10px;height:10px;border-radius:50%;background:rgba(216,204,243,.16)}
.shot__chrome em{font-style:normal;margin-left:10px;font-size:12.5px;font-weight:600;
  letter-spacing:.05em;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shot img{display:block;width:100%;height:auto}
@media(max-width:560px){
  .shot{border-radius:13px}
  .shot__chrome{padding:10px 14px}
  .shot__chrome em{font-size:11px}
}

/* ---------- tools grid (what you own) ---------- */
.tool{border:1px solid var(--card-line);background:var(--card);border-radius:13px;padding:18px 20px;transition:border-color .18s,transform .18s}
.tool:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.tool .tnum{font-family:"Anton",sans-serif;font-size:15px;color:var(--accent-text);letter-spacing:.04em}
.tool .tname{font-weight:700;font-size:16.5px;margin:7px 0 5px}
.tool .tdesc{font-size:15px;line-height:1.5;color:var(--muted)}

/* ---------- proof: quotes + video cards ---------- */
.quote{background:var(--card);border:1px solid var(--card-line);border-radius:16px;padding:28px 30px;display:flex;flex-direction:column;height:100%}
.quote blockquote{font-size:clamp(18px,2vw,22px);line-height:1.45;font-weight:600;letter-spacing:-.01em}
.quote blockquote .hl{color:var(--accent-2)}
.quote figcaption{margin-top:auto;padding-top:20px;font-size:14.5px;color:var(--muted)}
.quote figcaption b{color:var(--accent-2);font-weight:700}
.quotes-row{align-items:stretch}

.vcard{display:block;text-decoration:none;border:1px solid var(--card-line);border-radius:14px;overflow:hidden;background:var(--card);transition:border-color .18s,transform .18s}
.vcard:hover{border-color:var(--accent-line);transform:translateY(-3px)}
.vcard__thumb{position:relative;aspect-ratio:16/9;background:#100c19;overflow:hidden}
.vcard__thumb img{width:100%;height:100%;object-fit:cover;opacity:.92;transition:opacity .2s,transform .3s}
.vcard:hover .vcard__thumb img{opacity:1;transform:scale(1.03)}
.vcard__play{position:absolute;inset:0;margin:auto;width:54px;height:54px;border-radius:50%;
  background:rgba(123,90,217,.92);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(0,0,0,.5)}
.vcard__play::after{content:"";border-left:16px solid #fff;border-top:10px solid transparent;border-bottom:10px solid transparent;margin-left:4px}
.vcard__body{padding:16px 18px 18px}
.vcard__name{font-weight:700;font-size:15.5px}
.vcard__name span{color:var(--accent-2);font-weight:500;font-family:"Fraunces";font-style:italic}
.vcard__res{font-size:15px;color:var(--muted);margin-top:5px;line-height:1.45}

/* ---------- stat band: its own tinted section ---------- */
.band--stats{background:linear-gradient(180deg,rgba(123,90,217,.085),rgba(123,90,217,.035)),var(--bg-2)}
.band--stats::before,.band--stats::after{content:"";position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent-line),transparent)}
.band--stats::before{top:0}.band--stats::after{bottom:0}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:680px){.stats{grid-template-columns:1fr}}
.stat{text-align:center;padding:14px}
.stat .n{font-family:"Anton",sans-serif;font-size:clamp(46px,6vw,72px);line-height:1;color:var(--accent-2)}
.stat .l{font-size:14.5px;color:var(--muted);margin-top:10px}

/* ---------- comparison table ---------- */
.tbl-wrap{overflow-x:auto;border:1px solid var(--card-line);border-radius:16px;background:var(--card)}
table.cmp{border-collapse:collapse;width:100%;min-width:680px}
table.cmp th,table.cmp td{text-align:left;padding:16px 18px;font-size:15.5px;line-height:1.45;border-bottom:1px solid var(--hair);vertical-align:top}
table.cmp thead th{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
table.cmp thead th.own-col{color:var(--accent-2)}
table.cmp tbody th{font-weight:600;color:var(--muted);width:190px}
table.cmp td.own-col{color:var(--text);font-weight:600}
table.cmp .own-col{background:rgba(123,90,217,.07)}
table.cmp tr td.own-col:first-of-type{}
table.cmp tbody tr:last-child td,table.cmp tbody tr:last-child th{border-bottom:0}
.col-flag{display:inline-flex;align-items:flex-start;gap:7px}
.col-flag::before{content:"";flex:none;width:6px;height:6px;margin-top:.5em;border-radius:50%;background:var(--faint)}
.col-flag.good::before{background:var(--accent)}
.col-flag.bad{color:var(--danger)}
.col-flag.bad::before{background:var(--danger)}

/* ---------- fit columns ---------- */
.fit{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.fit{grid-template-columns:1fr}}
.fit__col{border:1px solid var(--card-line);background:var(--card);border-radius:16px;padding:28px 30px}
.fit__col.no{background:var(--danger-soft);border-color:var(--danger-line)}
.fit__col h3{margin-bottom:18px}
.fit__col ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.fit__col li{position:relative;padding-left:30px;font-size:15.5px;line-height:1.45;color:var(--muted)}
.fit__col li strong{color:var(--text)}
.tick,.ex{position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.tick{background:var(--accent-soft);border:1px solid var(--accent-line);color:var(--accent-2)}
.ex{background:var(--danger-soft);border:1px solid var(--danger-line);color:var(--danger)}

/* ---------- guarantee ---------- */
.guarantee{display:grid;grid-template-columns:auto minmax(0,62ch);justify-content:center;gap:clamp(24px,4vw,48px);align-items:center;
  border:1px solid var(--accent-line);background:linear-gradient(180deg,rgba(123,90,217,.10),rgba(123,90,217,.03));
  border-radius:20px;padding:clamp(30px,4vw,46px)}
@media(max-width:680px){.guarantee{grid-template-columns:1fr;text-align:center}}
.seal{width:128px;height:128px;border-radius:50%;border:2px solid var(--accent-line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--accent-soft);margin-inline:auto}
.seal .big{font-family:"Anton",sans-serif;font-size:38px;color:var(--accent-2);line-height:.9}
.seal .sm{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-text);margin-top:6px}

/* two-layer guarantee (seal + headline + cards) */
.guarantees{max-width:60ch;margin-inline:auto;text-align:center;display:flex;flex-direction:column;align-items:center}
.seal--check{width:84px;height:84px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-bottom:24px;
  box-shadow:0 18px 50px -18px rgba(123,90,217,.9),inset 0 1px 0 rgba(255,255,255,.25)}
.guarantee-cards{max-width:860px;margin-inline:auto}
.guarantee-cards .card .sub strong{color:var(--accent-2)}
/* clearer divider where the bg-tone shift alone is too subtle */
.section.band--guard::before{height:1px;background:linear-gradient(90deg,transparent,rgba(242,238,251,.16),transparent)}

/* ---------- FAQ ---------- */
.faq{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,60px);align-items:start}
@media(max-width:860px){.faq{grid-template-columns:1fr;gap:26px}}
.faq__list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--hair)}
.faq__item{border-bottom:1px solid var(--hair)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
  padding:22px 2px;font-weight:600;font-size:17px;color:var(--text)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__pm{flex:0 0 auto;width:22px;height:22px;position:relative;margin-top:2px}
.faq__pm::before,.faq__pm::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:transform .2s,opacity .2s}
.faq__pm::before{top:10px;left:3px;width:16px;height:2px}
.faq__pm::after{top:3px;left:10px;width:2px;height:16px}
.faq__item[open] .faq__pm::after{transform:rotate(90deg);opacity:0}
.faq__ans{padding:0 2px 24px;font-size:15.5px;line-height:1.6;color:var(--muted);max-width:62ch}
.faq__ans strong{color:var(--text)}

/* ---------- demo steps ---------- */
.dsteps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.dsteps{grid-template-columns:1fr}}
.dstep{border:1px solid var(--card-line);background:var(--card);border-radius:16px;padding:28px;position:relative}
.dstep__n{font-family:"Anton",sans-serif;font-size:13px;color:var(--accent-text);letter-spacing:.1em;
  border:1px solid var(--accent-line);border-radius:30px;padding:5px 12px;display:inline-block;margin-bottom:16px}
.dstep h3{margin-bottom:9px}
.dstep p{font-size:15px;line-height:1.5;color:var(--muted)}

/* ---------- final CTA ---------- */
.final{text-align:center}
.final .cta{margin-top:8px}
.final__sub{margin:14px auto 0;color:var(--muted);font-size:15px}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--hair);padding:40px 0}
.footer__in{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__copy{font-size:14.5px;color:var(--faint)}
@media(max-width:760px){.footer .cta{display:none}}

/* ---------- wins wall (masonry) ---------- */
.wall{column-count:3;column-gap:14px;margin-top:10px}
@media(max-width:900px){.wall{column-count:2}}
@media(max-width:560px){.wall{column-count:1}}
.wall__item{break-inside:avoid;margin:0 0 14px;border:1px solid var(--card-line);border-radius:12px;
  overflow:hidden;background:var(--card);cursor:zoom-in;transition:border-color .18s,transform .18s,box-shadow .18s}
.wall__item:hover{border-color:var(--accent-line);transform:translateY(-3px);box-shadow:0 16px 40px -20px rgba(0,0,0,.7)}
.wall__item img{width:100%;height:auto;display:block;opacity:0;transition:opacity .4s ease}
.wall__item img.loaded{opacity:1}

/* ---------- lightbox (images + inline video) ---------- */
.lb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,52px);background:rgba(10,8,15,.88);backdrop-filter:blur(8px)}
.lb.open{display:flex}
.lb__inner{position:relative;max-width:min(1040px,94vw);width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.lb__inner img{max-width:100%;max-height:88vh;border-radius:12px;border:1px solid var(--card-line);box-shadow:0 30px 90px -20px rgba(0,0,0,.8)}
.lb__fallback{font-size:14px;font-weight:600;color:var(--accent-2);text-decoration:none;opacity:.85;transition:opacity .15s}
.lb__fallback:hover{opacity:1;text-decoration:underline}
.lb__video{position:relative;width:100%;aspect-ratio:16/9;max-height:88vh;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 30px 90px -20px rgba(0,0,0,.8)}
.lb__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lb__close{position:absolute;top:max(16px,2vh);right:max(16px,2vw);width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:#fff;border:0;font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5);transition:background .15s}
.lb__close:hover{background:#8d6fe4}

/* ---------- logo mark ---------- */
.logo-mark{width:30px;height:30px;border-radius:8px;object-fit:cover;display:block;flex:0 0 auto}

/* ---------- demo form modal (2-step Tally flow) ---------- */
.fm{position:fixed;inset:0;z-index:400;display:none;align-items:center;justify-content:center;
  padding:clamp(12px,3vw,48px);background:rgba(10,8,15,.38)}
.fm.open{display:flex}
.fm__panel{position:relative;width:min(540px,100%);height:min(760px,94vh);max-height:94vh;
  display:flex;flex-direction:column;border-radius:20px;overflow:hidden;
  border:1px solid rgba(123,90,217,.38);
  background:linear-gradient(180deg,#ffffff,#f6f5f2);
  box-shadow:0 44px 130px -38px rgba(0,0,0,.7),0 0 70px -26px rgba(123,90,217,.45)}
@media (prefers-reduced-motion: no-preference){
  .fm.open{animation:fm-bg .35s ease both}
  .fm.open .fm__panel{animation:fm-in .45s cubic-bezier(.16,1,.3,1)}
  @keyframes fm-bg{from{background:rgba(10,8,15,0)}to{background:rgba(10,8,15,.38)}}
  @keyframes fm-in{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:none;opacity:1}}
}
.fm__head{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 16px 14px 20px;
  background:linear-gradient(135deg,#241D33 0%,#1A1525 100%);
  border-bottom:1px solid rgba(123,90,217,.3)}
.fm__brand{display:flex;align-items:center;gap:11px;min-width:0}
.fm__logo{width:26px;height:26px;border-radius:7px;display:block;flex:0 0 auto;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.fm__title{font-family:"Archivo",sans-serif;font-size:15px;font-weight:700;letter-spacing:.005em;color:#F2EEFB;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fm__close{justify-self:end}
.fm__steps{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;color:#6f6880}
.fm__dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;background:rgba(20,15,30,.07);color:#6f6880;transition:background .25s,color .25s}
.fm__dot.on{background:var(--accent);color:#fff}
.fm__dot.done{background:#2e9e6b;color:#fff}
.fm__sep{width:18px;height:2px;border-radius:2px;background:rgba(20,15,30,.12)}
.fm__close{width:34px;height:34px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  border-radius:50%;border:1px solid rgba(216,204,243,.22);background:rgba(255,255,255,.05);color:#D8CCF3;
  cursor:pointer;padding:0;transition:background .18s,border-color .18s,transform .12s}
.fm__close svg{display:block}
.fm__close:hover{background:rgba(255,255,255,.12);border-color:rgba(216,204,243,.45)}
.fm__close:active{transform:scale(.9)}
.fm__body{position:relative;flex:1;min-height:0;overflow:hidden;padding:4px 14px 18px}
.fm__body iframe{display:block;width:100%;height:100%;border:0;background:transparent}
.fm__body iframe.leaving{opacity:0;transition:opacity .25s ease}
.fm__body iframe.entering{opacity:0}
.fm__body iframe.entered{opacity:1;transition:opacity .3s ease .1s}
@media(max-width:560px){
  /* full-screen sheet on phones: the form fills the screen and scrolls within
     itself — never a cramped scroll-in-a-box */
  .fm{padding:0}
  .fm__panel{width:100%;height:100%;max-height:100%;border-radius:0}
  .fm__head{padding:14px 16px 12px}
}

/* ---------- scroll reveal — transform only, never hides content ---------- */
/* opacity is intentionally never animated: a frozen/blocked animation frame
   still shows fully-visible content instead of a blank page. */
.reveal{transform:none}
@media (prefers-reduced-motion: no-preference){
  html.anim-ready .reveal{transform:translateY(16px);
    transition:transform .6s cubic-bezier(.16,1,.3,1)}
  html.anim-ready .reveal.in{transform:none}
}
@media(prefers-reduced-motion:reduce){.pill .dot{animation:none}}

/* generic stack spacing */
.stack-sm>*+*{margin-top:14px}
.stack>*+*{margin-top:20px}
.mt-s{margin-top:18px}.mt-m{margin-top:28px}.mt-l{margin-top:44px}
.lead+.lead{margin-top:14px}

/* ---------- mobile polish ---------- */
@media(max-width:560px){
  :root{--pad-x:20px}
  body{font-size:16px}
  .ribbon{font-size:12px;padding:8px 14px}
  .nav__in{height:60px}
  .cta--lg{width:100%;justify-content:center}
  .hero--center .hero__cta{width:100%}
  .section{padding:clamp(52px,14vw,72px) 0}
  .tbl-wrap{position:relative}
  .week{padding:22px 20px}
  .quote{padding:24px 22px}
}

/* ============================================================
   HYPER-MODERN LAYER — ambient lighting, glows, motion
   (loops/sheens are decorative; frozen frame still looks clean)
   ============================================================ */

/* softer, airier hairlines */
:root{--hair:rgba(242,238,251,.08)}

/* ---- ambient purple lighting behind hero + final CTA ---- */
.hero{overflow:hidden}
.hero::before{content:"";position:absolute;top:-26%;left:50%;width:120vw;height:90vh;
  transform:translateX(-50%);pointer-events:none;z-index:0;
  background:radial-gradient(42% 50% at 50% 50%,rgba(123,90,217,.20),transparent 70%)}
.hero::after{content:"";position:absolute;top:8%;right:-8%;width:46vw;height:46vw;pointer-events:none;z-index:0;
  background:radial-gradient(50% 50% at 50% 50%,rgba(123,90,217,.10),transparent 70%)}
.hero .wrap{position:relative;z-index:1}
.final{overflow:hidden}
.final::before{content:"";position:absolute;bottom:-40%;left:50%;width:90vw;height:90vh;
  transform:translateX(-50%);pointer-events:none;z-index:0;
  background:radial-gradient(40% 50% at 50% 50%,rgba(123,90,217,.18),transparent 70%)}
.final .wrap{position:relative;z-index:1}

/* ---- hero video: glow halo ---- */
.hero--center .hero__media{position:relative}
.hero--center .hero__media::before{content:"";position:absolute;inset:-10% -6%;z-index:0;pointer-events:none;
  background:radial-gradient(50% 50% at 50% 50%,rgba(123,90,217,.34),transparent 70%);filter:blur(26px)}
.hero--center .vsl{position:relative;z-index:1}
.vsl{box-shadow:0 40px 90px -34px rgba(0,0,0,.8),0 0 0 1px rgba(216,204,243,.06)}

/* ---- pill glow ---- */
.pill{box-shadow:0 0 0 1px rgba(123,90,217,.06),0 8px 30px -16px rgba(123,90,217,.6)}

/* ---- buttons: brand glow + hover sheen ---- */
.cta{position:relative;overflow:hidden;box-shadow:0 12px 34px -12px rgba(123,90,217,.6)}
.cta>*{position:relative;z-index:1}
.cta::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.22) 48%,transparent 66%);
  transform:translateX(-130%)}
.cta:hover{box-shadow:0 16px 44px -10px rgba(123,90,217,.8)}
@media (prefers-reduced-motion: no-preference){
  .cta:hover::after{transform:translateX(130%);transition:transform .7s ease}
}

/* ---- richer card hover (glow lift) ---- */
.card,.tool,.vcard,.week,.quote,.dstep,.wall__item{transition:border-color .22s,background .22s,transform .22s,box-shadow .22s}
.card:hover,.tool:hover,.vcard:hover,.week:hover,.dstep:hover{box-shadow:0 24px 60px -28px rgba(123,90,217,.5)}

/* ---- animated nav underline ---- */
.nav__links a:not(.cta){position:relative}
.nav__links a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:0;
  background:var(--accent);transition:width .26s ease}
.nav__links a:not(.cta):hover::after{width:100%}

/* ---- crisper reveal motion (transform-only, stays visible if frozen) ---- */
@media (prefers-reduced-motion: no-preference){
  html.anim-ready .reveal{transform:translateY(22px) scale(.99);
    transition:transform .65s cubic-bezier(.16,1,.3,1)}
  html.anim-ready .reveal.in{transform:none}
}
/* mobile: no entrance motion — content sits still instead of jumping in */
@media(max-width:640px){
  html.anim-ready .reveal{transform:none;transition:none}
}

/* ============================================================
   MODERN PASS v3 — calmer surfaces, stronger type, fewer boxes
   ============================================================ */

/* ---- type scale: bigger titles, finer labels, airier body ---- */
.h2{font-size:clamp(30px,4.2vw,44px);letter-spacing:-.025em;line-height:1.06}
.h3{font-size:clamp(19px,2.1vw,24px)}
.eyebrow{font-size:12px;letter-spacing:.22em;margin-bottom:16px;opacity:.9}
.body{line-height:1.62;max-width:62ch}
.lead{line-height:1.55}
.display{letter-spacing:-.04em}

/* rule → short fading gradient instead of a hard bar */
.rule{width:64px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),rgba(123,90,217,0));margin:20px 0 24px}

/* ---- surfaces: tone steps instead of borders (fewer boxes) ---- */
:root{
  --surface:rgba(255,255,255,.045);
  --surface-2:rgba(255,255,255,.07);
}
.card,.tool,.meta,.dstep,.quote,.week,.fit__col{
  border-color:transparent;background:var(--surface);
  border-radius:18px;
}
.card:hover,.tool:hover,.dstep:hover,.week:hover{
  border-color:transparent;background:var(--surface-2)}
.card{padding:28px 30px}
.tool{padding:22px 24px}
.dstep{padding:30px}
.quote{padding:30px 32px}
.week{padding:28px 30px}
/* keep the danger tint on negative surfaces, just borderless */
.neg-card{border-color:transparent;border-radius:18px;padding:28px 30px}
.fit__col.no{border-color:transparent}
.bar{border-radius:16px;padding:22px 28px}
.bar.pos{border-color:transparent;background:var(--accent-soft)}
.bar.neg{border-color:transparent}

/* ---- band hairlines: gone — tone shift alone separates sections ---- */
.band::before,.band::after{background:linear-gradient(90deg,transparent,var(--hair),transparent)}

/* ---- VSL: softer mask, deeper ambient shadow, thinner chrome ---- */
.vsl{border-radius:20px;border-color:rgba(216,204,243,.12);
  box-shadow:0 60px 120px -40px rgba(0,0,0,.85),0 0 0 1px rgba(216,204,243,.05)}

/* ---- CTA: full-pill, calmer at rest, lifts on hover ---- */
.cta{border-radius:999px;box-shadow:0 10px 28px -14px rgba(123,90,217,.55)}
.cta:hover{transform:translateY(-2px)}
.cta--lg{padding:20px 42px}

/* ---- pills & step numbers follow the pill language ---- */
.week__day,.dstep__n{border-radius:999px}

/* ---- comparison tables: lighter chrome, stronger "us" column ---- */
.tbl-wrap{border-color:transparent;background:var(--surface);border-radius:18px}
table.cmp .own-col{background:rgba(123,90,217,.10)}
table.cmp thead th.own-col{color:#fff}
table.cmp th,table.cmp td{padding:17px 20px}

/* ---- guarantee: calmer gradient, no hard border ---- */
.guarantee{border-color:rgba(123,90,217,.22);border-radius:24px}

/* ---- wins wall: rounder, borderless tiles ---- */
.wall__item{border-color:transparent;border-radius:14px;background:var(--surface)}
.wall__item:hover{border-color:transparent}

/* ---- video cards ---- */
.vcard{border-color:transparent;background:var(--surface);border-radius:16px}
.vcard:hover{border-color:transparent;background:var(--surface-2)}

/* ---- grid breathing room ---- */
.grid{gap:18px}
.weeks{gap:16px}

/* ---- final CTA: a touch more drama ---- */
.final .display{font-size:clamp(36px,5.6vw,60px)}

/* ============================================================
   WOW PASS — atmosphere, glass, gradient type, motion polish
   ============================================================ */

/* ---- film grain over everything (depth without clutter) ---- */
body::after{content:"";position:fixed;inset:0;z-index:2400;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px}

/* ---- hero aurora: soft drifting color field at the top ---- */
html{overflow-x:clip}   /* aurora + glows may exceed viewport; never allow sideways scroll */
.hero--center{overflow:visible}
.hero--center::before{content:"";position:absolute;left:-10%;right:-10%;top:-18%;height:85%;
  z-index:0;pointer-events:none;filter:blur(34px);
  background:
    radial-gradient(38% 48% at 22% 8%,rgba(123,90,217,.20),transparent 70%),
    radial-gradient(30% 42% at 78% 4%,rgba(96,128,222,.13),transparent 70%),
    radial-gradient(46% 56% at 52% 0%,rgba(165,137,236,.10),transparent 72%)}
@media (prefers-reduced-motion: no-preference){
  .hero--center::before{animation:aurora 22s ease-in-out infinite alternate}
  @keyframes aurora{
    from{transform:translate3d(-2.5%,0,0) scale(1)}
    to{transform:translate3d(2.5%,1.5%,0) scale(1.06)}
  }
}

/* ---- gradient display type: white falling into lavender ---- */
.display,.h2{
  background:linear-gradient(180deg,#ffffff 0%,#f2eefb 52%,#c3b3e4 115%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:#f2eefb}
.display .serif,.h2 .serif{-webkit-text-fill-color:var(--accent-2)}

/* ---- glass cards: 1px gradient ring, light falls from the top ---- */
.card,.tool,.meta,.dstep,.quote,.week,.fit__col.yes,.vcard{
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#2b2537,#241e2f) padding-box,
    linear-gradient(180deg,rgba(216,204,243,.22),rgba(216,204,243,.04) 60%) border-box}
.card:hover,.tool:hover,.dstep:hover,.week:hover,.vcard:hover{
  background:
    linear-gradient(180deg,#312a3f,#272135) padding-box,
    linear-gradient(180deg,rgba(216,204,243,.34),rgba(216,204,243,.08) 60%) border-box}
.neg-card,.fit__col.no{
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#2b1a28,#231827) padding-box,
    linear-gradient(180deg,rgba(217,106,106,.28),rgba(217,106,106,.06) 60%) border-box}
.wall__item{
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#2a2335,#241e2e) padding-box,
    linear-gradient(180deg,rgba(216,204,243,.16),rgba(216,204,243,.03) 60%) border-box}
.tbl-wrap{
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#292332,#221c2b) padding-box,
    linear-gradient(180deg,rgba(216,204,243,.18),rgba(216,204,243,.04) 60%) border-box}
.guarantee{
  border:1px solid transparent;
  background:
    linear-gradient(180deg,#271f3b,#1f192b) padding-box,
    linear-gradient(180deg,rgba(165,137,236,.38),rgba(165,137,236,.07) 70%) border-box}

/* ---- big stat numbers: gradient ink ---- */
.meta .k{
  background:linear-gradient(180deg,#e9e2fa,var(--accent-2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---- quotes: a whisper of a serif quote mark ---- */
.quote{position:relative}
.quote::before{content:"\201C";position:absolute;top:2px;right:18px;font-family:"Fraunces",serif;
  font-size:92px;line-height:1;color:rgba(165,137,236,.14);pointer-events:none}
.quote figcaption{margin-top:auto;padding-top:22px}

/* ---- ribbon: quiet, typographic ---- */
.ribbon{background:rgba(123,90,217,.10);color:var(--accent-2);
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  padding:10px 16px;border-bottom:1px solid rgba(123,90,217,.14)}

/* ---- nav: floating glass pill ---- */
.nav{background:transparent;backdrop-filter:none;border-bottom:0;padding:12px 0}
.nav.is-stuck{background:transparent;border-bottom-color:transparent}
.nav__in{height:56px;width:min(1080px,calc(100% - 32px));padding:0 10px 0 24px;
  border-radius:999px;
  background:rgba(28,23,38,.55);backdrop-filter:blur(20px) saturate(1.5);
  -webkit-backdrop-filter:blur(20px) saturate(1.5);
  border:1px solid rgba(216,204,243,.10);
  box-shadow:0 18px 50px -22px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.05);
  transition:background .25s,box-shadow .25s}
.nav.is-stuck .nav__in{background:rgba(22,17,31,.78);
  box-shadow:0 22px 60px -22px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.06)}
.nav .cta.cta--sm{padding:9px 18px;font-size:14px}

/* ---- CTAs: gradient ink, inner light, shine sweep ---- */
.cta{position:relative;overflow:hidden;
  background:linear-gradient(180deg,#9272ea,#7048d2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 14px 34px -14px rgba(123,90,217,.6)}
.cta:hover{background:linear-gradient(180deg,#9d7ff0,#7b55dd);transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 20px 44px -16px rgba(123,90,217,.75)}
.cta::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.25) 48%,transparent 62%);
  transform:translateX(-130%)}
@media (prefers-reduced-motion: no-preference){
  .cta::before{transition:transform .65s ease}
  .cta:hover::before{transform:translateX(130%)}
}

/* ---- VSL: hairline light along the top edge ---- */
.vsl{box-shadow:0 60px 120px -40px rgba(0,0,0,.85),
  inset 0 1px 0 rgba(255,255,255,.08),0 0 0 1px rgba(216,204,243,.07)}

/* ---- selection ink ---- */
::selection{background:rgba(123,90,217,.5);color:#fff}

/* ============================================================
   MOBILE FIXES
   ============================================================ */

/* stat pill: no pulsing-dot artifact; one tight line on small screens */
.pill--stat .dot{display:none}
@media(max-width:760px){
  .hero--center .pill--stat{font-size:13px;letter-spacing:0;gap:7px;padding:10px 16px;
    white-space:normal;text-align:center;line-height:1.4}
  .hero--center .pill--stat b{font-size:14.5px;margin-right:3px}
  .hero--center .pill--stat .pill__sep{margin:0 2px}
}

/* tighten the dead air between nav and hero on mobile (sizing overrides live at end of file) */
@media(max-width:560px){
  .hero--center{padding-block:8px 14px}
}

/* hide the nav entirely on mobile — ribbon + hero CTA carry it */
@media(max-width:760px){
  .nav{display:none}
  html{scroll-padding-top:16px}
}

/* hero steps: kill the 220px flex-basis-as-height in column layout */
@media(max-width:680px){
  .hstep{flex:0 0 auto}
}

/* comparison table on mobile: compact "vs" switcher (built by engine.js).
   One card, Client Engine vs ONE alternative at a time — no long scroll. */
.cmpm{display:none}
@media(max-width:700px){
  .tbl-wrap{display:none}
  .cmpm{display:block}
  .cmpm__tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;
    background:var(--card);border:1px solid var(--card-line);border-radius:13px;margin:22px 0 14px}
  .cmpm__tab{font-family:inherit;font-size:13.5px;font-weight:700;color:var(--muted);
    background:transparent;border:0;border-radius:9px;padding:10px 2px;cursor:pointer;
    transition:color .15s,background .15s}
  .cmpm__tab.on{color:#fff;background:var(--accent)}
  .cmpm__card{border:1px solid var(--card-line);background:var(--card);border-radius:16px;padding:4px 18px 18px}
  .cmpm__head{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:15px 0 4px;
    font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}
  .cmpm__head .us{color:var(--accent-2)}
  .cmpm__head .them{color:var(--faint)}
  .cmpm__row{padding:0}
  .cmpm__crit{display:flex;align-items:center;gap:12px;margin:16px 0 9px;
    font-size:10.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);white-space:nowrap}
  .cmpm__crit::before,.cmpm__crit::after{content:"";height:1px;background:var(--hair);flex:1}
  .cmpm__crit::before{flex:0 0 0px;display:none}
  .cmpm__pair{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .cmpm__pair .us{font-size:14.5px;font-weight:700;color:var(--text);line-height:1.5;text-wrap:pretty}
  .cmpm__pair .them{font-size:14.5px;color:var(--muted);line-height:1.5;text-wrap:pretty}
  .cmpm__card.swap .them{animation:cmpm-fade .28s both}
}
@keyframes cmpm-fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---- floating mini player: VSL keeps playing bottom-right ---- */
.vsl.is-mini,
.hero--center .vsl.is-mini{
  position:fixed;right:18px;bottom:18px;z-index:300;margin:0;
  width:min(380px,calc(100vw - 36px));max-width:none;height:auto;max-height:none;
  border-radius:14px;
  box-shadow:0 24px 60px -18px rgba(0,0,0,.9),0 0 0 1px rgba(216,204,243,.12);
}
@media (prefers-reduced-motion: no-preference){
  .vsl.is-mini{animation:vsl-pop .5s cubic-bezier(.16,1,.3,1)}
  @keyframes vsl-pop{
    from{transform:translateY(20px) scale(.94);opacity:0}
    to{transform:none;opacity:1}
  }
}
.vsl__close{display:none;position:absolute;top:8px;right:8px;z-index:5;
  width:32px;height:32px;align-items:center;justify-content:center;
  border-radius:50%;border:1px solid rgba(216,204,243,.25);
  background:rgba(16,12,25,.78);color:#fff;font-size:17px;line-height:1;
  cursor:pointer;backdrop-filter:blur(6px);padding:0}
.vsl.is-mini .vsl__close{display:flex}
.vsl__close:hover{background:rgba(123,90,217,.9);border-color:transparent}
@media(max-width:560px){
  .vsl.is-mini,.hero--center .vsl.is-mini{width:min(300px,calc(100vw - 28px));right:14px;bottom:14px}
}

/* ---- hero hierarchy: headline leads, everything else steps back ---- */
.hero--center .display{font-size:min(clamp(30px,5vw,56px),5.4vh);max-width:1080px;word-spacing:.09em;text-wrap:balance}
.hero--center{padding-top:clamp(8px,1.4vh,16px);padding-bottom:clamp(12px,2.4vh,30px)}
.hero__stack{gap:clamp(8px,1.3vh,14px)}
.hero--center .vsl{width:min(100%,1120px);max-height:none}
/* video absorbs whatever height the text doesn't use — bigger screens get a bigger video,
   and the centering slack (dead air above the pill) goes to the player instead */
@media(min-width:561px){
  .hero--center .vsl{width:min(100%,1120px,max(640px,calc((100svh - 600px) * 16 / 9)))}
}
/* short laptop screens: tighten every link in the chain so it still fits one screen */
@media(min-width:561px) and (max-height:780px){
  .hero--center .display{font-size:min(5.4vw,6vh)}
  .hero--center .vsl{width:min(100%,calc(34vh * 16 / 9))}
  .pilot-line{font-size:13px;margin-bottom:10px}
  .pilot-line b{font-size:14px}
  .hero__stack{gap:clamp(8px,1.3vh,13px)}
  .hero--center .cta--lg{font-size:17px;padding:13px 28px}
  .hero--center .pill--stat{padding:9px 20px;font-size:14.5px}
  .hero--center .pill--stat b{font-size:16px}
  .hstep{font-size:13.5px}
}
/* very short windows (split screens, small laptops at high zoom) */
@media(min-width:561px) and (max-height:620px){
  .hero--center{padding-block:6px}
  .hero--center .display{font-size:min(4.8vw,5.4vh)}
  .hero--center .vsl{width:min(100%,calc(30vh * 16 / 9))}
  .pilot-line{display:none}
  .hero__stack{gap:clamp(5px,1vh,9px)}
  .hero--center .cta--lg{font-size:15px;padding:10px 22px}
  .hstep{font-size:12px}
  .hstep__n{width:18px;height:18px;font-size:10.5px}
  .hero--center .pill--stat{padding:7px 16px;font-size:13px}
}
.hero--center .rule{display:none}            /* headline → video, no divider needed */
.hero__sub{max-width:min(96ch,100%);margin-inline:auto;font-size:clamp(14.5px,1.5vw,17.5px);line-height:1.5;
  color:var(--muted);text-wrap:balance}
.hero__sub strong{color:var(--text);font-weight:600}
/* sub-header reads as a caption: clearly narrower than the headline */
.hero--center .hero__sub{max-width:760px;margin-inline:auto}
/* desktop: pin the hero stack to the top — centering slack was reading as a
   big margin between the nav and the pill; leftover space falls below the steps */
@media(min-width:561px){
  .hero--center{align-items:flex-start;padding-top:clamp(6px,1vh,12px)}
  .pilot-line{margin-bottom:8px}
  .hero__stack{gap:clamp(12px,2.4vh,30px)}
}
@media(min-width:561px) and (max-height:780px){.hero__sub{font-size:14px;max-width:88ch}}
@media(min-width:561px) and (max-height:620px){.hero__sub{display:none}}
.pill--stat{background:transparent;border-color:var(--hair);box-shadow:none;
  font-size:17px;font-weight:600;color:var(--text);padding:13px 28px}
.pill--stat b{font-size:17px}
.hstep{color:var(--faint)}
.hstep__n{background:transparent;border-color:var(--hair);color:var(--accent-text)}

/* ---- CTA state hygiene ----
   touch devices: tapping leaves :hover stuck on the button (iOS especially),
   so the washed-out lighter hover gradient stays visible — disable hover
   styling entirely where there is no real pointer */
@media (hover: none){
  .cta:hover{background:linear-gradient(180deg,#9272ea,#7048d2);transform:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 14px 34px -14px rgba(123,90,217,.6)}
  .cta:hover::before,.cta:hover::after{transform:translateX(-130%)}
}
/* label text joins .cta>* on the z-index:1 layer (it was a bare text node
   below the shine pseudo-layers; the arrow span was above — uneven crispness) */
.cta .cta__t{position:relative;z-index:1}

/* ---- mobile hero: compact enough that video + CTA + steps fit one screen ----
   (last in file so it wins over the desktop-tier rules above) */
.hero__actions{display:contents}  /* desktop: behaves as before, stack owns layout */
@media(max-width:560px){
  .hero--center .display{margin-top:0;font-size:31px;line-height:1.12;margin-inline:0;max-width:none;width:auto;text-wrap:pretty}
  .hero__sub{font-size:14.5px;line-height:1.45;margin-inline:auto;width:330px;max-width:100%;text-wrap:pretty}
  .hero__stack{gap:clamp(16px,3.4vh,40px);justify-content:center}
  .hero--center .vsl{width:100%}
  .hero__guard{flex-direction:column;align-items:stretch;gap:8px;width:100%}
  .hero__guard .guard{width:100%;justify-content:flex-start;align-items:center;gap:12px;padding:13px 20px;white-space:normal;text-align:left}
  .hero--center .cta--lg{font-size:17px;padding:15px 24px}
  /* button + steps share one column, equal width, centered as a unit */
  .hero__actions{display:block;width:340px;max-width:100%;margin-inline:auto}
  .hero__actions .hero__cta{width:auto;margin-bottom:24px}
  .hero__actions .cta--lg{width:100%;justify-content:center}
  .hero__steps{gap:9px;max-width:none}
  .hstep{font-size:13px;line-height:1.4;justify-content:flex-start;text-align:left}
  .hstep__t{flex:0 1 auto}
  .hstep__n{width:23px;height:23px;font-size:11.5px}
  .hero--center .pill--stat{font-size:12px;padding:9px 16px}
}
/* taller phones (iPhone Pro/Max class): scale the whole hero up to use the room */
@media(max-width:560px) and (min-height:760px){
  .hero--center .display{font-size:34px}
  .hero__sub{font-size:16px;width:340px}
  .hero__stack{gap:clamp(18px,4vh,48px)}
  .hero--center .cta--lg{font-size:18px;padding:17px 24px}
  .hero__actions{width:356px}
  .hstep{font-size:14px}
  .hstep__n{width:25px;height:25px;font-size:12px}
  .hero--center .pill--stat{font-size:12.5px;padding:10px 18px}
}

/* ============================================================
   Pilot cohort (Friday → Wednesday window)
   ============================================================ */

/* urgency line above the hero CTA */
.pilot-line{font-size:14.5px;font-weight:600;color:var(--accent-2);margin:0 0 14px;text-align:center}
.pilot-line b{font-family:"Anton",sans-serif;font-weight:400;font-size:16px}

/* the math block */
.pilot-math{border:1px solid var(--accent-line);border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg,rgba(123,90,217,.10),rgba(123,90,217,.03))}
.pilot-math__head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:14px 26px;border-bottom:1px solid var(--accent-line);
  font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2)}
.pilot-math__head b{font-weight:800;color:#fff}
.pilot-math__grid{display:grid;grid-template-columns:1fr 1.18fr 1fr}
.pm-col{display:flex;flex-direction:column;gap:7px;padding:28px 26px}
.pm-col+.pm-col{border-left:1px solid var(--hair)}
.pm-col .k{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.pm-col .n{font-family:"Anton",sans-serif;font-size:clamp(34px,3.6vw,46px);line-height:1;color:var(--text)}
.pm-col--old .n{color:var(--faint);text-decoration:line-through;
  text-decoration-thickness:3px;text-decoration-color:var(--danger)}
.pm-col--new{background:rgba(123,90,217,.10)}
.pm-col--new .n{color:var(--accent-2)}
.pm-col .s{font-size:14px;line-height:1.5;color:var(--muted);text-wrap:pretty}
.pilot-math__foot{margin:0;padding:16px 26px;border-top:1px solid var(--hair);
  font-size:14.5px;line-height:1.55;color:var(--muted);text-wrap:pretty}
@media(max-width:760px){
  .pilot-math__grid{grid-template-columns:1fr}
  .pm-col{padding:20px 22px}
  .pm-col+.pm-col{border-left:0;border-top:1px solid var(--hair)}
  .pilot-math__head{padding:13px 22px}
  .pilot-math__foot{padding:14px 22px}
  .pilot-line{font-size:13px}
}
