/* =========================================================
   GNOSIS — Cinematic Homepage v2
   Ink + gold + iris + chrome/glass on void black
   Fraunces (display) + Inter Tight (body) + JetBrains Mono (meta)
   ========================================================= */

:root{
  /* INK navy ramp */
  --ink-900:#050616; --ink-800:#0B1130; --ink-700:#14274A;
  --ink-600:#1F3563; --ink-500:#2B477F; --ink-400:#3D5C99;
  --ink-300:#90AFD8; --ink-200:#C8D5E8; --ink-100:#E6E8F4;
  /* IRIS */
  --iris-700:#2E236C; --iris-600:#3A2D80; --iris-500:#4330B8;
  --iris-400:#6F66B4; --iris-300:#BCACD6;
  /* LUMEN */
  --lumen-700:#2B7FB8; --lumen-500:#5BB5E8; --lumen-400:#8ACDF0;
  /* GOLD */
  --gold-700:#9C7820; --gold-500:#C9A24A; --gold-400:#D9B566;
  --gold-300:#E2C685; --gold-200:#F0DAA8; --gold-100:#F6ECCF;
  /* FOREST (AI Lab) */
  --forest-500:#408A71; --forest-300:#B0E4CC;

  /* Surfaces */
  --black:#000000;
  --void:#040513;
  --night:#070918;
  --surface-1:#0B0E1F;
  --surface-2:#11142A;
  --surface-3:#181C37;
  --glass-1:rgba(255,255,255,0.04);
  --glass-2:rgba(255,255,255,0.07);
  --glass-edge:rgba(255,255,255,0.10);
  --chrome:rgba(228,232,240,0.85);
  --chrome-soft:rgba(228,232,240,0.55);

  /* Text */
  --paper:#E8E5D6;
  --paper-soft:#D8D5C6;
  --mute:rgba(232,229,214,.68);
  --mute-2:rgba(232,229,214,.42);
  --mute-3:rgba(232,229,214,.22);

  /* Type */
  --display:"Fraunces","Instrument Serif",Georgia,serif;
  --body:"Inter Tight","Inter",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono","SF Mono",ui-monospace,monospace;

  /* Accent (changeable via tweaks) */
  --accent:#E2C685;       /* gold */
  --accent-soft:rgba(226,198,133,.18);
  --accent-strong:#C9A24A;

  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:22px;
  --radius-xl:34px;
  --radius-pill:999px;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;font-family:var(--body)}
html{scroll-behavior:auto;background:var(--black);color-scheme:dark}
body{
  background:var(--black);color:var(--paper);
  font:400 15.5px/1.55 var(--body);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  letter-spacing:-.005em;
  cursor:none; /* magnetic cursor takes over */
}
body.no-cursor{cursor:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:none;border:none;background:none;color:inherit}
body.no-cursor button{cursor:pointer}
img,video{max-width:100%;display:block}
::selection{background:var(--accent);color:#000}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ===== UTILS ===== */
.serif{font-family:var(--display);font-weight:400}
.serif-i{font-family:var(--display);font-style:italic;font-weight:300}
.mono{font-family:var(--mono);font-feature-settings:"ss01","cv11"}
.acc{color:var(--accent)}
.muted{color:var(--mute)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font:600 10.5px/1 var(--mono);
  letter-spacing:.22em;text-transform:uppercase;color:var(--chrome);}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent);opacity:.7}
.eyebrow.no-mark::before{display:none}
.eyebrow .acc{color:var(--accent)}

.container{max-width:1400px;margin:0 auto;padding-inline:clamp(20px,3.5vw,48px)}
.grain{position:fixed;inset:0;pointer-events:none;opacity:.06;z-index:1;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/></svg>");}

/* ===== THREE.JS AMBIENT ===== */
#ambient{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.45;transition:opacity .6s}
body.ambient-off #ambient{opacity:0}

/* ===== MAGNETIC CURSOR ===== */
.cursor{position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;background:var(--accent);
  pointer-events:none;z-index:9999;mix-blend-mode:difference;transform:translate(-50%,-50%);
  transition:width .25s cubic-bezier(.16,1,.3,1),height .25s cubic-bezier(.16,1,.3,1),background .25s,opacity .25s;
  will-change:transform}
.cursor-ring{position:fixed;top:0;left:0;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.35);
  pointer-events:none;z-index:9998;transform:translate(-50%,-50%);
  transition:width .35s cubic-bezier(.16,1,.3,1),height .35s cubic-bezier(.16,1,.3,1),border-color .25s,opacity .25s,background .25s;
  backdrop-filter:invert(1) grayscale(1);
  will-change:transform}
.cursor.lg{width:70px;height:70px;background:transparent;border:1px solid var(--accent);mix-blend-mode:normal}
.cursor-ring.hide{opacity:0}
.cursor-label{position:fixed;top:0;left:0;padding:6px 12px;border-radius:999px;background:var(--accent);
  color:#000;font:600 10.5px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;
  z-index:9997;transform:translate(20px,20px);pointer-events:none;opacity:0;transition:opacity .2s;white-space:nowrap}
.cursor-label.on{opacity:1}
body.no-cursor .cursor,body.no-cursor .cursor-ring,body.no-cursor .cursor-label{display:none}
@media(hover:none){.cursor,.cursor-ring,.cursor-label{display:none!important}}

/* =========================================================
   DIAGNOSTIC INTRO (covers viewport, dismissable)
   ========================================================= */
.intro{position:fixed;inset:0;z-index:200;background:var(--black);display:grid;place-items:center;
  padding:clamp(20px,4vw,60px);overflow:hidden;transform-origin:center center}
