/* ════════════════════════════════════════════════════════════
   SAMA REVERSAL · vishakmoopar.com
   Built on the Sama design system - Clinical authority, warmed.
   ════════════════════════════════════════════════════════════ */

:root{
  --ink:#16201E; --ink-soft:#2A332F;
  --teal-900:#0A3437; --teal-700:#0E4A4E; --teal-500:#14686C; --teal-200:#BBD3D2; --teal-050:#E7F0EE;
  --green-600:#2F8A63; --green-500:#3A9C72; --green-050:#E7F1EA;
  --sand:#F4EFE5; --bone:#FCFAF4; --white:#FFFFFF;
  --line:#E5DECF; --line-strong:#D8CFBC;
  --muted:#5C635F; --faint:#8B908A;
  --watch:#C28A1F; --high:#BB5E3C;
  --focus:#14686C;

  --font-display:'Spectral',Georgia,'Times New Roman',serif;
  --font-sans:'IBM Plex Sans',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',monospace;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px; --r-pill:999px;

  --e-1:0 1px 2px rgba(20,40,38,.06), 0 1px 1px rgba(0,0,0,.03);
  --e-2:0 4px 16px -6px rgba(14,74,78,.16), 0 1px 3px rgba(20,40,38,.06);
  --e-3:0 18px 48px -16px rgba(14,74,78,.22), 0 2px 6px rgba(20,40,38,.07);

  --ease:cubic-bezier(.2,.6,.2,1);
  --dur:220ms;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--sand);color:var(--ink);
  font-family:var(--font-sans);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:var(--teal-700);text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:3px}

.wrap{max-width:1120px;margin:0 auto;padding:0 32px;position:relative}
.wrap.narrow{max-width:760px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.ink{color:var(--ink)}
.ink-soft{color:var(--ink-soft);font-style:normal}
.muted{color:var(--muted)}
.serif{font-family:var(--font-display)}
em,i.emph{font-style:italic;font-family:var(--font-display);font-weight:400;color:var(--teal-700)}

/* ──── typography ──── */
.display{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(2.4rem,1.4rem+3vw,3.6rem);line-height:1.06;
  letter-spacing:-0.018em;margin:18px 0 0;color:var(--ink);
  text-wrap:balance;
}
h2,.h2{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.7rem,1.2rem+1.6vw,2.5rem);line-height:1.18;
  letter-spacing:-0.01em;margin:14px 0 0;color:var(--ink);text-wrap:balance;
}
h3,.h3{font-family:var(--font-sans);font-weight:600;font-size:1.35rem;line-height:1.3;color:var(--ink);margin:0}
.h-serif h3,h3.serif{font-family:var(--font-display);font-weight:500;font-size:1.45rem;letter-spacing:-0.005em}
p{margin:14px 0 0;color:var(--ink-soft)}
.sub{font-size:1.18rem;line-height:1.6;color:var(--ink-soft);margin:22px 0 0;max-width:48ch}
.caption{font-size:.85rem;color:var(--muted);line-height:1.55}
.metric{font-family:var(--font-mono);font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:var(--ink)}

