/* ============================================================
   THE SIXTH WAVE — landing page
   Locked identity. Every value here is from the brand spec.
   ============================================================ */

:root{
  --deep-night:#06121E;
  --ocean-ink:#0B1B2B;
  --paper:#F4F1EA;
  --violet-wash:#F2EEFF;
  --rose-wash:#FDF2F8;
  --deep-violet:#4C1D95;
  --cosmic-rose:#EC4899;
  --gold:#B8862A;
  --muted:#5A6472;
  --divider:#D8D2C4;
  --grad:linear-gradient(115deg,#3B0764 0%,#7E22CE 50%,#EC4899 100%);
  --display:'Michroma',sans-serif;
  --sans:'Geist','Geist Fallback',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --pad-x:24px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--sans);
  background:var(--deep-night);
  color:#fff;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit}
::selection{background:rgba(236,72,153,.30);color:#fff}

/* ---------- Layout ---------- */
.section{
  position:relative;
  padding-block:72px;
  padding-inline:var(--pad-x);
}
/* Hairline gradient rule at the top of each section */
.section::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(236,72,153,.25) 50%,transparent);
  pointer-events:none;
  z-index:1;
}
.col{margin-inline:auto;width:100%}
.col-hero{max-width:800px}
.col-720{max-width:720px}
.col-body{max-width:680px}
.col-600{max-width:600px}
.col-560{max-width:560px}
.col-520{max-width:520px}

@media (min-width:768px){.section{padding-block:120px}}

/* ---------- Alternating backgrounds ---------- */
.s-ocean{background:var(--ocean-ink)}

/* ---------- Type primitives ---------- */
.wordmark{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(30px,8.5vw,48px);
  letter-spacing:.12em;
  line-height:1.08;
  color:#fff;
  text-wrap:balance;
}
.tagline{
  font-weight:300;font-size:18px;letter-spacing:.02em;
  line-height:1.5;color:rgba(255,255,255,.80);
}
.eyebrow{
  font-weight:500;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--cosmic-rose);margin-bottom:12px;
}
.h-section{
  font-weight:600;font-size:28px;letter-spacing:.01em;
  line-height:1.15;color:#fff;margin-bottom:24px;
}
.prose p{
  font-weight:400;font-size:16px;letter-spacing:0;
  line-height:1.75;color:rgba(255,255,255,.85);margin-bottom:20px;
}
.prose p:last-child{margin-bottom:0}
.prose .em{font-weight:600;color:#fff}
.prose--center{text-align:center}
.head{text-align:center}
.subhead{
  font-weight:300;font-size:16px;line-height:1.6;
  color:rgba(255,255,255,.70);
}

/* Large statement beats — the visual heartbeat of the page */
.statement{
  font-weight:600;
  font-size:26px;
  line-height:1.3;
  letter-spacing:.01em;
  color:#fff;
  text-align:center;
  max-width:520px;
  margin:48px auto 32px;
}

@media (min-width:768px){
  .wordmark{font-size:clamp(44px,5.6vw,72px);white-space:nowrap}
  .tagline{font-size:24px}
  .h-section{font-size:40px}
  .prose p{font-size:18px}
  .statement{font-size:36px}
  .subhead{font-size:18px}
}

/* ---------- Light section overrides ---------- */
.section--light{background:var(--paper);color:var(--ocean-ink)}
.section--light::before{
  background:linear-gradient(90deg,transparent,rgba(76,29,149,.20) 50%,transparent);
}
.section--light .eyebrow{color:var(--deep-violet)}
.section--light .h-section{color:var(--ocean-ink)}
.section--light .prose p{color:rgba(11,27,43,.85)}
.section--light .prose .em{color:var(--ocean-ink)}
.section--light .statement{color:var(--ocean-ink)}

/* ---------- CTA ---------- */
.btn{
  display:inline-block;font-family:var(--sans);font-weight:500;
  font-size:15px;letter-spacing:.04em;line-height:1;color:#fff;
  background:var(--grad);padding:16px 36px;border:0;border-radius:100px;
  cursor:pointer;text-decoration:none;
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
  box-shadow:0 8px 30px -12px rgba(236,72,153,.55);
}
.btn:hover{
  transform:translateY(-2px);filter:brightness(1.06);
  box-shadow:0 16px 44px -14px rgba(236,72,153,.7);
}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid var(--cosmic-rose);outline-offset:4px}
@media (min-width:768px){.btn{font-size:16px}}