.intro-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.85;filter:saturate(1) contrast(1.02);pointer-events:none}
.intro::before{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 1200px 700px at 50% 40%,rgba(67,48,184,.18),transparent 65%),
             radial-gradient(ellipse 900px 500px at 30% 80%,rgba(226,198,133,.08),transparent 65%),
             linear-gradient(180deg,rgba(5,6,22,.25),rgba(5,6,22,.55) 55%,rgba(5,6,22,.78))}
.intro::after{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000,transparent 75%)}
.intro-inner{position:relative;z-index:2;width:100%;max-width:1120px;display:grid;grid-template-rows:auto 1fr auto;gap:clamp(24px,4vw,56px)}
.intro-top{display:flex;justify-content:space-between;align-items:center;gap:24px}
.intro-brand{display:flex;align-items:center;gap:12px;font:600 13px/1 var(--body);color:var(--chrome)}
.intro-brand img{height:26px;border-radius:5px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
.intro-meta{display:flex;gap:14px;align-items:center;font:500 10.5px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--mute-2)}
.intro-meta b{color:var(--accent);font-weight:700}
.intro-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 2.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.intro-q{display:grid;align-content:center;justify-items:center;text-align:center;gap:clamp(24px,3vw,40px);max-width:980px;margin-inline:auto}
.intro-q .step{font:500 10.5px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--mute-2)}
.intro-q .step b{color:var(--accent)}
.intro-q h1{font:300 clamp(40px,7vw,88px)/.98 var(--display);
  letter-spacing:-.028em;color:var(--paper);font-variation-settings:"opsz" 96,"SOFT" 50}
.intro-q h1 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.intro-q .answers{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:8px}
.intro-q .ans{position:relative;text-align:left;background:var(--glass-1);border:1px solid var(--glass-edge);
  border-radius:18px;padding:18px 20px;font:500 16px/1.35 var(--body);color:var(--paper-soft);
  transition:.35s cubic-bezier(.2,.7,.2,1);overflow:hidden}