.eyebrow{
  font-family:var(--font-mono);font-weight:500;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--teal-500);
  display:inline-flex;align-items:center;gap:8px;
}
.eyebrow i{width:14px;height:14px}
.eyebrow.eb-light{color:#BBD3D2}
.eyebrow.center-eb{justify-content:center;display:flex}

/* ──── buttons ──── */
.btn{
  font-family:var(--font-sans);font-weight:600;font-size:.98rem;
  border-radius:var(--r-pill);padding:13px 22px;border:1.5px solid transparent;
  cursor:pointer;line-height:1;display:inline-flex;align-items:center;gap:10px;
  text-decoration:none;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.btn i{width:16px;height:16px;flex-shrink:0}
.btn-primary{background:var(--teal-700);color:#FCFAF4}
.btn-primary:hover{background:var(--teal-500);box-shadow:var(--e-2);color:#FCFAF4}
.btn-primary:active{background:var(--teal-900);transform:translateY(1px)}
.btn-secondary{background:transparent;color:var(--teal-700);border-color:var(--line-strong)}
.btn-secondary:hover{border-color:var(--teal-500);color:var(--teal-500);background:rgba(20,104,108,.04)}
.btn-ghost{background:transparent;color:var(--teal-700);padding:10px 8px;border:0}
.btn-ghost:hover{color:var(--teal-500)}
.btn-light{background:#FCFAF4;color:var(--teal-900)}
.btn-light:hover{background:#fff;box-shadow:var(--e-2);transform:translateY(-1px)}
.btn-outline-light{background:transparent;color:#FCFAF4;border-color:rgba(252,250,244,.5)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn.wide{display:flex;justify-content:center;width:100%;padding:15px 22px}

/* ──── nav ──── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(244,239,229,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.nav.scrolled{background:rgba(244,239,229,.92);border-bottom-color:var(--line);box-shadow:0 4px 18px -10px rgba(14,74,78,.18)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand-mark{width:32px;height:32px;color:var(--teal-700)}
.brand-mark.light{color:#FCFAF4}
.brand-logo{display:block;height:44px;width:auto;max-width:200px;object-fit:contain;transition:opacity var(--dur) var(--ease)}
.brand:hover .brand-logo{opacity:.85}
.footer-logo{height:48px;max-width:220px}
@media (max-width:860px){.brand-logo{height:36px;max-width:160px}.footer-logo{height:42px}}
.brand .wm{font-family:var(--font-display);font-weight:500;font-size:1.6rem;letter-spacing:-.02em;color:var(--ink);line-height:1}
.brand .wm-thin{font-weight:300;color:var(--teal-700)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.95rem;color:var(--ink-soft);font-weight:500;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--teal-700);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}
.nav-links a:hover{color:var(--teal-700)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{padding:10px 18px;font-size:.9rem}
@media (max-width:860px){.nav-links{display:none}.nav-cta{padding:9px 14px;font-size:.85rem}.brand .wm{font-size:1.3rem}}

/* ──── hero ──── */
.hero{padding:80px 0 90px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;position:relative;z-index:2}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:48px}.hero{padding:48px 0 64px}}

.hero-cta{display:flex;gap:14px;margin-top:32px;align-items:center;flex-wrap:wrap}
.reassure{display:flex;gap:22px;margin-top:30px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line)}
.reassure span{display:inline-flex;align-items:center;gap:8px;font-size:.92rem;color:var(--muted)}
.reassure i{width:16px;height:16px;color:var(--green-600);stroke-width:2.25}

/* photo placeholder */
.photo{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--line);
  background:linear-gradient(150deg,#E9E2D2,#DCEAE4 70%);
  box-shadow:var(--e-2);min-height:440px;
}
.ph-label{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;
  gap:8px;color:#7C8A82;font-size:.85rem;text-align:center;padding:24px;
}
.ph-label i{width:30px;height:30px}
.ph-label .caption{color:#90998F}

/* floating metric card */
.float-card{
  position:absolute;left:24px;right:24px;bottom:24px;
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--e-3);padding:18px 20px;
}
.mc-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.mc-num{display:flex;align-items:baseline;gap:16px;margin-top:10px}
.mc-val{font-family:var(--font-mono);font-weight:500;font-size:2.4rem;color:var(--teal-700);line-height:1}
.mc-arrow{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.85rem;color:var(--green-600)}
.mc-arrow i{width:14px;height:14px}
.mc-bar{position:relative;height:8px;background:var(--sand);border-radius:var(--r-pill);margin-top:18px;overflow:visible}
.mc-band{position:absolute;left:24%;right:45%;top:0;bottom:0;background:var(--green-050);border-radius:var(--r-pill)}
.mc-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,var(--high),var(--watch) 60%,var(--green-600));border-radius:var(--r-pill);transition:width 1.4s var(--ease)}
.mc-tick{position:absolute;top:-2px;width:1px;height:12px;background:var(--line-strong)}
.mc-tick span{position:absolute;top:14px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.65rem;color:var(--faint);letter-spacing:.04em}
.mc-foot{display:flex;align-items:center;gap:6px;margin-top:26px;color:var(--muted)}
.mc-foot i{width:13px;height:13px}

.status{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.72rem;color:var(--green-600);text-transform:uppercase;letter-spacing:.1em}
.status.in-range{color:var(--green-600)}
.pulse-dot{position:relative;width:8px;height:8px;border-radius:50%;background:var(--green-600);flex-shrink:0}
.pulse-dot::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--green-600);animation:pulse 2.4s var(--ease) infinite;opacity:.6}
@keyframes pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.4);opacity:0}}

/* ──── trust bar ──── */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bone)}
.trust-in{display:flex;justify-content:space-between;gap:24px;padding:28px 0;flex-wrap:wrap}
.stat{display:flex;flex-direction:column;gap:4px}
.stat .n{font-family:var(--font-mono);font-weight:500;font-size:1.9rem;color:var(--teal-700);letter-spacing:-.01em}
.stat .l{font-size:.88rem;color:var(--muted)}