.note{
  font-weight:300;font-size:13px;letter-spacing:.02em;
  line-height:1.6;color:var(--muted);margin-top:16px;
}

/* ============================================================
   S1 — HERO
   ============================================================ */
.hero{
  min-height:100svh;display:grid;place-items:center;
  text-align:center;background:var(--deep-night);
  overflow:hidden;padding-block:96px;position:relative;
}
.hero::before{
  content:"";position:absolute;
  width:120vmax;height:120vmax;top:50%;left:50%;
  transform:translate(-50%,-58%);
  background:radial-gradient(closest-side,rgba(126,34,206,.16),rgba(236,72,153,.06) 45%,transparent 70%);
  pointer-events:none;z-index:0;
}
.hero__inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
}
.mark-hero{width:120px;height:120px;margin-bottom:32px}
.hero .wordmark{margin-bottom:0}
.hero .tagline{margin-top:24px;max-width:30ch}
.hero .btn{margin-top:40px}

@media (min-width:768px){
  .mark-hero{width:180px;height:180px;margin-bottom:40px}
  .hero .tagline{margin-top:32px}
  .hero .btn{margin-top:56px}
}

/* Mark load animation — builds, curls, locks; plays once */
.mark-build{animation:markBuild 1100ms cubic-bezier(.16,1,.3,1) both}
@keyframes markBuild{
  0%{opacity:0;transform:scale(.90)}
  55%{opacity:1}
  100%{opacity:1;transform:scale(1)}
}
.rise{animation:rise 800ms cubic-bezier(.16,1,.3,1) both}
.rise-1{animation-delay:440ms}
.rise-2{animation-delay:640ms}
.rise-3{animation-delay:860ms}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ============================================================
   S2 — THE MOVEMENT
   ============================================================ */
.prose .standalone{margin-block:28px}

/* Wave metaphor — the emotional peak of the page */
.wave-moment{
  border-top:1px solid rgba(236,72,153,.30);
  border-bottom:1px solid rgba(236,72,153,.30);
  padding-block:48px;
  margin-top:64px;
  max-width:640px;
  margin-inline:auto;
  text-align:center;
}
.wave-moment p{
  font-weight:400;font-size:16px;letter-spacing:0;
  line-height:1.9;color:rgba(255,255,255,.85);
  margin-bottom:20px;text-align:center;
}
.wave-moment p:last-child{margin-bottom:0}
.wave-moment p.wave-moment__close{
  font-weight:600;font-size:22px;color:#fff;
  margin-top:40px;line-height:1.4;
}
@media (min-width:768px){
  .wave-moment p{font-size:18px}
  .wave-moment p.wave-moment__close{font-size:28px}
  .wave-moment{max-width:680px}
}

/* ============================================================
   S4 — THE DIFFERENCE
   ============================================================ */
.s-difference{position:relative;overflow:hidden;text-align:center}
.ghost{
  position:absolute;top:50%;left:50%;
  width:400px;height:400px;
  transform:translate(-50%,-50%);
  opacity:.06;filter:brightness(0) invert(1);
  pointer-events:none;z-index:0;
}
.s-difference .col{position:relative;z-index:1}
@media (min-width:768px){.ghost{width:600px;height:600px}}

/* ============================================================
   S5 — FOUNDING COHORT (LIGHT)
   ============================================================ */
.s-cohort .btn{margin-top:8px}

/* ============================================================
   S6 — THE SIGNAL
   ============================================================ */