.intro-q .ans::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 0% 0%,var(--accent-soft),transparent 60%);opacity:0;transition:.4s}
.intro-q .ans:hover{border-color:var(--accent);transform:translateY(-3px);background:rgba(255,255,255,.06)}
.intro-q .ans:hover::before{opacity:1}
.intro-q .ans .k{display:block;font:600 10px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.intro-q .ans .arr{position:absolute;top:18px;right:18px;width:28px;height:28px;border-radius:50%;border:1px solid var(--glass-edge);
  display:grid;place-items:center;transition:.3s;color:var(--chrome)}
.intro-q .ans:hover .arr{background:var(--accent);border-color:var(--accent);color:#000;transform:rotate(-45deg)}
.intro-q .ans .arr svg{width:13px;height:13px}

.intro-bottom{display:flex;justify-content:center;align-items:center;gap:24px}
.intro-skip{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--glass-edge);border-radius:999px;background:transparent;color:var(--chrome);font:500 11px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;transition:.3s}
.intro-skip:hover{border-color:var(--accent);color:var(--accent)}
.intro-enter{display:inline-flex;align-items:center;gap:12px;padding:16px 30px 16px 32px;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#000;font:600 12.5px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;transition:gap .35s cubic-bezier(.16,1,.3,1),background .25s,color .25s}
.intro-enter:hover{gap:18px;background:var(--paper);border-color:var(--paper)}
.intro-enter svg{width:15px;height:15px}

body.intro-done .intro{pointer-events:none}

@media(max-width:680px){
  .intro-q .answers{grid-template-columns:1fr}
  .intro-meta{display:none}
}

/* =========================================================
   TOP NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px clamp(20px,3.5vw,40px);
  display:flex;align-items:center;gap:clamp(16px,2.5vw,32px);
  transition:transform .55s cubic-bezier(.2,.7,.2,1),background .35s, backdrop-filter .35s;
  transform:translateY(-110%)}
body.intro-done .nav{transform:translateY(0)}
.nav.scrolled{background:rgba(5,6,22,.65);backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--glass-edge);padding-block:14px}
.nav-brand{display:flex;align-items:center;gap:10px;font:600 13.5px/1 var(--body);color:var(--paper);letter-spacing:-.005em}
.nav-brand img{height:28px;width:28px;border-radius:6px;background:#fff;padding:2px;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 14px -4px rgba(0,0,0,.5);object-fit:contain}
.nav-links{display:flex;align-items:center;gap:clamp(14px,2vw,28px);margin-left:auto}
.nav-links a{position:relative;font:500 13px/1 var(--body);color:var(--mute);padding:6px 0;transition:color .25s}
.nav-links a:hover{color:var(--paper)}
.nav-links a.on{color:var(--paper)}
.nav-links a.on::after{content:"";position:absolute;left:50%;bottom:-2px;width:5px;height:5px;border-radius:50%;background:var(--accent);transform:translateX(-50%);box-shadow:0 0 12px var(--accent)}
.nav-cta{padding:9px 18px 9px 16px;border-radius:999px;background:var(--accent);color:#000;font:600 12.5px/1 var(--body);
  display:inline-flex;align-items:center;gap:8px;transition:.3s;border:1px solid var(--accent);letter-spacing:-.005em}
.nav-cta:hover{background:var(--paper);border-color:var(--paper);color:#000;gap:12px}
.nav-cta svg{width:14px;height:14px}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:#000}

@media(max-width:780px){
  .nav-links{display:none}
}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;padding:clamp(12px,1.5vw,22px);min-height:100vh}
.hero-frame{position:relative;width:100%;min-height:calc(100vh - 28px);border-radius:clamp(16px,2vw,26px);
  overflow:hidden;isolation:isolate;background:#000}
.hero-media{position:absolute;inset:0;z-index:1}
.hero-media img,.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-media video{opacity:1;transition:opacity .8s}
.hero-frame::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,0) 25%,rgba(0,0,0,.1) 55%,rgba(0,0,0,.85) 100%),
             radial-gradient(ellipse 80% 60% at 50% 40%,transparent 30%,rgba(0,0,0,.4) 85%)}
.hero-frame .scanline{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.10;
  background-image:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(255,255,255,.06) 2px,rgba(255,255,255,.06) 3px)}

.hero-tag{position:absolute;top:clamp(82px,8vw,100px);left:clamp(24px,3vw,40px);z-index:5;
  display:flex;flex-direction:column;gap:6px;color:var(--chrome-soft);font:500 10.5px/1.5 var(--mono);letter-spacing:.22em;text-transform:uppercase}
.hero-tag b{color:var(--paper);font-weight:700}
.hero-tag-r{position:absolute;top:clamp(82px,8vw,100px);right:clamp(24px,3vw,40px);z-index:5;
  display:flex;flex-direction:column;gap:6px;text-align:right;color:var(--chrome-soft);font:500 10.5px/1.5 var(--mono);letter-spacing:.22em;text-transform:uppercase}
.hero-tag-r b{color:var(--paper);font-weight:700}
.hero-tag-r .live{display:inline-flex;align-items:center;gap:6px;color:var(--accent)}
.hero-tag-r .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 1.4s infinite}

.hero-content{position:absolute;left:0;right:0;bottom:0;z-index:6;
  padding:clamp(24px,3.5vw,48px) clamp(24px,3vw,44px) clamp(20px,2.8vw,36px);
  display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(20px,4vw,60px);align-items:end}
.hero-title{font:300 clamp(80px,18vw,260px)/.84 var(--display);
  letter-spacing:-.07em;color:var(--paper);position:relative;
  font-variation-settings:"opsz" 144,"SOFT" 30}
.hero-title .l{display:block;overflow:hidden}
.hero-title .l > span{display:inline-block;transform:translateY(110%);will-change:transform}
.hero-title .em{font-style:italic;color:var(--accent);
  font-variation-settings:"opsz" 144,"SOFT" 100}
.hero-title .ast{position:absolute;top:.1em;right:-.04em;font:400 .22em/1 var(--display);font-style:italic;color:var(--accent);opacity:0}

.hero-right{padding-bottom:18px}
.hero-right p{font:400 clamp(14px,1.1vw,16.5px)/1.55 var(--body);color:var(--paper-soft);max-width:34ch;margin-bottom:24px;opacity:0}
.hero-right p .em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300}

.hero-cta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;opacity:0}

.cta-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 8px 8px 22px;border-radius:999px;
  background:var(--paper);color:#000;font:600 13.5px/1 var(--body);letter-spacing:-.005em;
  transition:gap .35s cubic-bezier(.16,1,.3,1),background .25s,color .25s;will-change:transform}
.cta-pill:hover{gap:16px;background:var(--accent)}
.cta-pill .circ{width:38px;height:38px;border-radius:50%;background:#000;color:var(--paper);display:grid;place-items:center;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.cta-pill:hover .circ{transform:scale(1.08) rotate(-12deg)}
.cta-pill svg{width:14px;height:14px}

.cta-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border:1px solid var(--glass-edge);border-radius:999px;
  font:500 12.5px/1 var(--body);color:var(--paper);transition:.3s;backdrop-filter:blur(10px);background:rgba(255,255,255,.04)}
.cta-ghost:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,255,255,.06)}
.cta-ghost svg{width:13px;height:13px}

.hero-stage{position:absolute;bottom:clamp(22px,3vw,36px);right:clamp(24px,3vw,40px);z-index:6;
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;font:500 10.5px/1.4 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--mute-2);pointer-events:none;opacity:0}
.hero-stage b{font:400 18px/1 var(--display);font-style:italic;color:var(--accent);letter-spacing:-.01em;text-transform:none}

.hero-scroll{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:6;color:var(--chrome-soft);font:500 10px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0}
.hero-scroll .line{width:1px;height:32px;background:linear-gradient(180deg,var(--chrome) 0%,transparent);animation:scrollline 2.2s infinite}
@keyframes scrollline{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(0);transform-origin:bottom}}

@media(max-width:780px){
  .hero-content{grid-template-columns:1fr;gap:18px;padding:90px 22px 24px}
  .hero-title{font-size:clamp(68px,22vw,180px)}
  .hero-tag,.hero-tag-r,.hero-stage,.hero-scroll{display:none}
}

/* =========================================================
   MARQUEE TICKER
   ========================================================= */
.marquee{padding:clamp(14px,1.5vw,22px) 0;background:var(--accent);color:#000;overflow:hidden;border-block:1px solid var(--accent-strong);position:relative;z-index:3}
.marquee-row{display:flex;gap:60px;white-space:nowrap;font:500 clamp(20px,2.4vw,32px)/1 var(--display);will-change:transform}
.marquee-row span{display:inline-flex;align-items:center;gap:60px;flex-shrink:0}
.marquee-row .dot{width:8px;height:8px;border-radius:50%;background:#000;flex:none}
.marquee-row .it{font-style:italic;font-weight:400}

/* =========================================================
   MANIFESTO (scroll-pinned)
   ========================================================= */
.manifesto{position:relative;background:var(--void);overflow:hidden;min-height:100vh}
.manifesto-grid{position:absolute;inset:0;z-index:1;background-image:
  linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:96px 96px;mask-image:radial-gradient(ellipse 70% 80% at 50% 50%,#000 30%,transparent);pointer-events:none}
.manifesto-bgvideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.78;will-change:transform}
.manifesto-bgscrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 40% at 20% 50%,rgba(5,6,22,.75),transparent 70%),
    linear-gradient(90deg,rgba(5,6,22,.55) 0%,rgba(5,6,22,.35) 45%,rgba(5,6,22,.15) 100%),
    linear-gradient(180deg,rgba(5,6,22,.45) 0%,rgba(5,6,22,.1) 25%,rgba(5,6,22,.1) 75%,rgba(5,6,22,.55) 100%)}
.manifesto-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,100px);
  padding:clamp(80px,10vw,160px) clamp(20px,3.5vw,48px);max-width:1500px;margin:0 auto;align-items:center;min-height:100vh}
.manifesto-portrait{position:sticky;top:15vh;height:70vh;border-radius:var(--radius-lg);overflow:hidden;background:#000}
.manifesto-portrait img,.manifesto-portrait video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:transform}
.manifesto-portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.65) 100%);pointer-events:none;z-index:2}
.manifesto-portrait .badge{position:absolute;left:18px;bottom:18px;z-index:3;padding:9px 14px;border-radius:999px;
  background:rgba(0,0,0,.6);backdrop-filter:blur(10px);font:600 10px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--chrome);border:1px solid var(--glass-edge)}
