/* ============================================================
   MEDIA HOUSE — landing page
   Three visual directions via [data-theme]: warm | noir | bold
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background .5s ease,color .5s ease;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
::selection{background:var(--accent);color:var(--bg)}

/* ---------- TYPE / SPACE SCALE ---------- */
:root{
  --maxw:1280px;
  --pad-x:clamp(20px,5vw,80px);
  --sec-y:clamp(80px,11vw,160px);
  --r:0px;
  --t:cubic-bezier(.22,.61,.36,1);
}

/* =====================================================
   THEME A — WARM EDITORIAL  (paper + forest green)
   ===================================================== */
[data-theme="warm"]{
  --bg:#f5f3ee;
  --bg-2:#ece7dd;
  --bg-inv:#23271f;
  --fg:#1d1b16;
  --fg-inv:#f3f1ea;
  --muted:#6f685b;
  --line:#d8d2c6;
  --accent:#3a4a3f;
  --accent-2:#a9603f;
  --font-display:"Newsreader",Georgia,serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"Space Mono",ui-monospace,monospace;
  --display-weight:500;
  --display-tracking:-0.02em;
  --display-style:italic-allowed;
  --r:2px;
  --hero-case:none;
}

/* =====================================================
   THEME B — CINEMATIC NOIR  (film black + terracotta)
   ===================================================== */
[data-theme="noir"]{
  --bg:#0a0a0b;
  --bg-2:#141416;
  --bg-inv:#f1efe9;
  --fg:#e9e6df;
  --fg-inv:#0a0a0b;
  --muted:#8b877d;
  --line:#26262a;
  --accent:#c2603a;
  --accent-2:#d8a05f;
  --font-display:"Archivo",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"Space Mono",ui-monospace,monospace;
  --display-weight:800;
  --display-tracking:-0.02em;
  --r:0px;
  --hero-case:none;
}

/* =====================================================
   THEME C — BOLD CONTRAST  (off-white + ink + vivid clay)
   ===================================================== */
[data-theme="bold"]{
  --bg:#eceae3;
  --bg-2:#e0ddd3;
  --bg-inv:#101010;
  --fg:#111110;
  --fg-inv:#f4f2ec;
  --muted:#5d5a51;
  --line:#cfcbbf;
  --accent:#d8522a;
  --accent-2:#101010;
  --font-display:"Archivo",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"Space Mono",ui-monospace,monospace;
  --display-weight:900;
  --display-tracking:-0.035em;
  --r:0px;
  --hero-case:uppercase;
}

/* ---------- LAYOUT PRIMITIVES ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--sec-y)}
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}
[data-theme="bold"] .eyebrow{color:var(--fg)}

h1,h2,h3{font-family:var(--font-display);font-weight:var(--display-weight);letter-spacing:var(--display-tracking);line-height:1.02;text-wrap:balance}
p{text-wrap:pretty}

/* ---------- HEADER ---------- */
.hdr{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad-x);
  transition:background .35s var(--t),border-color .35s,padding .35s var(--t);
  border-bottom:1px solid transparent;
}
.hdr.scrolled{
  background:color-mix(in oklab,var(--bg) 86%,transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
  padding-block:12px;
}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:var(--display-weight);font-size:1.18rem;letter-spacing:-.01em}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 22%,transparent)}
.nav{display:flex;align-items:center;gap:34px}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:.92rem;color:var(--muted);transition:color .2s;position:relative;padding-block:4px}
.nav-links a:hover{color:var(--fg)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--accent);transition:width .25s var(--t)}
.nav-links a:hover::after{width:100%}

.lang{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em}
.lang button{padding:6px 11px;color:var(--muted);transition:.2s}
.lang button.on{background:var(--fg);color:var(--bg)}

