/* ════════════════════════════════════════════════════════════════
   MOIRA · LANDING v6 — supplement for the "founder's vision letter"
   Re-aimed structure: vision → belief → film → why-now → founders →
   what we're building → what changes → commitments → the invitation.
   Builds ON moira-brand.css + moira-landing-v5.css. No new colors.
   ════════════════════════════════════════════════════════════════ */

/* ════════ HERO · vision-led, super-white, centered ════════ */
.hero--vision{min-height:100svh;display:flex;align-items:center;justify-content:center;
  padding:clamp(100px,13vh,150px) 0 clamp(60px,8vh,96px);overflow:hidden}
/* subtle, elite background motion — a slow monochrome hairline sweep + faint drift, masked to fade */
.hv-atmos{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  -webkit-mask-image:radial-gradient(ellipse 74% 66% at 50% 46%,#000 28%,transparent 84%);
  mask-image:radial-gradient(ellipse 74% 66% at 50% 46%,#000 28%,transparent 84%)}
.hv-atmos::before{content:"";position:absolute;inset:-2px;
  background-image:repeating-linear-gradient(90deg,transparent 0 119px,rgba(20,20,23,.03) 119px 120px);
  animation:hvDrift 46s linear infinite}
@keyframes hvDrift{to{background-position:120px 0}}
.hv-sweep{position:absolute;top:0;bottom:0;left:0;width:1px;will-change:transform,opacity;
  background:linear-gradient(180deg,transparent,rgba(20,20,23,.13),transparent);
  animation:hvSweep 24s var(--ease) infinite}
@keyframes hvSweep{0%{transform:translateX(9vw);opacity:0}16%{opacity:.5}84%{opacity:.5}100%{transform:translateX(88vw);opacity:0}}
@media(prefers-reduced-motion:reduce){.hv-atmos{display:none}}
.hero--vision .hv-in{max-width:1120px;margin:0 auto;padding:0 44px;text-align:center;position:relative;z-index:2}
.hero--vision .eyebrow{justify-content:center;color:var(--n5)}

/* the wedge, set as the hero headline */
.hwedge{font-family:var(--sans);font-stretch:var(--wdth);font-variation-settings:'wdth' 115;
  font-weight:640;letter-spacing:-.032em;line-height:1.0;
  font-size:clamp(46px,7.2vw,104px)}
@supports (font-stretch:115%){.hwedge{font-variation-settings:normal}}
.hwedge .line{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em}
.hwedge .line > span{display:block;transform:translateY(116%);transition:transform 1.05s var(--ease)}
.loaded .hwedge .line > span{transform:translateY(0)}
.loaded .hwedge .line:nth-child(2) > span{transition-delay:.12s}
.hwedge .hw-grey{font-size:.40em;font-weight:560;letter-spacing:-.02em;color:var(--n5);
  font-stretch:normal;margin-bottom:.34em;text-wrap:balance}
@supports (font-stretch:115%){.hwedge .hw-grey{font-variation-settings:normal}}
.hwedge .hw-you{font-family:var(--serif);font-style:italic;font-weight:400;font-stretch:normal;
  position:relative;padding:0 .03em}
.hwedge .hw-you::after{content:"";position:absolute;left:.02em;right:.02em;bottom:.04em;height:2px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform 1.1s var(--ease) .7s}
.loaded .hwedge .hw-you::after{transform:scaleX(1)}
/* safety net — force the visible end-state so the headline can never stay hidden
   if a transition fails to fire/complete (and for reduced-motion / print) */
.hero-settled .hwedge .line > span{transform:none;transition:none}
.hero-settled .hwedge .hw-you::after{transform:scaleX(1);transition:none}
@media (prefers-reduced-motion:reduce){
  .hwedge .line > span{transform:none}
  .hwedge .hw-you::after{transform:scaleX(1)}
}
@media print{
  .hwedge .line > span{transform:none}
  .hwedge .hw-you::after{transform:scaleX(1)}
}

.hero--vision .hero-sub{font-size:clamp(17px,1.7vw,20px);line-height:1.6;color:var(--n6);
  max-width:60ch;margin:clamp(26px,3vw,38px) auto clamp(30px,3.4vw,40px)}
.hero--vision .hero-cta{justify-content:center}
/* secondary as a quiet text link, not a co-equal button */
.filmlink{display:inline-flex;align-items:center;gap:9px;font-family:var(--text);font-size:15px;
  color:var(--n6);padding:15px 10px;transition:color .3s var(--ease)}
.filmlink:hover{color:var(--ink)}
.filmlink .pl{width:26px;height:26px;border-radius:50%;border:1px solid var(--n4);display:grid;place-items:center;
  transition:border-color .3s var(--ease),background .3s var(--ease)}
.filmlink:hover .pl{border-color:var(--ink)}
.filmlink .pl svg{width:9px;height:9px;margin-left:1px;fill:currentColor}
.filmlink .rt{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--n5)}

/* honest meta strip */
.hmeta{display:flex;justify-content:center;flex-wrap:wrap;gap:0;margin-top:clamp(44px,5vw,64px);
  border-top:1px solid var(--hair);max-width:680px;margin-left:auto;margin-right:auto;padding-top:20px}
.hmeta .hm{flex:1;min-width:150px;display:flex;flex-direction:column;gap:5px;padding:0 20px;
  border-left:1px solid var(--hair)}
.hmeta .hm:first-child{border-left:0}
.hmeta .hmk{font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--n4)}
.hmeta .hmv{font-family:var(--mono);font-size:12px;letter-spacing:.02em;color:var(--ink)}
@media(max-width:600px){
  .hero--vision{padding:clamp(120px,30vw,150px) 0 64px}
  .hmeta{flex-direction:column;gap:0;max-width:280px}
  .hmeta .hm{border-left:0;border-top:1px solid var(--hair);padding:14px 0;min-width:0}
  .hmeta .hm:first-child{border-top:0}
}

/* ════════ BELIEF · the POV that recruits ════════ */
.belief{padding:var(--sec-pad) 0}
.belief-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,5.5vw,84px);
  align-items:center;margin-top:clamp(34px,4vw,56px)}