.manifesto-portrait .pcorner{position:absolute;top:18px;right:18px;z-index:3;font:500 10px/1.4 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--chrome-soft);text-align:right}
.manifesto-portrait .pcorner b{color:var(--accent);font-weight:700}

.manifesto-text{position:relative;display:flex;flex-direction:column;gap:36px;padding-block:8vh;max-width:42em;text-shadow:0 1px 18px rgba(0,0,0,.4)}
.manifesto-text .step{font:500 10.5px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.manifesto-text h2{font:300 clamp(36px,5vw,68px)/1 var(--display);letter-spacing:-.022em;color:var(--paper);max-width:18ch;
  font-variation-settings:"opsz" 96,"SOFT" 30}
.manifesto-text h2 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.manifesto-text h2 .w{display:inline-block;overflow:hidden;vertical-align:bottom;padding-right:.2em;line-height:1.05}
.manifesto-text h2 .w span{display:inline-block;will-change:transform}
.manifesto-text p{font:400 clamp(15px,1.15vw,17.5px)/1.6 var(--body);color:var(--paper-soft);max-width:36em}
.manifesto-text p .em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300}
.manifesto-text p strong{color:var(--paper);font-weight:600}
.manifesto-quote{padding:22px 26px;border-left:2px solid var(--accent);font:300 italic clamp(20px,2.2vw,26px)/1.35 var(--display);color:var(--paper);max-width:32em;background:linear-gradient(90deg,var(--accent-soft),transparent)}
.manifesto-quote .em{color:var(--accent)}

@media(max-width:980px){
  .manifesto-inner{grid-template-columns:1fr;gap:40px;padding:64px 22px}
  .manifesto-portrait{position:relative;top:auto;height:60vh}
}

/* =========================================================
   STATS COUNTER
   ========================================================= */
.stats{background:var(--black);padding:clamp(60px,8vw,120px) 0;position:relative;border-top:1px solid var(--glass-edge);border-bottom:1px solid var(--glass-edge)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{position:relative;padding:clamp(28px,3.5vw,48px) clamp(24px,3vw,36px);text-align:left}
.stat + .stat{border-left:1px solid var(--glass-edge)}
.stat .num{font:300 clamp(56px,7vw,110px)/.9 var(--display);color:var(--paper);
  font-variation-settings:"opsz" 144,"SOFT" 30;letter-spacing:-.04em;margin-bottom:14px;display:flex;align-items:baseline;gap:4px}
.stat .num .suf{color:var(--accent);font-style:italic;font-size:.6em;font-variation-settings:"opsz" 144,"SOFT" 100}
.stat .lbl{font:500 11px/1.3 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:8px}
.stat .desc{font:400 13px/1.45 var(--body);color:var(--mute-2);max-width:18em}

@media(max-width:980px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat + .stat{border-left:none}
  .stat:nth-child(odd){border-right:1px solid var(--glass-edge)}
  .stat:nth-child(n+3){border-top:1px solid var(--glass-edge)}
}

/* =========================================================
   PROGRAMS — horizontal scroll
   ========================================================= */
.programs{background:var(--black);padding:clamp(80px,10vw,160px) 0 clamp(40px,5vw,80px);position:relative;overflow:hidden}
.programs-head{padding-inline:clamp(20px,3.5vw,48px);max-width:1500px;margin:0 auto clamp(40px,5vw,72px);
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.programs-head .lhs{max-width:36em}
.programs-head h2{font:300 clamp(38px,5vw,72px)/.98 var(--display);letter-spacing:-.024em;color:var(--paper);margin-top:18px;font-variation-settings:"opsz" 96,"SOFT" 30}
.programs-head h2 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.programs-head .rhs{font:400 14.5px/1.55 var(--body);color:var(--mute);max-width:24em}
.programs-head .rhs .em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300}

.programs-rail{position:relative;padding-inline:clamp(20px,3.5vw,48px);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none}
.programs-rail::-webkit-scrollbar{display:none}
.programs-track{display:flex;gap:16px;padding-bottom:32px}

.program-card{flex:0 0 clamp(280px,28vw,400px);height:clamp(440px,55vh,560px);
  border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-1);
  border:1px solid var(--glass-edge);position:relative;display:flex;flex-direction:column;
  scroll-snap-align:start;transition:transform .5s cubic-bezier(.2,.7,.2,1),border-color .35s}