/* ──── sections ──── */
.section{padding:96px 0;position:relative}
.section.alt{background:var(--bone);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.s-head{max-width:62ch}
.s-head.center{margin:0 auto 12px;text-align:center}
.s-head p{font-size:1.05rem;color:var(--ink-soft);margin:18px 0 0}
@media (max-width:720px){.section{padding:64px 0}}

/* ──── split / cards ──── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:40px}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:36px}}

.diagram{background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);padding:28px 30px;box-shadow:var(--e-1)}
.diagram .row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);transition:background var(--dur) var(--ease)}
.diagram .row:last-of-type{border-bottom:0}
.diagram .row:hover{background:rgba(20,104,108,.025)}
.diagram .row .dot{width:10px;height:10px;border-radius:999px;flex:0 0 10px}
.diagram .row .t{font-size:.98rem;color:var(--ink)}
.diagram .row .v{margin-left:auto;font-family:var(--font-mono);font-size:.85rem;color:var(--muted)}
.legend-foot{display:flex;align-items:center;gap:6px;margin-top:14px;color:var(--faint)}
.legend-foot i{width:13px;height:13px}

.explainer-copy h3{font-family:var(--font-display);font-weight:500;font-size:1.6rem;line-height:1.2;letter-spacing:-.005em;margin:0 0 14px}
.explainer-copy p{font-size:1.02rem}
.check-list{list-style:none;padding:0;margin:20px 0 0}
.check-list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:.98rem;color:var(--ink-soft)}
.check-list i{width:18px;height:18px;color:var(--green-600);flex-shrink:0;margin-top:3px;stroke-width:2}

/* 3-card row */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
@media (max-width:900px){.cards3{grid-template-columns:1fr}}
.card{
  background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--e-1);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.card:hover{transform:translateY(-3px);box-shadow:var(--e-2);border-color:var(--line-strong)}
.section.alt .card{background:var(--sand)}
.card .ic{
  width:48px;height:48px;border-radius:var(--r-md);background:var(--teal-050);color:var(--teal-700);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.card:hover .ic{background:#D9E6E4;transform:rotate(-4deg) scale(1.04)}
.card .ic i{width:22px;height:22px;stroke-width:1.75}
.card .step{font-family:var(--font-mono);font-size:.75rem;color:var(--teal-500);letter-spacing:.12em;text-transform:uppercase}
.card h3{font-family:var(--font-display);font-weight:500;font-size:1.3rem;margin:8px 0 10px;color:var(--ink);letter-spacing:-.005em;line-height:1.2}
.card p{font-size:.97rem;line-height:1.6;color:var(--ink-soft);margin:0 0 14px}
.card .mini{list-style:none;padding:0;margin:14px 0 0;border-top:1px dashed var(--line);padding-top:14px}
.card .mini li{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:.88rem;color:var(--muted)}
.card .mini i{width:14px;height:14px;color:var(--green-600)}

/* ──── results ──── */
.results-split{grid-template-columns:1fr 1.1fr;align-items:center}
@media (max-width:900px){.results-split{grid-template-columns:1fr}}
.results-copy h2{margin:14px 0 0}
.results-copy p{margin-top:18px;font-size:1.04rem}
.results-copy .btn{margin-top:24px}

.result-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);padding:28px;box-shadow:var(--e-2)}
.rc-head{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.rc-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.7rem;color:var(--watch);background:var(--watch-050,#F6ECD6);padding:4px 10px;border-radius:var(--r-pill);letter-spacing:.08em;text-transform:uppercase}
.rc-tag i{width:11px;height:11px}
.chart{position:relative;height:240px;margin-top:18px}
.chart-svg{width:100%;height:100%}
.res-line{stroke-dasharray:1400;stroke-dashoffset:1400;transition:stroke-dashoffset 1.8s var(--ease)}
.reveal.in-view .res-line{stroke-dashoffset:0}
#resDot{opacity:0;transition:opacity .5s var(--ease) 1.6s}
.reveal.in-view #resDot{opacity:1}
.legend{display:flex;gap:22px;margin-top:14px;font-size:.82rem;color:var(--muted)}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend .sw{width:14px;height:14px;border-radius:3px}
.rc-foot{display:flex;align-items:center;gap:6px;margin-top:14px;color:var(--faint)}
.rc-foot i{width:13px;height:13px}

/* ──── offer (the cohort) ──── */
.offer{
  margin-top:36px;background:var(--white);border:1px solid var(--line);
  border-radius:var(--r-xl);padding:36px clamp(24px,3vw,40px);box-shadow:var(--e-3);position:relative;overflow:hidden;
}
.offer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal-700),var(--green-600));
}
.offer-top{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.offer-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.78rem;color:var(--green-600);text-transform:uppercase;letter-spacing:.1em;background:var(--green-050);padding:7px 14px;border-radius:var(--r-pill)}
.offer-mono{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.78rem;color:var(--muted);letter-spacing:.06em}
.offer-mono i{width:14px;height:14px}

.offer-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start}
@media (max-width:860px){.offer-grid{grid-template-columns:1fr;gap:32px}}
.offer-incl h3{font-family:var(--font-display);font-weight:500;font-size:1.4rem;letter-spacing:-.005em;margin:0 0 18px}
.incl{list-style:none;padding:0;margin:0}
.incl li{
  display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);
  font-size:.98rem;color:var(--ink);opacity:0;transform:translateX(-12px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);
}
.offer.in-view .incl li{opacity:1;transform:none}
.offer.in-view .incl li:nth-child(1){transition-delay:.0s}
.offer.in-view .incl li:nth-child(2){transition-delay:.08s}
.offer.in-view .incl li:nth-child(3){transition-delay:.16s}
.offer.in-view .incl li:nth-child(4){transition-delay:.24s}
.offer.in-view .incl li:nth-child(5){transition-delay:.32s}
.offer.in-view .incl li:nth-child(6){transition-delay:.40s}
.incl li:last-child{border-bottom:0}
.incl li i{width:20px;height:20px;color:var(--teal-700);flex-shrink:0;margin-top:1px;stroke-width:1.75}