.s-signal{text-align:center}
.signal-intro{
  font-weight:500;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--cosmic-rose);margin-bottom:56px;
}
.stats{
  display:grid;grid-template-columns:1fr;gap:48px;
  max-width:900px;margin-inline:auto;
}
/* Gradient text on stat headers */
.stat__big{
  font-family:var(--display);font-weight:400;font-size:18px;
  letter-spacing:.08em;line-height:1.3;margin-bottom:14px;
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.stat__sub{
  font-weight:400;font-size:15px;line-height:1.6;
  color:rgba(255,255,255,.62);
}
@media (min-width:768px){
  .stats{grid-template-columns:repeat(3,1fr);gap:40px}
  .stat__big{font-size:20px}
  .stat__sub{font-size:16px}
  .stat{padding-inline:8px}
}
.stat + .stat{position:relative}
@media (min-width:768px){
  .stat + .stat::before{
    content:"";position:absolute;left:-20px;top:6px;bottom:6px;
    width:1px;background:rgba(255,255,255,.10);
  }
}

/* ============================================================
   S7 — APPLICATION FORM
   ============================================================ */
/* Elevated destination panel */
.form-panel{
  position:relative;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.09);
  border-radius:20px;
  padding:32px 24px 40px;
  margin-top:40px;
}
.form-panel::before{
  content:"";position:absolute;inset:0;border-radius:20px;
  background:radial-gradient(
    ellipse 80% 40% at 50% 0%,
    rgba(124,58,237,.10),
    rgba(236,72,153,.06) 60%,
    transparent 100%
  );
  pointer-events:none;z-index:0;
}
.form-panel > *{position:relative;z-index:1}
@media (min-width:768px){.form-panel{padding:48px 48px 56px}}