.program-card:hover{transform:translateY(-6px);border-color:var(--accent)}
.program-card .ph{position:relative;height:46%;overflow:hidden;background:var(--surface-2)}
.program-card .ph img,.program-card .ph video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.program-card:hover .ph img,.program-card:hover .ph video{transform:scale(1.06)}
.program-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4))}
.program-card .num-tag{position:absolute;top:14px;left:14px;z-index:2;padding:5px 11px;border-radius:999px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(10px);border:1px solid var(--glass-edge);
  font:500 10px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--chrome)}
.program-card .num-tag b{color:var(--accent);font-weight:700}
.program-card .price{position:absolute;top:14px;right:14px;z-index:2;padding:5px 11px;border-radius:999px;
  background:var(--accent);color:#000;font:600 10px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase}

.program-card .body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1}
.program-card .body h3{font:600 clamp(18px,1.5vw,22px)/1.15 var(--body);color:var(--paper);letter-spacing:-.015em}
.program-card .body h3 .em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300;display:block;font-size:.78em;margin-top:4px}
.program-card .body p{font:400 13.5px/1.5 var(--body);color:var(--mute);flex:1}
.program-card .body .learn{display:inline-flex;align-items:center;gap:8px;font:600 12px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--paper);padding-top:14px;border-top:1px solid var(--glass-edge);margin-top:auto}
.program-card .body .learn svg{width:14px;height:14px;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.program-card:hover .body .learn svg{transform:translateX(6px)}

.programs-foot{padding-inline:clamp(20px,3.5vw,48px);max-width:1500px;margin:24px auto 0;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.programs-foot .hint{font:500 11px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--mute-2);display:flex;align-items:center;gap:8px}
.programs-foot .hint svg{width:14px;height:14px}
.rail-nav{display:flex;gap:8px}
.rail-nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--glass-edge);background:var(--glass-1);color:var(--paper);display:grid;place-items:center;transition:.3s;cursor:none}
.rail-nav button:hover{border-color:var(--accent);color:var(--accent);background:rgba(226,198,133,.08)}
.rail-nav button svg{width:16px;height:16px}

/* =========================================================
   VIDEO-ON-SCROLL
   ========================================================= */
/* =========================================================
   INSIDE THE LAB — two tracks
   ========================================================= */
.lab{position:relative;background:var(--black);padding:clamp(40px,6vw,100px) 0 clamp(80px,10vw,140px);overflow:hidden}
.lab::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:min(1500px,100% - clamp(40px,7vw,96px));height:1px;background:linear-gradient(90deg,transparent,var(--glass-edge) 20%,var(--glass-edge) 80%,transparent)}
.lab-stage{position:relative;max-width:1500px;margin:0 auto;padding-inline:clamp(20px,3.5vw,48px)}

.lab-tracks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(20px,2.5vw,40px)}
@media (max-width:1080px){.lab-tracks{grid-template-columns:1fr}}

.lab-track{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.012));border:1px solid var(--glass-edge);border-radius:24px;padding:clamp(28px,3vw,44px) clamp(24px,2.6vw,40px) clamp(28px,3vw,40px);display:flex;flex-direction:column;gap:clamp(28px,3vw,40px);overflow:hidden;transition:border-color .4s ease}
.lab-track::after{content:"";position:absolute;inset:0;border-radius:24px;pointer-events:none;background:radial-gradient(120% 60% at 50% 0%,rgba(226,198,133,.06),transparent 55%);opacity:.5;transition:opacity .5s}
.lab-track:hover{border-color:rgba(226,198,133,.32)}
.lab-track:hover::after{opacity:1}
.lab-track[data-track="B"]::after{background:radial-gradient(120% 60% at 50% 0%,rgba(144,175,216,.07),transparent 55%)}

.lab-track-head{display:flex;flex-direction:column;gap:18px;position:relative;z-index:1}
.lab-mark{display:flex;align-items:center;gap:16px}
.lab-letter{width:48px;height:48px;border-radius:14px;border:1px solid var(--glass-edge);display:grid;place-items:center;font:300 24px/1 var(--display);font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100;background:rgba(226,198,133,.06)}
.lab-track[data-track="B"] .lab-letter{color:#90AFD8;background:rgba(144,175,216,.06)}
.lab-meta{display:flex;flex-direction:column;gap:4px}
.lab-meta b{font:600 13px/1.2 var(--body);color:var(--paper);letter-spacing:-.005em}
.lab-meta em{font:400 11px/1.3 var(--mono);font-style:normal;letter-spacing:.16em;text-transform:uppercase;color:var(--mute-2)}

.lab-track h3{font:300 clamp(28px,2.4vw,40px)/1.05 var(--display);letter-spacing:-.022em;color:var(--paper);font-variation-settings:"opsz" 96,"SOFT" 30;max-width:18ch}
.lab-track h3 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.lab-track[data-track="B"] h3 .em{color:#90AFD8}

.lab-lead{font:400 14.5px/1.6 var(--body);color:var(--mute);max-width:42ch}

.lab-attrs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 22px;padding-top:18px;border-top:1px solid var(--glass-edge);margin-top:4px}
.lab-attr{display:flex;flex-direction:column;gap:4px}
.lab-attr .k{font:500 10px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--mute-2)}
.lab-attr .v{font:500 12.5px/1.4 var(--body);color:var(--paper-soft);letter-spacing:-.005em}