.offer-price{
  background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 26px;text-align:left;display:flex;flex-direction:column;gap:14px;
}
.price-num{font-family:var(--font-display);font-weight:500;font-size:3rem;color:var(--teal-700);line-height:1;letter-spacing:-.01em;display:flex;align-items:baseline;gap:4px;margin-top:4px}
.price-num .ccy{font-size:1.6rem;color:var(--teal-700)}
.price-num .metric{font-family:var(--font-display);color:var(--teal-700)}
.price-meta{color:var(--muted);margin:0}
.offer-price .btn{margin-top:6px}
.offer-price .caption{display:flex;align-items:center;gap:7px;color:var(--muted);margin-top:6px}
.offer-price .caption i{width:14px;height:14px;color:var(--green-600);flex-shrink:0}

/* ──── success stories ──── */
.stories-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;align-items:stretch;
}
@media (max-width:980px){.stories-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.stories-grid{grid-template-columns:1fr}}

.story-card{
  display:flex;flex-direction:column;
  background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--e-1);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.story-card:hover{transform:translateY(-3px);box-shadow:var(--e-2);border-color:var(--line-strong)}

.story-photo{
  position:relative;margin:0;aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(150deg,#E9E2D2,#DCEAE4 70%);
}
.story-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.story-card:hover .story-photo img{transform:scale(1.04)}
.story-tag{
  position:absolute;left:14px;top:14px;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:#FCFAF4;background:rgba(14,74,78,.85);backdrop-filter:blur(8px);
  padding:6px 12px;border-radius:var(--r-pill);z-index:3;
}
.story-tag .pulse-dot{background:var(--green-500)}
.story-tag .pulse-dot::before{background:var(--green-500)}

/* ─── story play overlay (Wistia) ─── */
.story-card.has-video .story-photo::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(14,74,78,.55));
  opacity:0;transition:opacity var(--dur) var(--ease);pointer-events:none;z-index:2;
}
.story-card.has-video:hover .story-photo::after{opacity:1}
.story-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:rgba(252,250,244,.94);backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--teal-700);
  box-shadow:0 12px 32px -8px rgba(14,74,78,.5);
  transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);
  z-index:4;
}
.story-play i{width:26px;height:26px;margin-left:3px;fill:currentColor;stroke:currentColor;stroke-width:1.5}
.story-play .sp-ring{
  position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(252,250,244,.55);
  animation:spRing 2.4s var(--ease) infinite;
}
@keyframes spRing{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.25);opacity:0}}
.story-card.has-video:hover .story-play{transform:translate(-50%,-50%) scale(1.06);background:#fff}
.story-vid-tag{
  position:absolute;right:14px;bottom:14px;z-index:3;
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--teal-900);background:rgba(252,250,244,.95);
  padding:6px 12px;border-radius:var(--r-pill);
  box-shadow:0 4px 16px -6px rgba(14,74,78,.4);
}
.story-vid-tag i{width:13px;height:13px}