.b-copy{min-width:0}
.belief .b-lead{font-family:var(--sans);font-stretch:var(--wdth);font-weight:560;
  font-size:clamp(30px,3.6vw,48px);line-height:1.05;letter-spacing:-.03em;max-width:14ch}
.belief .b-lead .serif-i{font-stretch:normal}
.belief .b-body{font-size:clamp(17px,1.7vw,21px);line-height:1.55;color:var(--n6);
  margin-top:clamp(22px,2.4vw,30px);max-width:30em}
.belief .b-kicker{font-family:var(--sans);font-weight:600;font-size:clamp(19px,2.1vw,27px);
  line-height:1.26;letter-spacing:-.02em;margin-top:clamp(22px,2.4vw,30px);max-width:24em;text-wrap:pretty}

/* the belief portrait — a real person in the brand's clinical frame */
.b-figure{margin:0;min-width:0}
.b-photo{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--n2);
  border:1px solid var(--hair)}
.b-photo image-slot{position:absolute;inset:0;width:100%;height:100%;display:block}
.b-photo image-slot::part(frame){background:var(--n2)}
.b-photo image-slot::part(image){filter:grayscale(1) contrast(1.04)}
.b-photo image-slot::part(ring){border-color:var(--n4)}
.b-photo image-slot::part(placeholder){font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--n5)}
.b-photo .pt{position:absolute;width:13px;height:13px;z-index:3;pointer-events:none;mix-blend-mode:difference}
.b-photo .pt::before{content:"";position:absolute;left:6px;top:0;width:1px;height:13px;background:rgba(255,255,255,.85)}
.b-photo .pt::after{content:"";position:absolute;top:6px;left:0;height:1px;width:13px;background:rgba(255,255,255,.85)}
.b-photo .pt.tl{top:12px;left:12px}.b-photo .pt.tr{top:12px;right:12px}
.b-photo .pt.bl{bottom:12px;left:12px}.b-photo .pt.br{bottom:12px;right:12px}
.b-cap{display:flex;align-items:center;gap:14px;margin-top:16px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--n5)}
.b-cap .bc-line{flex:1;height:1px;background:var(--hair)}
.b-cap .bc-b{color:var(--ink);flex:none}
@media(max-width:820px){.belief-grid{grid-template-columns:1fr;gap:clamp(30px,5vw,44px)}
  .belief .b-lead{max-width:20ch}.b-figure{order:2}.b-copy{order:1}
  .b-photo{aspect-ratio:3/2;max-height:420px}}

/* belief background treatment retired — using the contained framed portrait above */

/* ════════ THE FILM · the one cinematic dark moment ════════ */
.filmsec{padding:var(--sec-pad) 0}
.filmsec .regframe{inset:30px}
.filmsec .fs-in{position:relative;z-index:1}
.filmsec .fs-grid{display:grid;grid-template-columns:.84fr 1.16fr;gap:clamp(38px,5vw,72px);
  align-items:center;position:relative;z-index:1}
.fs-text{min-width:0}
.fs-kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-faint);display:block;margin-bottom:clamp(20px,2.2vw,28px)}
.filmsec .fs-h{font-family:var(--sans);font-stretch:var(--wdth);font-weight:560;
  font-size:clamp(30px,3.4vw,48px);line-height:1.06;letter-spacing:-.03em;color:var(--c-text);text-wrap:pretty;max-width:16ch}