.lab-modules{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px;background:var(--glass-edge);border:1px solid var(--glass-edge);border-radius:16px;overflow:hidden;position:relative;z-index:1}
.lab-module{display:grid;grid-template-columns:120px 1fr;gap:clamp(16px,1.8vw,28px);background:rgba(11,17,48,.55);padding:22px 22px}
@media (max-width:640px){.lab-module{grid-template-columns:1fr;gap:10px}}
.mod-rail{display:flex;flex-direction:column;gap:4px;padding-top:2px}
.mod-num{font:600 11px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.lab-track[data-track="B"] .mod-num{color:#90AFD8}
.mod-weeks{font:500 10.5px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--mute-2)}
.mod-body h4{font:600 14.5px/1.25 var(--body);color:var(--paper);letter-spacing:-.005em;margin-bottom:12px}
.mod-body h4 em{font-family:var(--display);font-style:italic;font-weight:300;color:var(--mute);font-size:.95em;letter-spacing:0}
.mod-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.mod-list li{position:relative;padding-left:22px;font:400 13.5px/1.5 var(--body);color:var(--paper-soft)}
.mod-list li::before{content:"";position:absolute;left:0;top:.55em;width:10px;height:1px;background:var(--accent);opacity:.7}
.lab-track[data-track="B"] .mod-list li::before{background:#90AFD8;opacity:.7}

.lab-cta{align-self:flex-start;display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:999px;background:var(--accent);color:#000;font:600 12.5px/1 var(--body);letter-spacing:-.005em;border:1px solid var(--accent);transition:gap .35s cubic-bezier(.16,1,.3,1),background .25s,color .25s;position:relative;z-index:1}
.lab-cta:hover{gap:16px;background:var(--paper);border-color:var(--paper)}
.lab-cta svg{width:14px;height:14px}
.lab-track[data-track="B"] .lab-cta{background:transparent;color:var(--paper);border-color:var(--glass-edge)}
.lab-track[data-track="B"] .lab-cta:hover{border-color:#90AFD8;color:#90AFD8;background:rgba(144,175,216,.06)}

/* Compact preview card variant for the homepage */
.lab-preview{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.012));border:1px solid var(--glass-edge);border-radius:24px;padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;gap:18px;overflow:hidden;color:inherit;transition:border-color .4s ease,transform .5s cubic-bezier(.2,.7,.2,1)}
.lab-preview::after{content:"";position:absolute;inset:0;border-radius:24px;pointer-events:none;background:radial-gradient(120% 60% at 50% 0%,rgba(226,198,133,.06),transparent 55%);opacity:.5;transition:opacity .5s}
.lab-preview[data-track="B"]::after{background:radial-gradient(120% 60% at 50% 0%,rgba(144,175,216,.07),transparent 55%)}
.lab-preview:hover{border-color:rgba(226,198,133,.32);transform:translateY(-3px)}
.lab-preview[data-track="B"]:hover{border-color:rgba(144,175,216,.32)}
.lab-preview:hover::after{opacity:1}

.lab-preview-head{display:flex;align-items:center;gap:16px;position:relative;z-index:1}
.lab-preview h3{font:300 clamp(26px,2.2vw,36px)/1.05 var(--display);letter-spacing:-.022em;color:var(--paper);font-variation-settings:"opsz" 96,"SOFT" 30;max-width:18ch;position:relative;z-index:1}
.lab-preview h3 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.lab-preview[data-track="B"] h3 .em{color:#90AFD8}
.lab-preview .lab-lead{font:400 14.5px/1.6 var(--body);color:var(--mute);max-width:42ch;position:relative;z-index:1}
.lab-preview .lab-lead em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300}
.lab-preview[data-track="B"] .lab-lead em{color:#90AFD8}

.lab-chips{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.lab-chip{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:var(--glass-1);border:1px solid var(--glass-edge);font:500 10.5px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--paper-soft)}

.lab-cta-link{margin-top:6px;display:inline-flex;align-items:center;gap:8px;padding-top:18px;border-top:1px solid var(--glass-edge);font:600 12px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--paper);position:relative;z-index:1}
.lab-cta-link svg{width:14px;height:14px;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.lab-preview:hover .lab-cta-link svg{transform:translateX(6px)}
.lab-preview[data-track="A"] .lab-cta-link{color:var(--accent)}
.lab-preview[data-track="B"] .lab-cta-link{color:#90AFD8}

.reel{position:relative;background:var(--black);padding:clamp(60px,8vw,120px) 0;overflow:hidden}
.reel-stage{position:relative;max-width:1500px;margin:0 auto;padding-inline:clamp(20px,3.5vw,48px)}
.reel-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-1);box-shadow:0 30px 80px -30px rgba(0,0,0,.8)}
.reel-frame video,.reel-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reel-frame::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.7));z-index:2;pointer-events:none}
.reel-corner{position:absolute;top:18px;left:18px;z-index:3;display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:rgba(0,0,0,.5);backdrop-filter:blur(12px);border:1px solid var(--glass-edge);font:500 10px/1 var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--chrome)}
.reel-corner .live::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#ff3b3b;margin-right:6px;box-shadow:0 0 8px #ff3b3b;animation:pulse 1.4s infinite;vertical-align:middle}
.reel-cap{position:absolute;left:24px;right:24px;bottom:24px;z-index:3;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;color:var(--paper)}
.reel-cap h3{font:300 clamp(22px,2.4vw,34px)/1.1 var(--display);font-variation-settings:"opsz" 96,"SOFT" 30;letter-spacing:-.015em;max-width:24ch}
.reel-cap h3 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.reel-cap .time{font:500 11px/1.4 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--mute);text-align:right}
.reel-cap .time b{display:block;color:var(--accent);font-weight:700;font-size:1.4em;letter-spacing:-.01em;text-transform:none;font-family:var(--display);font-style:italic;font-weight:300;margin-bottom:2px}