/* ─── video modal ─── */
.video-modal{
  position:fixed;inset:0;background:rgba(10,16,18,.92);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;
  z-index:200;padding:24px;opacity:0;transition:opacity .25s var(--ease);
}
.video-modal.open{display:flex;opacity:1}
.vm-wrap{
  position:relative;width:100%;max-width:1000px;
  background:var(--ink);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.6);
}
.vm-label{
  position:absolute;top:16px;left:20px;z-index:2;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:#E6EBE3;background:rgba(0,0,0,.45);padding:6px 12px;border-radius:var(--r-pill);
}
.vm-iframe{position:relative;width:100%;aspect-ratio:16/9}
.vm-iframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.vm-close{
  position:fixed;top:24px;right:24px;z-index:201;
  width:48px;height:48px;border-radius:50%;border:0;cursor:pointer;
  background:var(--bone);color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px -6px rgba(0,0,0,.4);
  transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);
}
.vm-close i{width:20px;height:20px}
.vm-close:hover{background:#fff;transform:rotate(90deg) scale(1.05)}
body.video-open{overflow:hidden}

/* ─── legal pages (privacy + terms) ─── */
.legal{padding:88px 0 96px;background:var(--sand)}
.legal-back{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-500);margin-bottom:36px;
  transition:color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.legal-back i{width:14px;height:14px;transition:transform var(--dur) var(--ease)}
.legal-back:hover{color:var(--teal-700)}
.legal-back:hover i{transform:translateX(-3px)}
.legal h1.display{margin:16px 0 0;font-size:clamp(2.2rem,1.4rem+2vw,3.2rem)}
.legal-meta{
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;
  color:var(--muted);margin:18px 0 0;padding-bottom:24px;border-bottom:1px solid var(--line);
}
.legal-lede{
  font-family:var(--font-display);font-weight:400;font-size:1.18rem;line-height:1.55;
  color:var(--ink);margin:32px 0 0;text-wrap:pretty;
}
.legal-sec{padding:36px 0 4px;border-top:1px solid var(--line);margin-top:36px}
.legal-sec h2{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.3rem,1.05rem+.8vw,1.6rem);line-height:1.25;letter-spacing:-.005em;
  color:var(--ink);margin:0;
}
.legal-sec p{margin:14px 0 0;color:var(--ink-soft);font-size:1.02rem;line-height:1.7}
.legal-sec strong{color:var(--ink);font-weight:600}
.legal-sec em{font-family:var(--font-display);font-style:italic;color:var(--teal-700)}
.legal-sec a{color:var(--teal-700);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(14,74,78,.35)}
.legal-sec a:hover{color:var(--teal-500);text-decoration-color:var(--teal-500)}
.legal-sec code{
  font-family:var(--font-mono);font-size:.85rem;
  background:var(--bone);border:1px solid var(--line);padding:1px 7px;border-radius:4px;color:var(--teal-900);
}
.legal-list{list-style:none;padding:0;margin:18px 0 0}
.legal-list li{
  position:relative;padding:10px 0 10px 26px;
  color:var(--ink-soft);font-size:1rem;line-height:1.65;
  border-bottom:1px solid rgba(229,222,207,.6);
}
.legal-list li:last-child{border-bottom:0}
.legal-list li::before{
  content:"";position:absolute;left:0;top:20px;width:14px;height:1px;background:var(--teal-700);
}
.legal-page .footer{padding:36px 0 36px}
.legal-page .footer .fine{border-top:0;margin-top:0;padding-top:0}

.story-body{display:flex;flex-direction:column;padding:24px 24px 22px;gap:14px;flex:1}
.story-meta{
  font-family:var(--font-mono);font-size:.78rem;color:var(--muted);letter-spacing:.04em;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.story-meta .metric{color:var(--teal-700);font-weight:600;margin-right:2px}
.story-quote{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:1.05rem;line-height:1.45;color:var(--ink);
  letter-spacing:-.005em;margin:0;text-wrap:pretty;
}
.story-stats{list-style:none;padding:14px 0 0;margin:auto 0 0;border-top:1px dashed var(--line)}
.story-stats li{
  display:grid;grid-template-columns:1fr auto;gap:8px 14px;
  padding:10px 0;align-items:baseline;font-size:.88rem;
  border-bottom:1px solid var(--line);
}
.story-stats li:last-child{border-bottom:0}
.ss-lbl{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);grid-column:1 / span 2}
.ss-val{display:inline-flex;align-items:center;gap:6px;font-size:.98rem;color:var(--ink)}
.ss-val i{width:13px;height:13px;color:var(--faint)}
.ss-val .metric{font-size:1.02rem}
.ss-val .metric.in{color:var(--green-600);font-weight:600}
.ss-unit{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);margin-left:2px}
.ss-delta{
  display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:.74rem;
  letter-spacing:.04em;color:var(--green-600);background:var(--green-050);
  padding:3px 9px;border-radius:var(--r-pill);justify-self:end;
}
.ss-delta i{width:12px;height:12px}

.story-foot{display:flex;align-items:center;gap:7px;margin-top:6px;color:var(--muted)}
.story-foot i{width:13px;height:13px}

.stories-note{
  display:flex;align-items:flex-start;gap:8px;
  margin:32px auto 0;max-width:72ch;text-align:left;color:var(--faint);
}
.stories-note i{width:14px;height:14px;color:var(--green-600);margin-top:3px;flex-shrink:0}

/* ──── programs ──── */
.cards4{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px;align-items:stretch;
}
@media (max-width:1100px){.cards4{grid-template-columns:repeat(2,1fr);gap:22px}}
@media (max-width:620px){.cards4{grid-template-columns:1fr}}
.programs{align-items:stretch}

/* ──── tools & programs · institutional grid ──── */
.cards5{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px;align-items:stretch;
}
@media (max-width:1180px){.cards5{grid-template-columns:repeat(2,1fr);gap:22px}}
@media (max-width:560px){.cards5{grid-template-columns:1fr}}