.filmsec .fs-h .serif-i{font-stretch:normal}
.fs-lead{font-size:clamp(15.5px,1.5vw,17.5px);line-height:1.6;color:var(--c-mute);
  margin-top:clamp(20px,2.2vw,28px);max-width:34ch}
.film--feature{aspect-ratio:16/9;margin:0;max-width:none}
@media(max-width:820px){.filmsec .fs-grid{grid-template-columns:1fr;gap:clamp(30px,5vw,42px)}
  .filmsec .fs-h{max-width:20ch}.fs-lead{max-width:46ch}}

/* ════════ WHY NOW · editorial conviction ════════ */
.whynow{padding:var(--sec-pad) 0}
.whynow-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,90px);align-items:center}
.whynow .wn-stmt{font-family:var(--sans);font-stretch:var(--wdth);font-weight:560;
  font-size:clamp(30px,3.7vw,50px);line-height:1.08;letter-spacing:-.03em;max-width:15ch}
.whynow .wn-stmt .serif-i{font-stretch:normal}
.whynow .wn-stmt .dim{color:var(--n5);display:block}
/* reach globe — one coach at the core, athletes lit worldwide ("why now" visual) */
.wn-viz{position:relative;align-self:center;min-width:0}
.reach-globe{display:block;width:100%;max-width:440px;aspect-ratio:1;margin:0 auto}
.wn-cap{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--n5)}
.wn-cap .wc-line{width:34px;height:1px;background:var(--n4);flex:none}
.wn-cap .wc-b{color:var(--ink)}
.whynow .wn-body{padding-top:8px}
.whynow .wn-body p{font-size:clamp(16px,1.55vw,18px);line-height:1.66;color:var(--n6);margin-bottom:18px;max-width:40ch}
.whynow .wn-body p:last-child{margin-bottom:0}
.whynow .wn-body b{color:var(--ink);font-weight:600}
@media(max-width:820px){.whynow-grid{grid-template-columns:1fr;gap:36px}
  .wn-viz{max-width:440px}}

/* ════════ FOUNDERS · the credibility layer (dossier) ════════ */
.founders{padding:var(--sec-pad) 0;background:var(--n1);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.founders .fo-intro{font-family:var(--sans);font-stretch:var(--wdth);font-weight:560;
  font-size:clamp(28px,3.6vw,46px);line-height:1.08;letter-spacing:-.03em;max-width:20ch;
  margin-bottom:clamp(48px,5.6vw,76px)}
.founders .fo-intro b{font-weight:700}
.fo-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3.4vw,48px);
  border-top:1px solid var(--ink);padding-top:clamp(32px,3.6vw,48px)}
.fcard{display:flex;flex-direction:column;gap:16px;min-width:0}
.fc-top{display:flex;align-items:center;gap:16px}
.fc-portrait{width:clamp(76px,8vw,94px);aspect-ratio:1;border-radius:13px;overflow:hidden;
  background:var(--n2);border:1px solid var(--hair);flex:none}
.fc-portrait image-slot{width:100%;height:100%;display:block;color:var(--n5)}
.fc-portrait image-slot::part(frame){background:var(--n2);border-radius:0}
.fc-portrait image-slot::part(image){filter:grayscale(1) contrast(1.04)}
.fc-portrait image-slot::part(ring){border-color:var(--n4)}
.fc-id{min-width:0}
.fc-name{font-family:var(--sans);font-stretch:var(--wdth);font-weight:640;
  font-size:clamp(24px,2.5vw,33px);line-height:1;letter-spacing:-.03em}
@supports (font-stretch:115%){.fc-name{font-variation-settings:normal}}
.fc-role{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--n5);display:block;margin-top:9px}
.fc-creds{font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:var(--ink);line-height:1.65;
  border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:13px 0}
.fc-bio{font-size:14.5px;line-height:1.62;color:var(--n6)}
.fc-bio b{color:var(--ink);font-weight:600}
.fo-close{margin-top:clamp(44px,5vw,64px);padding-top:clamp(28px,3vw,38px);border-top:1px solid var(--ink);
  font-family:var(--sans);font-weight:560;font-stretch:var(--wdth);
  font-size:clamp(20px,2.3vw,30px);line-height:1.28;letter-spacing:-.02em;max-width:30ch;text-wrap:pretty}
@supports (font-stretch:115%){.fo-close{font-variation-settings:normal}}
@media(max-width:720px){
  .fo-grid{grid-template-columns:1fr;gap:30px}
}

/* ════════ BUILD honesty note (inside the dark build section) ════════ */
.build-note{display:flex;align-items:flex-start;gap:13px;max-width:62ch;margin-top:18px;
  font-size:14.5px;line-height:1.58;color:var(--c-mute)}