.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.78em 1.4em;border-radius:var(--r);
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  background:var(--accent);color:var(--bg);
  border:1px solid var(--accent);
  transition:transform .25s var(--t),background .25s,color .25s,box-shadow .25s;
  white-space:nowrap;
}
[data-theme="noir"] .btn{color:#fff}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px -10px color-mix(in oklab,var(--accent) 60%,transparent)}
.btn.ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--fg);box-shadow:none}
.btn.lg{padding:1em 1.7em;font-size:1rem}
.arr{transition:transform .25s var(--t)}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-top:clamp(92px,13vh,150px)}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media .ph{width:100%;height:100%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,
    color-mix(in oklab,var(--bg) 30%,transparent) 0%,
    color-mix(in oklab,var(--bg) 8%,transparent) 38%,
    color-mix(in oklab,var(--bg) 72%,transparent) 78%,
    var(--bg) 100%);
}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x) clamp(48px,7vw,96px)}
.hero h1{
  font-size:clamp(2.9rem,8.2vw,7.2rem);
  text-transform:var(--hero-case);
  margin:.28em 0 .42em;
  max-width:16ch;
}
[data-theme="warm"] .hero h1 em{font-style:italic;color:var(--accent)}
[data-theme="noir"] .hero h1{letter-spacing:-.03em}
[data-theme="bold"] .hero h1{line-height:.92}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.4rem);color:var(--muted);max-width:50ch;margin-bottom:2.1em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-meta{position:absolute;z-index:2;top:clamp(96px,12vh,140px);right:var(--pad-x);
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;color:var(--muted);
  text-align:right;line-height:2;display:none}
@media(min-width:900px){.hero-meta{display:block}}
.hero-meta b{color:var(--accent);font-weight:400}

/* ---------- MARQUEE / CREDENTIAL STRIP ---------- */
.strip{border-block:1px solid var(--line);background:var(--bg-2);overflow:hidden}
.strip-track{display:flex;gap:0;white-space:nowrap;animation:slide 38s linear infinite}
.strip:hover .strip-track{animation-play-state:paused}
.strip-track span{display:inline-flex;align-items:center;gap:18px;padding:18px 0;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.strip-track span::after{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin:0 40px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- WHAT WE DO ---------- */
.lead{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,72px);align-items:start}
@media(min-width:860px){.lead{grid-template-columns:.85fr 1.15fr}}
.lead h2{font-size:clamp(1.9rem,3.4vw,3rem);max-width:14ch}
.lead-body p{font-size:clamp(1.05rem,1.4vw,1.35rem);color:var(--muted);max-width:54ch}
.lead-body p + p{margin-top:1.1em}
.lead-body strong{color:var(--fg);font-weight:600}

/* ---------- SECTION HEADERS ---------- */
.sec-head{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x);margin-bottom:clamp(40px,5vw,72px)}
.sec-head h2{font-size:clamp(2.2rem,5vw,4.2rem);margin-top:.32em;max-width:18ch}
[data-theme="bold"] .sec-head h2{text-transform:uppercase}
.sec-head .lede{margin-top:1em;color:var(--muted);font-size:clamp(1.05rem,1.4vw,1.3rem);max-width:56ch}

/* ---------- WHY / BENEFIT GRID ---------- */
.benefits{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
@media(min-width:680px){.benefits{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.benefits{grid-template-columns:1fr 1fr 1fr}}
.benefit{
  padding:clamp(30px,3vw,46px) clamp(26px,2.4vw,40px);
  border-bottom:1px solid var(--line);
  position:relative;
  transition:background .3s;
}
@media(min-width:680px){.benefit:nth-child(odd){border-right:1px solid var(--line)}}
@media(min-width:1040px){
  .benefit{border-right:1px solid var(--line)}
  .benefit:nth-child(3n){border-right:none}
}
.benefit:hover{background:var(--bg-2)}
.benefit .num{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);letter-spacing:.1em}
.benefit h3{font-size:clamp(1.35rem,2vw,1.85rem);margin:.7em 0 .5em;line-height:1.08}
[data-theme="bold"] .benefit h3{text-transform:uppercase;letter-spacing:-.02em}
.benefit p{color:var(--muted);font-size:1rem;line-height:1.6}

/* ---------- METHOD ---------- */
.method{background:var(--bg-inv);color:var(--fg-inv)}
.method .eyebrow{color:var(--accent-2)}
.method .eyebrow::before{background:var(--accent-2)}
.method .sec-head h2{color:var(--fg-inv)}
.method .sec-head .lede{color:color-mix(in oklab,var(--fg-inv) 64%,transparent)}
.steps{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x);display:grid;gap:0;
  grid-template-columns:1fr;border-top:1px solid color-mix(in oklab,var(--fg-inv) 16%,transparent)}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,64px);align-items:baseline;
  padding:clamp(26px,3vw,42px) 0;
  border-bottom:1px solid color-mix(in oklab,var(--fg-inv) 16%,transparent);
}
.step .si{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-2);letter-spacing:.1em;padding-top:.5em}
.step h3{font-size:clamp(1.5rem,2.8vw,2.4rem);color:var(--fg-inv)}
.step p{color:color-mix(in oklab,var(--fg-inv) 62%,transparent);font-size:clamp(1rem,1.3vw,1.2rem);max-width:48ch;margin-top:.5em}
@media(min-width:820px){.step{grid-template-columns:80px .9fr 1.1fr}.step p{margin-top:.15em}}