.tool-card{padding:32px 26px;position:relative}
@media (max-width:560px){.tool-card{padding:28px 22px}}
.tool-head{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding-bottom:14px;margin-bottom:18px;
  border-bottom:1px dashed var(--line);
}
.tool-id{
  font-family:var(--font-mono);font-weight:500;font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--teal-700);
  white-space:nowrap;
}
.tool-card.featured .tool-id{color:var(--teal-900)}
.tool-dot{display:inline-flex;align-items:center}
.tool-dot .pulse-dot{width:7px;height:7px}
.tool-dot .pulse-dot.dim{background:var(--teal-200)}
.tool-dot .pulse-dot.dim::before{background:var(--teal-200)}
.tool-card h3{
  font-family:var(--font-display);font-weight:500;font-size:1.18rem;line-height:1.22;
  letter-spacing:-.005em;margin:10px 0 8px;
}
.tool-card .ic{width:42px;height:42px;margin-bottom:14px}
.tool-card .ic i{width:20px;height:20px}
.tool-card .tool-desc{
  font-size:.92rem;line-height:1.55;color:var(--ink-soft);margin:0 0 18px;
  text-wrap:pretty;
}
.tool-meta{margin:0 0 20px;padding:14px 0 4px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.tool-meta > div{display:grid;grid-template-columns:80px 1fr;gap:10px;align-items:baseline}
.tool-meta dt{
  font-family:var(--font-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);margin:0;
}
.tool-meta dd{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.02em;
  color:var(--ink);margin:0;line-height:1.45;
}
.tool-card .program-cta{margin-top:auto;align-self:stretch;justify-content:space-between;width:100%;padding:13px 18px}
.tool-card .ribbon{top:10px;right:10px}
.tool-card.featured{
  grid-column:1 / -1;
  display:grid;grid-template-columns:1.45fr 1fr;gap:56px;align-items:stretch;
  background:linear-gradient(180deg,var(--bone),#F6F1E3);
  border-color:var(--teal-200);box-shadow:var(--e-2);
  padding:48px clamp(28px,4vw,56px);
  margin-top:8px;
}
.section.alt .tool-card.featured{background:linear-gradient(180deg,var(--white),var(--bone))}
.tool-card.featured::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal-700),var(--green-600));
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.tool-card.featured .featured-ic{background:var(--teal-700);color:#FCFAF4;width:54px;height:54px}
.tool-card.featured .featured-ic i{width:24px;height:24px}
.tool-card.featured h3{font-size:1.75rem;line-height:1.16;margin:12px 0 14px}
.tool-card.featured .tool-desc{font-size:1.04rem;line-height:1.6;margin:0 0 22px;max-width:54ch}
.featured-points{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.featured-points li{display:flex;align-items:flex-start;gap:12px;font-size:.96rem;color:var(--ink);line-height:1.5}
.featured-points li i{width:18px;height:18px;color:var(--green-600);margin-top:3px;stroke-width:2;flex-shrink:0}

.featured-side{
  display:flex;flex-direction:column;gap:22px;
  padding-left:48px;border-left:1px solid var(--line-strong);
  justify-content:center;
}
.featured-side .tool-meta{margin:0;border-top:0;padding:0;gap:10px}
.featured-side .tool-meta > div{grid-template-columns:90px 1fr}
.featured-side .program-cta{width:100%;justify-content:center;padding:16px 22px;font-size:1.02rem}
.featured-foot{display:flex;align-items:center;gap:7px;margin:0;color:var(--muted);font-size:.82rem}
.featured-foot i{width:14px;height:14px;color:var(--green-600);flex-shrink:0}

@media (max-width:1180px){
  .tool-card.featured{grid-template-columns:1fr;gap:32px;padding:40px clamp(24px,4vw,40px)}
  .featured-side{padding-left:0;padding-top:32px;border-left:0;border-top:1px solid var(--line-strong)}
  .tool-card.featured h3{font-size:1.5rem}
}

.tool-card:hover{transform:translateY(-3px)}
.tool-card:hover .ic{transform:rotate(-3deg) scale(1.04)}
.tool-card.featured:hover{transform:none}

/* ──── institutional footer ──── */
.footer .cols{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:48px;
}
@media (max-width:980px){.footer .cols{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.footer .cols{grid-template-columns:1fr;gap:32px}}

.foot-brand .foot-positioning{
  color:#9AA399;font-size:.92rem;line-height:1.65;margin:14px 0 0;max-width:38ch;
}
.foot-legal{color:#6F786E;margin-top:14px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em}

.foot-social{display:flex;gap:10px;margin-top:22px}
.foot-social .soc{
  width:40px;height:40px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid #2F3A37;color:#E6EBE3;background:transparent;
  margin:0;padding:0;line-height:1;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.foot-social .soc i,
.foot-social .soc svg{
  width:18px!important;height:18px!important;
  display:block;stroke:currentColor;fill:none;stroke-width:1.75;
}
.foot-social .soc:hover{background:var(--teal-700);border-color:var(--teal-700);color:#FCFAF4;transform:translateY(-2px)}

.foot-col a{display:flex;align-items:center;gap:8px}
.foot-col a i{width:14px;height:14px;color:#7E867E;flex-shrink:0;transition:color var(--dur) var(--ease)}
.foot-col a:hover i{color:#FCFAF4}
.program-card{display:flex;flex-direction:column;position:relative}
.program-card .program-cta{margin-top:auto;align-self:flex-start}
.program-card.featured{
  background:linear-gradient(180deg,var(--bone),#F6F1E3);
  border-color:var(--teal-200);
  box-shadow:var(--e-2);
  position:relative;
}
.section.alt .program-card.featured{background:linear-gradient(180deg,var(--white),var(--bone))}
.program-card.featured::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal-700),var(--green-600));
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.program-card.featured .ic{background:var(--teal-700);color:#FCFAF4}
.program-card:hover .ic{transform:rotate(-4deg) scale(1.04)}
.ribbon{
  position:absolute;top:14px;right:14px;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green-600);background:var(--green-050);padding:5px 12px;border-radius:var(--r-pill);
}

/* ──── specialist · block 1 ──── */
.portrait-hero{
  margin:0 0 48px;
  border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--e-2);
  background:linear-gradient(150deg,#E9E2D2,#DCEAE4 70%);
  position:relative;
}
.portrait-hero img{
  width:100%;height:auto;display:block;
  transition:transform 1.2s var(--ease);
}
.portrait-hero:hover img{transform:scale(1.015)}
.portrait-hero figcaption{
  position:absolute;left:20px;bottom:18px;color:#FCFAF4;
  background:rgba(14,74,78,.78);backdrop-filter:blur(6px);
  padding:7px 14px;border-radius:var(--r-pill);
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
}
.specialist-copy h2{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(1.6rem,1.2rem+1.6vw,2.4rem);line-height:1.2;
  letter-spacing:-.01em;margin:16px 0 0;text-wrap:balance;
}
.specialist-copy p{font-size:1.08rem;line-height:1.75;margin:22px 0 0;color:var(--ink-soft)}
.specialist-copy em{font-family:var(--font-display);font-style:italic;color:var(--teal-700)}
.pull-quote{
  margin:36px 0 36px;padding:28px 32px 28px 36px;
  background:var(--bone);border-left:3px solid var(--teal-700);border-radius:0 var(--r-md) var(--r-md) 0;
  position:relative;box-shadow:var(--e-1);
}
.pull-quote .pq-mark{
  position:absolute;left:18px;top:18px;width:18px;height:18px;color:var(--teal-200);
}
.pull-quote p{
  margin:0 0 0 24px;
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(1.2rem,1rem+.8vw,1.6rem);line-height:1.4;
  color:var(--ink);letter-spacing:-.005em;
}
.specialist-copy .signed{
  font-family:var(--font-display);font-style:italic;color:var(--teal-700);
  margin-top:28px;font-size:1.1rem;
}

/* ──── who is vishak · block 2 ──── */
.who-grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center;
}
@media (max-width:980px){.who-grid{grid-template-columns:1fr;gap:48px}}

.who-images{
  display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:1fr 1fr;gap:14px;
}
.who-images figure{
  margin:0;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--e-1);
  background:linear-gradient(150deg,#E9E2D2,#DCEAE4 70%);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.who-images figure:hover{transform:translateY(-2px);box-shadow:var(--e-2)}
.who-images img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease)}
.who-images figure:hover img{transform:scale(1.04)}
.wi-feature{grid-row:1 / span 2;aspect-ratio:4/5}
.wi-tile{aspect-ratio:5/4}
@media (max-width:680px){
  .who-images{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .wi-feature{grid-row:auto;aspect-ratio:4/3}
}

.who-copy h2{margin:14px 0 0}
.who-lead{
  font-size:1.15rem;line-height:1.7;margin:22px 0 0;color:var(--ink);
  font-family:var(--font-display);font-weight:400;
}
.who-lead .metric{color:var(--teal-700);font-weight:500}

.who-list{list-style:none;padding:0;margin:26px 0 0;border-top:1px solid var(--line)}
.who-list li{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px 0;border-bottom:1px solid var(--line);
  font-size:1.0rem;line-height:1.6;color:var(--ink);
}
.who-list li i{
  width:18px;height:18px;color:var(--teal-700);flex-shrink:0;margin-top:5px;stroke-width:1.75;
  transition:transform var(--dur) var(--ease);
}
.who-list li:hover i{transform:translateX(3px)}
.who-list .metric{color:var(--teal-700);font-weight:600;margin-right:4px}
.who-list em{font-family:var(--font-display);font-style:italic;color:var(--teal-700);font-weight:500}
.who-tag{
  display:inline-block;font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--green-600);background:var(--green-050);
  padding:3px 9px;border-radius:var(--r-pill);margin-right:8px;vertical-align:1px;
}
.who-cta{margin-top:28px}

/* ──── voices / clinician (legacy, kept for any reuse) ──── */
.doc{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center}
@media (max-width:900px){.doc{grid-template-columns:1fr;gap:36px}}
.doc-photo{min-height:420px;border-radius:var(--r-xl)}
.cred-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:18px}
.cred{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;color:var(--muted);background:var(--bone);border:1px solid var(--line);padding:6px 12px;border-radius:var(--r-pill)}
.cred i{width:13px;height:13px;color:var(--teal-700)}
.doc-body h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(1.4rem,1.1rem+1.2vw,2rem);line-height:1.25;letter-spacing:-.005em;color:var(--ink);margin:18px 0 0;text-wrap:balance}
.doc-body p{font-size:1.02rem;margin-top:18px}
.signed{font-family:var(--font-display);color:var(--teal-700);margin-top:24px}

/* ──── letter / spouse ──── */
.letter{text-align:center}
.letter h2{margin:18px 0 0;color:var(--ink)}
.letter p{font-size:1.08rem;line-height:1.75;margin:18px auto 0;max-width:56ch}
.letter-cta{margin-top:30px}

/* ──── FAQ ──── */
.faq{margin-top:28px;background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:last-child{border-bottom:0}
.faq-q{
  width:100%;text-align:left;background:none;border:0;padding:22px 24px;
  font-family:var(--font-sans);font-weight:600;font-size:1.04rem;color:var(--ink);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:background var(--dur) var(--ease);
}
.faq-q:hover{background:rgba(20,104,108,.04)}
.faq-q i{color:var(--teal-500);transition:transform var(--dur) var(--ease);flex-shrink:0;width:18px;height:18px}
.faq-q[aria-expanded="true"] i{transform:rotate(45deg)}
.faq-a{font-size:.98rem;line-height:1.65;color:var(--ink-soft);max-width:68ch;overflow:hidden;max-height:0;padding:0 24px;transition:max-height var(--dur) var(--ease),padding var(--dur) var(--ease)}
.faq-a.open{max-height:320px;padding:0 24px 22px}
.faq-a p{margin:0}

/* ──── CTA band ──── */
.cta-band{
  background:var(--teal-700);color:#FCFAF4;border-radius:var(--r-xl);
  padding:64px 48px;text-align:center;margin:0 auto;box-shadow:var(--e-3);
  position:relative;overflow:hidden;
}
.cta-band::after{
  content:"";position:absolute;inset:-30%;background:radial-gradient(circle at 30% 80%,rgba(47,138,99,.16),transparent 55%);pointer-events:none;
}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{font-family:var(--font-display);font-weight:500;font-size:clamp(1.7rem,1.2rem+1.6vw,2.4rem);margin:14px 0 0;color:#FCFAF4;letter-spacing:-.01em;line-height:1.18}
.cta-band p{color:var(--teal-200);font-size:1.08rem;margin:18px auto 30px;max-width:52ch}
.cta-band-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ──── footer ──── */
.footer{background:var(--ink);color:#C9CFC9;padding:64px 0 40px}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
@media (max-width:860px){.footer .cols{grid-template-columns:1fr 1fr;gap:32px}}
.foot-brand .brand .wm{color:#FCFAF4}
.foot-brand .brand .wm-thin{color:var(--teal-200)}
.foot-brand p{color:#9AA399;font-size:.92rem;margin:14px 0 0;max-width:34ch}
.foot-brand .caption{color:#6F786E;margin-top:14px}
.footer h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:#7E867E;margin:0 0 16px;font-family:var(--font-mono);font-weight:500}
.footer a{display:block;color:#C9CFC9;font-size:.95rem;margin-bottom:10px}
.footer a:hover{color:#fff}
.footer .fine{
  border-top:1px solid #2A332F;margin-top:48px;padding-top:24px;
  font-size:.78rem;color:#7E867E;line-height:1.7;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:flex-start;
}
.fine-links{display:inline-flex;gap:10px;align-items:center;flex-shrink:0}
.fine-links a{color:#C9CFC9;font-weight:500;transition:color var(--dur) var(--ease)}
.fine-links a:hover{color:#FCFAF4}
.fine-sep{color:#3F4845}
.fine-disclaimer{flex:1;min-width:280px;text-align:right}
@media (max-width:760px){.fine-disclaimer{text-align:left}}

/* ──── mobile sticky CTA ──── */
.m-cta{
  position:fixed;left:16px;right:16px;bottom:16px;height:56px;display:none;z-index:60;
  background:var(--bone);border:1px solid var(--line);border-radius:var(--r-pill);
  box-shadow:var(--e-3);
  transform:translateY(120%);transition:transform var(--dur) var(--ease);
  overflow:hidden;
}
.m-cta.show{transform:translateY(0)}
.m-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-weight:600;font-size:.88rem;text-decoration:none}
.m-btn i{width:16px;height:16px}
.m-secondary{color:var(--teal-700)}
.m-primary{background:var(--teal-700);color:#FCFAF4;border-radius:var(--r-pill)}
@media (max-width:860px){.m-cta{display:flex}body{padding-bottom:80px}}

/* ──── reveal ──── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in-view{opacity:1;transform:none}

/* ──── reduced motion ──── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal,.incl li{opacity:1!important;transform:none!important}
  .res-line{stroke-dashoffset:0}
}