.form{display:flex;flex-direction:column;gap:22px}
.field{display:flex;flex-direction:column;gap:9px}
.field--hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.label{
  font-weight:500;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--deep-violet);
}
.label .opt{
  color:var(--muted);letter-spacing:.04em;
  text-transform:none;font-weight:400;
}
.input,.textarea,.select{
  font-family:var(--sans);font-weight:400;font-size:15px;
  letter-spacing:0;color:#fff;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;padding:14px 16px;width:100%;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
  -webkit-appearance:none;appearance:none;
}
/* Country dropdown styling */
.select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,.4)' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
  padding-right:44px;cursor:pointer;
  color:rgba(255,255,255,.32);
}
.select.has-value{color:#fff}
.select option{background:#0B1B2B;color:#fff}
.textarea{resize:vertical;min-height:140px;line-height:1.6}
.input::placeholder,.textarea::placeholder{color:rgba(255,255,255,.32)}
.input:focus,.textarea:focus,.select:focus{
  outline:none;border-color:var(--cosmic-rose);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 3px rgba(236,72,153,.18);
}
.input.invalid,.textarea.invalid,.select.invalid{
  border-color:#f87171;box-shadow:0 0 0 3px rgba(248,113,113,.16);
}
.field__err{font-size:12px;color:#fca5a5;letter-spacing:.01em;min-height:0}
.s-form .btn{width:100%;margin-top:6px}
.form-status{
  font-size:14px;line-height:1.6;border-radius:12px;
  padding:14px 16px;display:none;margin-bottom:24px;
}
.form-status.ok{
  display:block;background:rgba(126,34,206,.16);
  border:1px solid rgba(236,72,153,.4);color:#fff;
}
.form-status.err{
  display:block;background:rgba(248,113,113,.10);
  border:1px solid rgba(248,113,113,.4);color:#fecaca;
}

/* ============================================================
   S8 — FOOTER
   ============================================================ */
.footer{
  padding-block:64px;border-top:1px solid rgba(255,255,255,.07);
  text-align:center;
}
.footer__lockup{
  display:flex;align-items:center;justify-content:center;
  gap:12px;margin-bottom:28px;
}
.footer__mark{width:32px;height:32px}
.footer__word{
  font-family:var(--display);font-weight:400;
  font-size:14px;letter-spacing:.12em;color:#fff;
}
.footer__site{
  font-weight:300;font-size:13px;letter-spacing:.02em;
  color:var(--muted);margin-bottom:20px;
}
.footer__site a{color:rgba(255,255,255,.72);text-decoration:none}
.footer__site a:hover{color:#fff}
.socials{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:8px 22px;margin-bottom:28px;
}
.socials a{
  font-weight:300;font-size:13px;letter-spacing:.02em;
  color:var(--muted);text-decoration:none;transition:color .2s ease;
}
.socials a:hover{color:var(--cosmic-rose)}
.footer__legal{
  font-weight:300;font-size:13px;letter-spacing:.02em;
  color:var(--muted);margin-bottom:18px;
}
.footer__depth{
  font-weight:300;font-style:italic;font-size:12px;
  letter-spacing:.04em;color:rgba(255,255,255,.35);
}
@media (min-width:768px){
  .footer{text-align:left}
  .footer__lockup{justify-content:flex-start}
  .footer__site,.socials{justify-content:flex-start}
}

/* ---------- Scroll reveal (no-JS safe: visible by default) ---------- */
.reveal.pending{opacity:0;transform:translateY(18px)}
.reveal.pending.in{
  opacity:1;transform:none;
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);
}
@media (prefers-reduced-motion:reduce){
  .mark-build,.rise{animation:none !important}
  .reveal.pending{opacity:1 !important;transform:none !important}
}

/* ---------- Utilities ---------- */
.mt-40{margin-top:40px}
.mb-12{margin-bottom:12px}

/* ============================================================
   MULTI-PAGE SYSTEM — added for v2
   ============================================================ */

/* ---------- Site navigation bar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
  padding:14px clamp(16px,4vw,40px) 14px clamp(16px,4vw,40px);
  padding-right:clamp(20px,4vw,48px);
  background:rgba(6,18,30,.72);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s ease, border-color .3s ease;
}
.nav__brand{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}
.nav__mark{width:30px;height:30px}
.nav__word{
  font-family:var(--display);font-weight:400;font-size:14px;
  letter-spacing:.14em;color:#fff;white-space:nowrap;
}
@media (max-width:480px){.nav__word{font-size:12px;letter-spacing:.1em}}
.nav__links{display:none;align-items:center;gap:34px;flex-shrink:0}
.nav__links a{
  font-weight:400;font-size:14px;letter-spacing:.02em;
  color:rgba(255,255,255,.74);text-decoration:none;
  position:relative;padding:4px 0;transition:color .2s ease;
}
.nav__links a:hover{color:#fff}
.nav__links a.active{color:#fff}
.nav__links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--grad);border-radius:2px;
}
.nav__cta{
  font-weight:500;font-size:14px;letter-spacing:.03em;color:#fff;
  text-decoration:none;background:var(--grad);
  padding:9px 22px;border-radius:100px;
  box-shadow:0 8px 24px -12px rgba(236,72,153,.6);
  transition:transform .2s ease, filter .2s ease;
}
.nav__cta:hover{transform:translateY(-1px);filter:brightness(1.07)}

/* mobile menu */
.nav__toggle{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;background:none;border:0;cursor:pointer;padding:9px;
}
.nav__toggle span{
  display:block;height:2px;width:100%;background:#fff;border-radius:2px;
  transition:transform .3s ease, opacity .2s ease;
}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__drawer{
  position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
  background:var(--ocean-ink);z-index:99;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);
  display:flex;flex-direction:column;gap:6px;
  padding:96px 28px 40px;
  box-shadow:-30px 0 60px -30px rgba(0,0,0,.6);
}
.nav.open + .nav__drawer,.nav__drawer.open{transform:translateX(0)}
.nav__drawer a{
  font-size:18px;font-weight:400;color:rgba(255,255,255,.82);
  text-decoration:none;padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.nav__drawer a.active{color:var(--cosmic-rose)}
.nav__scrim{
  position:fixed;inset:0;background:rgba(6,18,30,.6);
  backdrop-filter:blur(2px);z-index:98;opacity:0;visibility:hidden;
  transition:opacity .3s ease,visibility .3s ease;
}
.nav__scrim.open{opacity:1;visibility:visible}

@media (min-width:880px){
  .nav__links{display:flex}
  .nav__toggle{display:none}
}

/* page content sits below fixed nav */
.has-nav{padding-top:62px}

/* ---------- Hero slideshow ---------- */
.hero-slides{
  position:relative;min-height:100svh;
  display:grid;place-items:center;text-align:center;
  background:var(--deep-night);overflow:hidden;
  padding:120px var(--pad-x) 96px;
}
.hero-slides::before{
  content:"";position:absolute;width:120vmax;height:120vmax;
  top:50%;left:50%;transform:translate(-50%,-54%);
  background:radial-gradient(closest-side,rgba(126,34,206,.18),rgba(236,72,153,.06) 45%,transparent 70%);
  pointer-events:none;z-index:0;
}
.hero-slides__inner{position:relative;z-index:1;width:100%;max-width:860px}
.hero-slides .mark-hero{width:104px;height:104px;margin:0 auto 40px}
@media (min-width:768px){.hero-slides .mark-hero{width:132px;height:132px;margin-bottom:48px}}

.slides{position:relative}
.slide{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:flex-start;
  opacity:0;visibility:hidden;transform:translateY(14px);
  transition:opacity .7s ease, transform .7s ease, visibility .7s;
  pointer-events:none;
}
.slide.current{opacity:1;visibility:visible;transform:none;pointer-events:auto;position:relative}
.slide__eyebrow{
  font-weight:500;font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--cosmic-rose);margin-bottom:20px;
}
.slide__line{
  font-family:var(--display);font-weight:400;
  font-size:clamp(24px,6.4vw,46px);line-height:1.28;letter-spacing:.01em;
  color:#fff;text-wrap:balance;max-width:18ch;margin:0 auto;
}
.slide__sub{
  font-weight:300;font-size:clamp(15px,2.6vw,19px);line-height:1.6;
  color:rgba(255,255,255,.74);margin-top:20px;max-width:46ch;
}
@media (prefers-reduced-motion:reduce){
  .slide{transition:opacity .01s}
}

.hero-cta-row{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:center;
  margin-top:48px;position:relative;z-index:2;
}
.btn--ghost{
  background:transparent;border:1px solid rgba(255,255,255,.22);
  box-shadow:none;
}
.btn--ghost:hover{
  background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.4);
  filter:none;
}

/* slideshow controls */
.slides-nav{
  display:flex;align-items:center;justify-content:center;gap:18px;
  margin-top:40px;position:relative;z-index:2;
}
.slides-arrow{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.03);
  color:#fff;cursor:pointer;display:grid;place-items:center;
  transition:border-color .2s ease, background .2s ease;
  font-size:16px;line-height:1;
}
.slides-arrow:hover{border-color:var(--cosmic-rose);background:rgba(236,72,153,.12)}
.slides-dots{display:flex;gap:9px}
.dot{
  width:8px;height:8px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:rgba(255,255,255,.24);transition:background .25s ease, width .25s ease;
}
.dot.active{background:var(--cosmic-rose);width:22px;border-radius:5px}