.reel-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.reel-meta .m{padding:18px 20px;border:1px solid var(--glass-edge);border-radius:var(--radius-md);background:var(--glass-1)}
.reel-meta .m .lbl{font:500 10px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.reel-meta .m .v{font:500 14.5px/1.4 var(--body);color:var(--paper)}
@media(max-width:780px){.reel-meta{grid-template-columns:1fr}}

/* =========================================================
   ESSAYS — horizontal scroll
   ========================================================= */
.essays{background:var(--void);padding:clamp(80px,10vw,140px) 0;position:relative;overflow:hidden}
.essays-head{padding-inline:clamp(20px,3.5vw,48px);max-width:1500px;margin:0 auto clamp(36px,4vw,56px);display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.essays-head .lhs h2{font:300 clamp(34px,4.5vw,60px)/1 var(--display);color:var(--paper);font-variation-settings:"opsz" 96,"SOFT" 30;letter-spacing:-.022em;margin-top:14px;max-width:16ch}
.essays-head .lhs h2 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.essays-head .rhs{display:flex;flex-direction:column;align-items:flex-end;gap:14px;max-width:28em;text-align:right}
.essays-head .rhs p{font:400 14px/1.55 var(--body);color:var(--mute)}
.essays-head .rhs p .em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:300}

.essays-rail{padding-inline:clamp(20px,3.5vw,48px);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;scrollbar-width:none}
.essays-rail::-webkit-scrollbar{display:none}
.essays-track{display:flex;gap:14px;padding-bottom:24px}

/* Marquee mode — slow continuous scroll, pauses on hover, fades at edges */
.essays-rail.is-marquee{overflow:hidden;scroll-snap-type:none;padding-inline:0;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.essays-track.is-marquee-track{display:flex;width:max-content;animation:essaysMarquee 55s linear infinite;will-change:transform}
.essays-rail.is-marquee:hover .essays-track.is-marquee-track{animation-play-state:paused}
@keyframes essaysMarquee{
  0%{transform:translate3d(0,0,0)}
  100%{transform:translate3d(-50%,0,0)}
}

/* Essay card — keep section accent gold (no overrides needed; was a class-name collision) */

.essay{flex:0 0 clamp(320px,32vw,440px);height:clamp(420px,52vh,520px);
  border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-1);position:relative;scroll-snap-align:start;
  transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.essay:hover{transform:translateY(-8px)}
.essay-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s ease;z-index:1}
.essay:hover .essay-img{transform:scale(1.05)}
.essay::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.92) 100%);z-index:2}
.essay-body{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;z-index:3;color:var(--paper)}
.essay .tag{font:600 10.5px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.essay h4{font:300 italic clamp(22px,2.2vw,30px)/1.15 var(--display);color:var(--paper);margin-bottom:12px;letter-spacing:-.01em;
  font-variation-settings:"opsz" 96,"SOFT" 100}
.essay p{font:400 13px/1.5 var(--body);color:var(--mute);max-width:28em}
.essay .arr{position:absolute;top:24px;right:24px;width:38px;height:38px;border-radius:50%;border:1px solid var(--glass-edge);background:rgba(0,0,0,.4);backdrop-filter:blur(10px);display:grid;place-items:center;color:var(--paper);transition:.3s;z-index:3}
.essay:hover .arr{background:var(--accent);border-color:var(--accent);color:#000;transform:rotate(-45deg)}
.essay .arr svg{width:14px;height:14px}

/* =========================================================
   TESTIMONIALS — grid
   ========================================================= */
.testimonials{background:var(--black);padding:clamp(80px,10vw,140px) 0;position:relative}
.testimonials-head{padding-inline:clamp(20px,3.5vw,48px);max-width:1500px;margin:0 auto clamp(36px,4vw,56px);display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.testimonials-head h2{font:300 clamp(34px,4.5vw,60px)/1 var(--display);color:var(--paper);font-variation-settings:"opsz" 96,"SOFT" 30;letter-spacing:-.022em;margin-top:14px;max-width:14ch}
.testimonials-head h2 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 96,"SOFT" 100}
.testimonials-head .meta{display:flex;gap:24px;font:500 11px/1.4 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--mute-2)}
.testimonials-head .meta b{color:var(--accent);font-weight:700;display:block;font:400 28px/1 var(--display);font-style:italic;letter-spacing:-.01em;text-transform:none;margin-bottom:4px}

.testimonials-grid{padding-inline:clamp(20px,3.5vw,48px);max-width:1500px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tcard{padding:28px 26px;border-radius:var(--radius-lg);background:var(--surface-1);border:1px solid var(--glass-edge);display:flex;flex-direction:column;gap:18px;transition:.35s}
.tcard:hover{transform:translateY(-3px);border-color:var(--accent-soft)}
.tcard .qm{font:300 italic 56px/.5 var(--display);color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100}
.tcard p{font:300 italic clamp(15px,1.15vw,17px)/1.4 var(--display);color:var(--paper);flex:1;letter-spacing:-.005em;
  font-variation-settings:"opsz" 96,"SOFT" 60}
.tcard .who{font:600 12.5px/1 var(--body);color:var(--paper);letter-spacing:-.005em}
.tcard .who span{display:block;font:400 11.5px/1.35 var(--body);color:var(--mute-2);margin-top:4px;letter-spacing:0}
.tcard .who .country{display:inline-flex;align-items:center;gap:6px;font:500 10px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.tcard .who .country::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent)}

@media(max-width:980px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.testimonials-grid{grid-template-columns:1fr}}

/* =========================================================
   CLOSER (closing CTA)
   ========================================================= */
.closer{position:relative;padding:clamp(80px,10vw,160px) clamp(20px,3.5vw,48px);background:var(--void);overflow:hidden;text-align:center}
.closer::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 1200px 700px at 50% 40%,rgba(67,48,184,.22),transparent 60%),
                                                       radial-gradient(ellipse 800px 500px at 50% 90%,rgba(226,198,133,.13),transparent 60%);pointer-events:none}