/* ---------- MANIFESTO QUOTE ---------- */
.manifesto{text-align:center}
.manifesto blockquote{
  font-family:var(--font-display);font-weight:var(--display-weight);
  font-size:clamp(1.8rem,4.4vw,3.6rem);line-height:1.12;letter-spacing:var(--display-tracking);
  max-width:20ch;margin:0 auto;text-wrap:balance;
}
[data-theme="warm"] .manifesto blockquote{font-style:italic}
[data-theme="bold"] .manifesto blockquote{text-transform:uppercase}
.manifesto .who{margin-top:1.6em;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.manifesto .accent{color:var(--accent)}

/* ---------- CONTACT ---------- */
.contact{display:grid;grid-template-columns:1fr;gap:clamp(36px,5vw,80px);align-items:start}
@media(min-width:920px){.contact{grid-template-columns:1fr 1fr}}
.contact h2{font-size:clamp(2.4rem,5.2vw,4.4rem);max-width:12ch}
[data-theme="bold"] .contact h2{text-transform:uppercase}
.contact .ct-sub{color:var(--muted);font-size:clamp(1.05rem,1.4vw,1.3rem);margin-top:1em;max-width:42ch}
.contact .ct-detail{margin-top:2.2em;display:flex;flex-direction:column;gap:.5em;font-family:var(--font-mono);font-size:.92rem;letter-spacing:.04em}
.contact .ct-detail a{color:var(--accent);transition:.2s}
.contact .ct-detail a:hover{opacity:.7}
.form{display:grid;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);
  padding:.85em 1em;color:var(--fg);font:inherit;font-size:1rem;transition:border-color .2s,background .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:var(--bg)}