.build-note .bn-mk{flex:none;margin-top:3px;width:22px;height:22px;border-radius:6px;
  border:1px solid var(--c-hair2);display:grid;place-items:center}
.build-note .bn-mk svg{width:12px;height:12px;stroke:var(--c-text);fill:none;stroke-width:1.6;
  stroke-linecap:round;stroke-linejoin:round}
.build-note b{color:var(--c-text);font-weight:600}

/* ════════ WHAT CHANGES · honest value, no fabricated numbers ════════ */
.changes{padding:var(--sec-pad) 0}
.changes .ch-intro{font-family:var(--sans);font-stretch:var(--wdth);font-weight:600;
  font-size:clamp(28px,3.5vw,46px);line-height:1.05;letter-spacing:-.03em;max-width:17ch;
  margin-bottom:clamp(48px,5.6vw,72px)}
.chg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink)}
.chg{padding:clamp(30px,3.4vw,46px) clamp(26px,3vw,40px) clamp(30px,3.4vw,46px) 0;
  border-left:1px solid var(--n3);padding-left:clamp(26px,3vw,40px);display:flex;flex-direction:column;gap:14px}
.chg:first-child{border-left:0;padding-left:0}
.chg .chg-tok{font-family:var(--sans);font-stretch:var(--wdth);font-weight:680;
  font-size:clamp(30px,3.4vw,46px);line-height:.96;letter-spacing:-.03em}
@supports (font-stretch:115%){.chg .chg-tok{font-variation-settings:normal}}
.chg .chg-lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--n5)}
.chg .chg-d{font-size:15.5px;line-height:1.58;color:var(--n6);max-width:30ch}
@media(max-width:820px){
  .chg-grid{grid-template-columns:1fr;border-top:0}
  .chg{border-left:0;border-top:1px solid var(--n3);padding:26px 0}
  .chg:first-child{border-top:1px solid var(--ink)}
}

/* ════════ COMMITMENTS · trust reframed as promises to the cohort ════════ */
.commit-lead .eb{font-family:var(--text);font-size:15px;color:var(--n6);margin-bottom:20px;display:block}
.commit-lead h2{font-family:var(--sans);font-stretch:var(--wdth);font-weight:560;
  font-size:clamp(32px,4vw,50px);line-height:1.05;letter-spacing:-.03em;max-width:16em}
.commit-lead h2 .serif-i{font-stretch:normal}

/* ════════ THE INVITATION · real founding offer (light) ════════ */
.invite .inv-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(48px,6vw,84px);align-items:center}
.invite .inv-left .ab{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--n5);display:block;margin-bottom:24px}
.invite .inv-left h2{font-family:var(--sans);font-stretch:var(--wdth);font-weight:640;
  font-size:clamp(34px,4.4vw,58px);line-height:1.0;letter-spacing:-.034em}
.invite .inv-left .inv-sub{font-size:17.5px;color:var(--n6);margin-top:22px;max-width:30em;line-height:1.55}
.inv-terms{list-style:none;margin:clamp(30px,3.4vw,42px) 0 0;padding:0;border-top:1px solid var(--ink)}
.inv-terms li{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;
  padding:16px 2px;border-bottom:1px solid var(--hair)}
.inv-terms .it-k{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--n5);
  padding-top:4px;white-space:nowrap}
.inv-terms .it-v{font-family:var(--sans);font-weight:560;font-size:clamp(16px,1.6vw,19px);
  letter-spacing:-.012em;line-height:1.3}
.inv-terms .it-v small{display:block;font-family:var(--text);font-weight:400;font-size:14px;color:var(--n6);
  letter-spacing:0;margin-top:5px;line-height:1.5}
.form-card .seats{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding-bottom:18px;margin-bottom:20px;border-bottom:1px solid var(--hair)}
.form-card .seats .sl{font-family:var(--sans);font-weight:600;font-size:16px;letter-spacing:-.01em}
.form-card .seats .sn{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--n6);display:inline-flex;align-items:center;gap:8px}
.form-card .fnote{font-size:13.5px;color:var(--n6);line-height:1.55;margin:2px 0 18px}
.field textarea{font-family:var(--text);font-size:15px;color:var(--ink);background:var(--n1);
  border:1px solid var(--n3);border-radius:8px;padding:13px 14px;outline:none;resize:vertical;min-height:84px;
  transition:border-color .3s,background .3s}
.field textarea::placeholder{color:var(--n4)}
.field textarea:focus{border-color:var(--ink);background:var(--n0)}
@media(max-width:820px){.invite .inv-grid{grid-template-columns:1fr;gap:40px}}
@media(max-width:600px){.field textarea{font-size:16px}}