.closer-inner{position:relative;z-index:2;max-width:880px;margin:0 auto}
.closer h2{font:300 clamp(40px,6vw,82px)/.95 var(--display);color:var(--paper);font-variation-settings:"opsz" 144,"SOFT" 30;letter-spacing:-.026em;margin:22px auto 28px;max-width:20ch}
.closer h2 .em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100}
.closer p{font:400 16px/1.6 var(--body);color:var(--mute);max-width:36em;margin:0 auto 36px}
.closer .row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.closer-orbit{position:absolute;border-radius:50%;border:1px solid var(--glass-edge);pointer-events:none}
.closer-o1{width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%)}
.closer-o2{width:900px;height:900px;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.5}
.closer-o3{width:1200px;height:1200px;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.25}
.closer-photo{position:absolute;border-radius:50%;overflow:hidden;border:1px solid var(--glass-edge);box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.closer-photo img{width:100%;height:100%;object-fit:cover}
.cp-1{width:110px;height:110px;top:14%;left:8%}
.cp-2{width:140px;height:140px;bottom:12%;right:10%}
.cp-3{width:80px;height:80px;top:18%;right:14%;opacity:.85}
.cp-4{width:90px;height:90px;bottom:18%;left:14%;opacity:.85}
@media(max-width:880px){.closer-photo{display:none}.closer-orbit{display:none}}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{background:var(--black);padding:clamp(48px,6vw,80px) clamp(20px,3.5vw,48px) 36px;border-top:1px solid var(--glass-edge);position:relative}
.foot-inner{max-width:1500px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--glass-edge)}
.foot .brand{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.foot .brand img{height:30px;border-radius:6px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}
.foot .brand b{font:600 18px/1 var(--body);color:var(--paper);letter-spacing:-.01em}
.foot .lede{font:400 14px/1.55 var(--body);color:var(--mute);max-width:24em;margin-bottom:18px}
.foot .badges{display:flex;gap:8px;flex-wrap:wrap}
.foot .badges span{font:500 10px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;padding:6px 10px;border:1px solid var(--glass-edge);border-radius:999px;color:var(--mute);background:var(--glass-1)}
.foot h4{font:600 11px/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.foot a.link{display:block;font:400 13.5px/1 var(--body);color:var(--mute);padding:6px 0;transition:.25s}
.foot a.link:hover{color:var(--paper);transform:translateX(4px)}
.foot-bottom{max-width:1500px;margin:32px auto 0;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;color:var(--mute-2);font:500 11.5px/1 var(--mono);letter-spacing:.06em}
.foot-bottom b{color:var(--paper);font-weight:700}
.foot-bottom .handle{color:var(--accent)}

.bigname{padding:0 0 24px;overflow:hidden;background:var(--black);position:relative}
.bigname-row{font:200 clamp(80px,18vw,260px)/.9 var(--display);
  font-variation-settings:"opsz" 144,"SOFT" 30;
  letter-spacing:-.04em;color:var(--paper);white-space:nowrap;display:flex;gap:.3em;will-change:transform;padding-block:8px}
.bigname-row .em{font-style:italic;color:var(--accent);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 100}
.bigname-row .dot{color:var(--iris-400)}

@media(max-width:780px){.foot-inner{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:480px){.foot-inner{grid-template-columns:1fr;gap:24px}}

/* =========================================================
   GSAP reveal helpers
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px)}
.rword{display:inline-block;overflow:hidden;vertical-align:bottom;line-height:1.05;padding-right:.02em}
.rword > span{display:inline-block;will-change:transform;transform:translateY(110%)}

/* =========================================================
   VARIANT B — EDITORIAL CINEMA (lighter, type-led)
   Applied when body.variant-b
   ========================================================= */
body.variant-b{
  --accent:#E8E5D6;
  --accent-soft:rgba(232,229,214,.14);
  --accent-strong:#D8D5C6;
}
body.variant-b .marquee{background:var(--paper);color:#000;border-color:#000}
body.variant-b .nav-cta{background:var(--paper);color:#000;border-color:var(--paper)}
body.variant-b .nav-cta:hover{background:var(--accent);color:#000;border-color:var(--accent)}
body.variant-b .cta-pill:hover{background:#fff}
body.variant-b .hero-tag-r .live,
body.variant-b .essay .tag,
body.variant-b .testimonials-head .meta b,
body.variant-b .stat .num .suf,
body.variant-b .hero-title .em,
body.variant-b .hero-title .ast,
body.variant-b .intro-q h1 .em,
body.variant-b .manifesto-text h2 .em,
body.variant-b .manifesto-text .step,
body.variant-b .programs-head h2 .em,
body.variant-b .programs-head .rhs .em,
body.variant-b .essays-head .lhs h2 .em,
body.variant-b .essays-head .rhs p .em,
body.variant-b .reel-cap h3 .em,
body.variant-b .reel-cap .time b,
body.variant-b .reel-meta .m .lbl,
body.variant-b .closer h2 .em,
body.variant-b .hero-stage b,
body.variant-b .manifesto-portrait .pcorner b,
body.variant-b .program-card .body h3 .em,
body.variant-b .tcard .qm,
body.variant-b .tcard .who .country,
body.variant-b .hero-tag b,
body.variant-b .hero-tag-r b{color:#C9A24A}

/* Motion intensity */
body.motion-calm .marquee-row{animation-duration:60s!important}
body.motion-wild .marquee-row{animation-duration:14s!important}

/* Background darkness levels */
body.bg-deep{--black:#000000;--void:#020210}
body.bg-mid{--black:#070918;--void:#0B0E1F}
body.bg-soft{--black:#0E0F1F;--void:#13152B}

/* Video toggle */
body.no-video .hero-media video,
body.no-video .manifesto-bgvideo,
body.no-video .reel-frame video{display:none}