.scroll-hint{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  z-index:2;color:rgba(255,255,255,.4);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;
}
.scroll-hint::after{
  content:"";width:1px;height:26px;
  background:linear-gradient(rgba(255,255,255,.4),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}
@media (prefers-reduced-motion:reduce){.scroll-hint::after{animation:none}}

/* ---------- Teaser cards (home) ---------- */
.teaser{position:relative}
.teaser__grid{
  display:grid;grid-template-columns:1fr;gap:20px;
  max-width:1000px;margin:0 auto;
}
@media (min-width:760px){
  .teaser__grid--2{grid-template-columns:1fr 1fr}
}
.card{
  position:relative;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);border-radius:18px;
  padding:34px 28px;overflow:hidden;
  transition:border-color .3s ease, transform .3s ease, background .3s ease;
}
.card:hover{border-color:rgba(236,72,153,.35);transform:translateY(-3px);background:rgba(255,255,255,.045)}
.card__num{
  font-family:var(--display);font-size:13px;letter-spacing:.2em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;margin-bottom:18px;display:block;
}
.card__title{
  font-weight:600;font-size:22px;line-height:1.25;color:#fff;margin-bottom:14px;
}
.card__text{
  font-weight:400;font-size:15.5px;line-height:1.7;
  color:rgba(255,255,255,.74);margin-bottom:22px;
}
.card__link{
  font-weight:500;font-size:14px;letter-spacing:.04em;
  color:var(--cosmic-rose);text-decoration:none;display:inline-flex;
  align-items:center;gap:7px;transition:gap .2s ease;
}
.card__link:hover{gap:12px}
.card__link span{transition:transform .2s ease}