.field textarea{resize:vertical;min-height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
.ftr{border-top:1px solid var(--line);padding-block:clamp(50px,6vw,80px)}
.ftr-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;align-items:flex-start}
.ftr .brand{font-size:1.5rem}
.ftr-soc{display:flex;gap:24px;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.ftr-soc a{color:var(--muted);transition:.2s}
.ftr-soc a:hover{color:var(--accent)}
.ftr-bot{margin-top:clamp(40px,5vw,64px);display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}

/* ---------- IMAGE PLACEHOLDERS ---------- */
.ph{
  position:relative;overflow:hidden;border-radius:var(--r);
  background:
    repeating-linear-gradient(135deg,
      color-mix(in oklab,var(--accent) 9%,var(--bg-2)) 0 14px,
      var(--bg-2) 14px 28px);
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
}
[data-theme="noir"] .hero-media .ph{
  background:
    radial-gradient(120% 90% at 70% 30%, color-mix(in oklab,var(--accent) 16%,#000) 0%, #050505 70%),
    repeating-linear-gradient(135deg,#0f0f10 0 16px,#0a0a0b 16px 32px);
  border:none;
}
.ph .ph-label{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:color-mix(in oklab,var(--fg) 60%,transparent);
  background:color-mix(in oklab,var(--bg) 70%,transparent);
  padding:.6em 1em;border:1px solid var(--line);border-radius:var(--r);
  backdrop-filter:blur(2px);
}
.hero-media .ph .ph-label{color:color-mix(in oklab,#fff 75%,transparent);background:rgba(0,0,0,.32);border-color:rgba(255,255,255,.18)}
.ph.tall{aspect-ratio:4/5}
.ph.wide{aspect-ratio:16/9}
.ph.sq{aspect-ratio:1/1}

/* play button on hero — inline watch link */
.playlink{display:inline-flex;align-items:center;gap:13px;color:var(--fg);transition:opacity .2s}
.playlink:hover{opacity:.7}
.playlink:hover .pl-ring{transform:scale(1.06)}
.pl-ring{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:color-mix(in oklab,var(--accent) 90%,transparent);transition:transform .25s var(--t);
  box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 45%,transparent);animation:pulse 2.8s var(--t) infinite}
.pl-ring svg{width:18px;height:18px;fill:var(--bg);margin-left:3px}
[data-theme="noir"] .pl-ring svg{fill:#fff}
.pl-txt{display:flex;flex-direction:column;line-height:1.25;text-align:left;white-space:nowrap}
.pl-txt span:first-child{font-weight:600;font-size:.95rem}
.pl-time{font-family:var(--font-mono);font-size:.72rem;color:var(--muted);letter-spacing:.05em}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 40%,transparent)}70%{box-shadow:0 0 0 16px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* ---------- MEDIA SPLIT (method/visual interludes) ---------- */
.split{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,60px);align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}.split.rev .split-media{order:2}}

/* ---------- DIRECTION SWITCHER ---------- */
.switcher{
  position:fixed;z-index:90;left:50%;bottom:22px;transform:translateX(-50%);
  display:flex;align-items:center;gap:4px;
  padding:7px 7px 7px 16px;border-radius:999px;
  background:color-mix(in oklab,var(--bg) 78%,#0000);
  border:1px solid var(--line);
  backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:0 18px 50px -18px rgba(0,0,0,.5);
  font-family:var(--font-mono);
}
.switcher .sw-label{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-right:6px}
.switcher button{
  display:flex;align-items:center;gap:7px;
  padding:7px 13px;border-radius:999px;font-size:.74rem;letter-spacing:.04em;color:var(--muted);
  transition:.22s var(--t);
}
.switcher button .sw-dot{width:9px;height:9px;border-radius:50%;border:1px solid currentColor}
.switcher button[data-sw="warm"] .sw-dot{background:#3a4a3f;border-color:#3a4a3f}
.switcher button[data-sw="noir"] .sw-dot{background:#c2603a;border-color:#c2603a}
.switcher button[data-sw="bold"] .sw-dot{background:#d8522a;border-color:#d8522a}
.switcher button.on{background:var(--fg);color:var(--bg)}
.switcher button.on .sw-dot{box-shadow:0 0 0 2px var(--bg)}
.switcher button:not(.on):hover{color:var(--fg)}
@media(max-width:620px){.switcher .sw-label{display:none}.switcher{padding-left:7px}}

/* ---------- REVEAL ANIMATION ---------- */
/* CRITICAL: opacity is ALWAYS 1 — content is never hidden by opacity, so it can
   never get stuck invisible if the environment throttles transitions/animations.
   The reveal is a transform-only slide; if it freezes, elements just sit a few px
   lower but remain fully visible. */
.rv{opacity:1}
html.js .rv{transform:translateY(22px);transition:transform .85s var(--t)}
html.js .rv.in{transform:none}
html.js .rv.d1{transition-delay:.08s}
html.js .rv.d2{transition-delay:.16s}
html.js .rv.d3{transition-delay:.24s}
html.js .rv.d4{transition-delay:.32s}
html.js .rv.d5{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){html.js .rv{transform:none;transition:none}.strip-track,.pl-ring{animation:none}}

/* ---------- MOBILE NAV ---------- */
@media(max-width:840px){
  .nav-links{display:none}
}

/* ---------- VALUES / CREED (editorial row list — distinct from benefit cards) ---------- */
.creed{max-width:1100px;margin:0 auto;padding-inline:var(--pad-x)}
.creed-item{
  display:grid;grid-template-columns:1fr;gap:12px;
  padding-block:clamp(26px,3.4vw,46px);
  border-top:1px solid var(--line);
}
.creed-item:last-child{border-bottom:1px solid var(--line)}
@media(min-width:820px){
  .creed-item{grid-template-columns:minmax(220px,.8fr) 1.2fr;gap:clamp(32px,5vw,80px);align-items:baseline}
}
.creed-item h3{
  font-family:var(--font-display);font-weight:var(--display-weight);
  font-size:clamp(1.7rem,3.4vw,2.7rem);letter-spacing:var(--display-tracking);line-height:1.05;
}
[data-theme="warm"] .creed-item h3{font-style:italic;color:var(--accent)}
[data-theme="noir"] .creed-item h3{color:var(--accent-2)}
[data-theme="bold"] .creed-item h3{text-transform:uppercase}
.creed-item p{color:var(--muted);font-size:clamp(1.05rem,1.4vw,1.28rem);line-height:1.55;max-width:52ch}

/* ---------- PRICING ---------- */
.pricing{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x)}
.price-card{
  border:1px solid var(--line);background:var(--bg-2);border-radius:var(--r);
  padding:clamp(34px,5vw,68px);
  display:grid;grid-template-columns:1fr;gap:clamp(24px,3vw,48px);
}
@media(min-width:860px){.price-card{grid-template-columns:.8fr 1.2fr;align-items:center}}
.price-num{font-family:var(--font-display);font-weight:var(--display-weight);
  font-size:clamp(2.6rem,6vw,4.6rem);line-height:1;letter-spacing:var(--display-tracking);color:var(--accent)}
[data-theme="bold"] .price-num{color:var(--fg)}
.price-label{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-top:1em}
.price-body p{color:var(--muted);font-size:clamp(1.02rem,1.3vw,1.2rem);max-width:56ch}
.price-body p + p{margin-top:1em}

/* ---------- CTA BAND ---------- */
.cta-band{background:var(--bg-inv);color:var(--fg-inv);text-align:center}
.cta-band .wrap{display:flex;flex-direction:column;align-items:center;gap:clamp(22px,3vw,34px)}
.cta-band h2{font-family:var(--font-display);font-weight:var(--display-weight);
  font-size:clamp(1.8rem,4vw,3.2rem);line-height:1.1;letter-spacing:var(--display-tracking);
  max-width:22ch;text-wrap:balance;color:var(--fg-inv)}
[data-theme="warm"] .cta-band h2{font-style:italic}
[data-theme="bold"] .cta-band h2{text-transform:uppercase;font-style:normal}

/* ---------- ABOUT / MEDAILONKY ---------- */
.about{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x);
  display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
@media(min-width:860px){.about{grid-template-columns:1fr 1fr 1fr}}
.about-card{padding:clamp(30px,3vw,46px) 0;border-bottom:1px solid var(--line)}
@media(min-width:860px){
  .about-card{padding:clamp(30px,3vw,46px) clamp(26px,2.4vw,40px);border-right:1px solid var(--line)}
  .about-card:first-child{padding-left:0}
  .about-card:last-child{border-right:none;padding-right:0}
}
.about-card .role{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;color:var(--accent);text-transform:uppercase}
.about-card h3{font-size:clamp(1.4rem,2vw,1.9rem);margin:.55em 0 .5em}
.about-card p{color:var(--muted);font-size:1rem;line-height:1.6}
.about-card p + p{margin-top:.9em}
.about-card .todo{color:var(--accent-2);font-style:italic}
.about-more{display:inline-block;margin-top:1.1em;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);transition:opacity .2s}
.about-more:hover{opacity:.65}

/* ---------- ARTICLE / BIO SUBPAGE ---------- */
.prose{max-width:780px;margin:0 auto;padding-inline:var(--pad-x)}
.subhero{padding-top:clamp(120px,17vh,210px);padding-bottom:clamp(28px,5vw,56px)}
.subhero h1{font-size:clamp(2.6rem,7vw,5rem);margin:.2em 0 .35em;text-transform:var(--hero-case)}
[data-theme="bold"] .subhero h1{line-height:.95}
.sub-lede{color:var(--muted);font-size:clamp(1.15rem,1.7vw,1.5rem);line-height:1.5;max-width:60ch}
.back-link{display:inline-block;margin-top:1.8em;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);transition:opacity .2s}
.back-link:hover{opacity:.65}
.prose .block{padding-block:clamp(34px,4.2vw,62px);border-top:1px solid var(--line)}
.prose h2{font-family:var(--font-display);font-weight:var(--display-weight);letter-spacing:var(--display-tracking);font-size:clamp(1.7rem,3.2vw,2.6rem);line-height:1.08;margin-bottom:.7em}
[data-theme="warm"] .prose h2{font-style:italic;color:var(--accent)}
[data-theme="bold"] .prose h2{text-transform:uppercase}
.prose p{color:var(--muted);font-size:clamp(1.05rem,1.3vw,1.2rem);line-height:1.65}
.prose p + p{margin-top:1em}
.prose strong{color:var(--fg);font-weight:600}
.bul{list-style:none;margin-top:1.1em;display:grid;gap:1em}
.bul li{position:relative;padding-left:1.5em;color:var(--muted);font-size:clamp(1.05rem,1.3vw,1.2rem);line-height:1.6}
.bul li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;background:var(--accent);border-radius:50%}
.bul li strong{color:var(--fg);font-weight:600}
.sub-cta{display:flex;justify-content:center}