/* ---------- Page header (interior pages) ---------- */
.page-head{
  position:relative;text-align:center;
  padding:80px var(--pad-x) 56px;overflow:hidden;
}
.page-head::before{
  content:"";position:absolute;width:80vmax;height:80vmax;
  top:-40%;left:50%;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(126,34,206,.14),transparent 70%);
  pointer-events:none;
}
.page-head__inner{position:relative;z-index:1;max-width:720px;margin:0 auto}
.page-head .eyebrow{margin-bottom:16px}
.page-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(28px,6vw,52px);line-height:1.12;letter-spacing:.01em;
  color:#fff;text-wrap:balance;
}
.page-head__sub{
  font-weight:300;font-size:clamp(16px,2.4vw,20px);line-height:1.6;
  color:rgba(255,255,255,.74);margin-top:22px;max-width:54ch;
  margin-inline:auto;
}
@media (min-width:768px){.page-head{padding:120px var(--pad-x) 72px}}

/* ---------- Pull quote ---------- */
.pullquote{
  border-left:2px solid;border-image:var(--grad) 1;
  padding:6px 0 6px 26px;margin:44px auto;max-width:620px;
  font-weight:400;font-size:clamp(19px,3vw,24px);line-height:1.5;
  color:#fff;font-style:italic;
}
.section--light .pullquote{color:var(--ocean-ink)}

/* ---------- Benefits list ---------- */
.benefits{
  list-style:none;max-width:600px;margin:0 auto;
  display:flex;flex-direction:column;gap:18px;
}
.benefit{
  display:flex;gap:16px;align-items:flex-start;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);
  border-radius:14px;padding:20px 22px;
}
.benefit__icon{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:var(--grad);display:grid;place-items:center;
  font-size:14px;color:#fff;margin-top:1px;
}
.benefit__body h4{
  font-weight:600;font-size:16.5px;color:#fff;margin-bottom:5px;letter-spacing:.01em;
}
.benefit__body p{
  font-weight:400;font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.7);
}
.benefit--gold{border-color:rgba(184,134,42,.4);background:rgba(184,134,42,.07)}
.benefit--gold .benefit__icon{background:linear-gradient(135deg,#B8862A,#E6B964)}

/* ---------- Footer nav columns ---------- */
.footer__nav{
  display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:center;
  margin-bottom:26px;
}
.footer__nav a{
  font-weight:400;font-size:14px;color:rgba(255,255,255,.72);
  text-decoration:none;transition:color .2s ease;
}
.footer__nav a:hover{color:var(--cosmic-rose)}
@media (min-width:768px){.footer__nav{justify-content:flex-start}}

/* ---------- Read-more inline ---------- */
.section-cta{text-align:center;margin-top:48px}


/* ---------- More spacing utilities (CSP-safe) ---------- */
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}
.pt-16{padding-top:16px}
.pt-24{padding-top:24px}
.benefits-tight{margin:40px auto 8px}
.note-center{text-align:center;margin-bottom:8px}
