/* ============================================================
   anantmd.com — NGM editorial system
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;1,8..60,400&family=DM+Sans:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,700;0,6..96,800&family=Playfair+Display:wght@700;800;900&family=Archivo:wght@700;800;900&display=swap');

:root{
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-body:"Source Serif 4",Georgia,serif;
  --font-ui:"DM Sans",system-ui,sans-serif;
  --paper:#FEFDFB; --paper-warm:#F5F3EE; --paper-cool:#F0EDE6;
  --ink:#1A1A1A; --ink-2:#3A3A3A; --ink-3:#6A6A6A; --ink-4:#9A9A9A; --ink-faint:#BEBEBE;
  --rule:#D4D0C8; --rule-light:#E8E5DE;
  --accent:#8B7355; --accent-light:#A89070; --gold:#C49A6C;
  --green:#4A7A5A; --blue:#4A6A7A; --orange:#B06840; --vermillion:#C07050; --purple:#6A5A7A;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--font-body);font-size:17px;line-height:1.8;
  color:var(--ink-2);background:var(--paper);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:var(--blue);text-decoration:none}

/* ---- shared layout ---- */
.wrap{max-width:1120px;margin:0 auto;padding:0 40px}
.reading{max-width:760px;margin:0 auto;padding:0 40px}
.section{padding:104px 0}
.section--tight{padding:80px 0}

.kicker{
  font-family:var(--font-ui);font-size:11px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--accent);
  display:block;margin-bottom:20px;
}
h1,h2,h3{font-family:var(--font-display);color:var(--ink);font-weight:400}
h2{font-size:2.5rem;line-height:1.15;letter-spacing:-.01em}
h3{font-size:1.4rem;font-weight:500;line-height:1.3}
.deck{font-family:var(--font-display);font-style:italic;font-size:1.4rem;line-height:1.6;color:var(--ink-3)}
p{margin-bottom:20px;text-wrap:pretty}
strong{color:var(--ink);font-weight:600}
.lead{font-size:1.2rem;line-height:1.65;color:var(--ink-2)}

.eyebrow-rule{display:flex;align-items:center;gap:16px;margin-bottom:36px}
.eyebrow-rule .kicker{margin-bottom:0}
.eyebrow-rule::after{content:"";flex:1;height:1px;background:var(--rule)}

/* ---- buttons / links ---- */
.btn{
  font-family:var(--font-ui);font-size:14px;font-weight:600;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  padding:14px 28px;border-radius:2px;text-decoration:none;transition:background .2s,color .2s,border-color .2s;
}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper);border:1px solid var(--ink)}
.btn-primary:hover{background:var(--vermillion);border-color:var(--vermillion)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}
.btn-ghost:hover{border-color:var(--ink)}

.link-arrow{
  font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--rule);padding-bottom:3px;transition:border-color .2s,color .2s;
}
.link-arrow .arr{transition:transform .25s ease}
.link-arrow:hover{color:var(--accent);border-color:var(--accent)}
.link-arrow:hover .arr{transform:translateX(4px)}

/* ============================================================ NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:68px;
  background:rgba(254,253,251,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.nav.scrolled{border-bottom-color:var(--rule-light);background:rgba(254,253,251,.94)}
.nav-inner{max-width:1120px;margin:0 auto;height:100%;padding:0 40px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:baseline;gap:9px;text-decoration:none}
.brand .nm{font-family:var(--font-display);font-size:1.3rem;color:var(--ink);letter-spacing:-.01em;white-space:nowrap}
.brand .suf{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--ink-4);text-transform:uppercase;white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--ink-3);position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:1px;background:var(--accent);transition:right .3s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{right:0}
.nav-cta{
  font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.03em;
  padding:8px 16px;border:1px solid var(--rule);border-radius:2px;color:var(--ink);transition:border-color .2s,background .2s}
.nav-cta:hover{border-color:var(--ink)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink)}

/* ============================================================ HERO */
.hero{padding:148px 0 96px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:72px;align-items:center}
.hero h1{margin:0}
.hero .name{
  display:block;font-family:var(--font-ui);font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.hero .headline{
  display:block;font-family:var(--font-display);font-weight:400;font-size:3.7rem;
  line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
.hero .headline em{font-style:italic;color:var(--accent)}
.hero .sub{margin-top:40px;font-size:1.18rem;line-height:1.65;color:var(--ink-3);max-width:520px}
.hero .sub .hims{color:var(--ink-2)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:40px}
.portrait{position:relative}
.portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 18%;border:1px solid var(--rule-light);box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.06))}
.portrait::after{content:"";position:absolute;left:-18px;bottom:-18px;width:120px;height:120px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);z-index:-1}
.portrait .cap{
  font-family:var(--font-ui);font-size:11px;letter-spacing:.04em;color:var(--ink-4);
  margin-top:14px;display:flex;justify-content:space-between}

/* ============================================================ BUILDING NOW */
.building{background:var(--paper)}
.building .body p{font-size:1.12rem;line-height:1.78;color:var(--ink-2)}
.building .body p:last-child{margin-bottom:0}

/* ============================================================ NGM CENTERPIECE */
.ngm{background:var(--paper-warm);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.ngm-head{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:64px}
.ngm-head h2{font-size:3rem}
.ngm-head .lead{margin:0}
.ngm-split{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:start}
.platform-list{list-style:none}
.platform-list li{display:grid;grid-template-columns:34px 1fr;gap:18px;padding:22px 0;border-bottom:1px solid var(--rule-light)}
.platform-list li:first-child{border-top:1px solid var(--rule-light)}
.platform-list .rn{font-family:var(--font-display);font-size:1rem;color:var(--accent);letter-spacing:.12em;padding-top:5px}
.platform-list .pname{font-family:var(--font-display);font-size:1.35rem;font-weight:500;color:var(--ink);line-height:1.25;margin-bottom:4px}
.platform-list .pdesc{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--ink-3);margin:0}
.ngm-aside{position:sticky;top:96px}
.shots{position:relative;height:auto}
.shot{border:1px solid var(--rule-light);background:var(--paper);border-radius:3px;overflow:hidden;box-shadow:var(--shadow-md,0 4px 24px rgba(0,0,0,.08))}
.shot+.shot{margin-top:-26px}
.shot.s2{margin-left:42px;box-shadow:0 8px 40px rgba(0,0,0,.12)}
.shot.s3{margin-left:14px;width:78%}
.shot .sl{font-family:var(--font-ui);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);padding:8px 12px;border-top:1px solid var(--rule-light)}
.proof{font-family:var(--font-body);font-size:15px;color:var(--ink-3);font-style:italic;border-left:2px solid var(--accent);padding-left:18px;margin:48px 0 0}
.dual{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:56px;border-top:1px solid var(--rule)}
.dual .col{padding:32px 32px 32px 26px;border-left:2px solid var(--accent)}
.dual .col:first-child{border-right:1px solid var(--rule-light)}
.dual .col h3{margin-bottom:8px}
.dual .col p{font-size:15px;line-height:1.55;color:var(--ink-3);margin-bottom:18px}

/* ============================================================ LONGEVITY 2026 */
.l26{background:var(--paper-cool)}
.l26-grid{display:grid;grid-template-columns:.62fr 1fr;gap:64px;align-items:center}
.datecard{border:1px solid var(--rule);background:var(--paper);padding:40px 36px}
.datecard .yr{font-family:var(--font-display);font-size:5rem;line-height:.9;color:var(--ink);letter-spacing:-.02em}
.datecard .dt{font-family:var(--font-ui);font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--accent);margin-top:14px;text-transform:uppercase}
.datecard .loc{font-family:var(--font-body);font-size:15px;color:var(--ink-3);margin-top:18px;line-height:1.5}
.datecard .rule{height:1px;background:var(--rule-light);margin:24px 0}
.l26 h2{font-size:2.6rem;margin-bottom:8px}
.l26 .role{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);margin-bottom:22px}

/* ============================================================ BACKGROUND */
.bg-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:72px;align-items:start}
.timeline{list-style:none}
.tl-row{display:grid;grid-template-columns:118px 1fr;gap:20px;padding:20px 0;border-bottom:1px solid var(--rule-light)}
.tl-row:first-child{border-top:1px solid var(--rule)}
.tl-row .per{font-family:var(--font-ui);font-size:12px;font-weight:500;letter-spacing:.02em;color:var(--ink-4);padding-top:4px}
.tl-row .role{font-family:var(--font-display);font-size:1.2rem;color:var(--ink);line-height:1.25}
.tl-row .org{font-family:var(--font-ui);font-size:13px;color:var(--accent);margin-top:2px}
.tl-row .note{font-size:14px;color:var(--ink-3);line-height:1.5;margin-top:6px}
.tl-row.advisory .role{font-size:1.05rem;color:var(--ink-2)}
.sidecard h3{font-size:1.1rem;font-weight:500;margin-bottom:14px}
.eduline{padding:14px 0;border-bottom:1px solid var(--rule-light)}
.eduline .d{font-family:var(--font-display);font-size:1.12rem;color:var(--ink)}
.eduline .i{font-family:var(--font-ui);font-size:13px;color:var(--ink-3);margin-top:2px}
.press{margin-top:36px;padding-top:28px;border-top:1px solid var(--rule)}
.press .lbl{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);margin-bottom:12px}
.press .outlets{font-family:var(--font-display);font-size:1.25rem;color:var(--ink-2);line-height:1.5}

/* ============================================================ SPEAKING */
.speaking{background:var(--paper-warm);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.spk-list{list-style:none;margin-top:8px}
.spk-row{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--rule-light)}
.spk-row:first-child{border-top:1px solid var(--rule)}
.spk-row .ev{font-family:var(--font-display);font-size:1.3rem;color:var(--ink)}
.spk-row .lc{font-family:var(--font-ui);font-size:13px;color:var(--ink-3)}
.spk-row .dt{font-family:var(--font-ui);font-size:12px;letter-spacing:.04em;color:var(--ink-4);white-space:nowrap}

/* ============================================================ NEWSLETTER */
.news{background:var(--ink);color:var(--paper)}
.news .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.news .kicker{color:var(--gold)}
.news h2{color:var(--paper);font-size:2.4rem}
.news p{color:rgba(254,253,251,.6);margin:0}
.nl-form{display:flex;flex-direction:column;gap:14px}
.nl-row{display:flex;gap:12px}
.nl-form input{
  font-family:var(--font-ui);font-size:15px;flex:1;width:100%;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.18);
  color:var(--paper);padding:14px 16px;border-radius:2px;outline:none;transition:border-color .2s}
.nl-form input::placeholder{color:rgba(254,253,251,.4)}
.nl-form input:focus{border-color:var(--gold)}
.nl-form button{
  font-family:var(--font-ui);font-size:14px;font-weight:600;cursor:pointer;
  background:var(--gold);color:var(--ink);border:none;border-radius:2px;padding:14px 24px;transition:background .2s}
.nl-form button:hover{background:#d4ab7d}
.nl-form button:disabled{opacity:.6;cursor:default}
.nl-note{font-family:var(--font-ui);font-size:12px;color:rgba(254,253,251,.4);margin-top:4px}
.nl-msg{font-family:var(--font-ui);font-size:14px;min-height:20px}
.nl-msg.ok{color:var(--gold)}
.nl-msg.err{color:#e0a890}

/* ============================================================ CONTACT */
.contact .reading{text-align:center}
.contact h2{font-size:2.4rem;margin-bottom:8px}
.contact .intro{color:var(--ink-3);max-width:520px;margin:0 auto 40px}
.cmethods{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;margin-bottom:56px}
.cm{font-family:var(--font-ui)}
.cm .l{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);margin-bottom:8px}
.cm a{font-family:var(--font-body);font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--rule);padding-bottom:2px;transition:border-color .2s}
.cm a:hover{border-color:var(--ink)}
.tagline{border-top:1px solid var(--rule);padding-top:40px;max-width:600px;margin:0 auto}
.tagline .q{font-family:var(--font-display);font-style:italic;font-size:1.5rem;line-height:1.5;color:var(--ink)}
.tagline .by{font-family:var(--font-ui);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);margin-top:18px}

/* ============================================================ FOOTER */
.foot{background:var(--paper);border-top:1px solid var(--rule);padding:56px 0 48px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px}
.foot .nm{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);margin-bottom:10px}
.foot .blurb{font-size:14px;color:var(--ink-3);line-height:1.6;max-width:340px}
.foot .col .h{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);margin-bottom:16px}
.foot .col a{display:block;font-family:var(--font-ui);font-size:14px;color:var(--ink-2);margin-bottom:11px;transition:color .2s}
.foot .col a:hover{color:var(--accent)}
.foot-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-top:48px;padding-top:28px;border-top:1px solid var(--rule-light)}
.foot-base .cp{font-family:var(--font-ui);font-size:12px;color:var(--ink-4)}
.foot-base .lk{font-family:var(--font-ui);font-size:12px;color:var(--accent)}

/* ============================================================ PRESS BAR */
.pressbar{border-top:1px solid var(--rule-light);border-bottom:1px solid var(--rule-light);background:var(--paper)}
.pressbar .wrap{display:flex;align-items:center;justify-content:center;gap:36px;padding:24px 40px;flex-wrap:wrap}
.pressbar .lbl{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4)}
.pressbar .names{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center}
.pressbar .names span{font-family:var(--font-display);font-size:1.3rem;color:var(--ink-3);white-space:nowrap}

/* ---- publication wordmarks: typeset to evoke each masthead, uniform muted ink ---- */
.pressbar .press-logos{gap:42px !important}
.pressbar .press-logos .plogo{color:var(--ink-2);white-space:nowrap;line-height:1;display:inline-block;opacity:.78;transition:opacity .2s}
.pressbar .press-logos .plogo:hover{opacity:1}
.pressbar .press-logos .plogo-wsj{font-family:"Playfair Display",Georgia,serif;font-weight:800;font-size:1.18rem;letter-spacing:-.005em}
.pressbar .press-logos .plogo-forbes{font-family:"Playfair Display",Georgia,serif;font-weight:900;font-size:1.62rem;letter-spacing:-.02em}
.pressbar .press-logos .plogo-fortune{font-family:"Bodoni Moda",Georgia,serif;font-weight:800;font-size:1.42rem;letter-spacing:.02em}
.pressbar .press-logos .plogo-bi{font-family:"Archivo","DM Sans",sans-serif;font-weight:900;font-size:1.04rem;letter-spacing:-.01em}
.pressbar .press-logos .plogo-vogue{font-family:"Bodoni Moda",Georgia,serif;font-weight:500;font-size:1.6rem;letter-spacing:.34em;text-indent:.34em}

/* ============================================================ NGM PILLARS + SHOWCASE */
.feature{margin:8px 0 4px;border:1px solid var(--rule-light);border-radius:3px;overflow:hidden;background:#fff;box-shadow:0 8px 40px rgba(0,0,0,.10)}
.feature img{width:100%;display:block;background:#fafafa}
.feature figcaption,.shot-pair figcaption{font-family:var(--font-ui);font-size:12px;color:var(--ink-3);padding:13px 18px;border-top:1px solid var(--rule-light);display:flex;gap:8px;align-items:baseline}
.feature figcaption .t,.shot-pair figcaption .t{color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:10px;white-space:nowrap;flex-shrink:0}
.shot-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}
.shot-pair figure{margin:0;border:1px solid var(--rule-light);border-radius:3px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.06))}
.shot-pair img{width:100%;display:block;background:#fafafa}

.pillars{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--rule);margin:56px 0 0}
.pillar{padding:30px 36px 30px 0;border-bottom:1px solid var(--rule-light)}
.pillar:nth-child(odd){border-right:1px solid var(--rule-light)}
.pillar:nth-child(even){padding-left:36px}
.pillar .rn{font-family:var(--font-display);font-size:1rem;color:var(--accent);letter-spacing:.18em;display:block;margin-bottom:10px}
.pillar h3{font-size:1.5rem;margin-bottom:8px}
.pillar .role{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:12px}
.pillar p{font-size:15px;line-height:1.6;color:var(--ink-3);margin-bottom:12px}
.pillar .tools{font-family:var(--font-ui);font-size:12.5px;color:var(--ink-4);line-height:1.5;margin:0}
.pillar .tools b{color:var(--ink-3);font-weight:600}
.pillar .more{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--accent)}

/* ============================================================ HIMS TOGGLE */
[data-hims-el]{display:none}
html[data-hims="on"] [data-hims-el]{display:block}
html[data-hims="on"] [data-hims-el].inline{display:inline}
html[data-hims="on"] .tl-row[data-hims-el]{display:grid}
/* while the Hims row is gated off, the next row closes the top of the timeline */
html:not([data-hims="on"]) .timeline .tl-row[data-hims-el] + .tl-row{border-top:1px solid var(--rule)}

/* ============================================================ RESPONSIVE */
@media(max-width:960px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--rule);padding:8px 24px 20px}
  .nav.open .nav-links a{padding:12px 0;font-size:15px}
}
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .portrait{max-width:420px}
  .hero .headline{font-size:3.2rem}
  .ngm-head,.ngm-split,.l26-grid,.bg-grid,.news .wrap{grid-template-columns:1fr;gap:40px}
  .pillars{grid-template-columns:1fr}
  .pillar:nth-child(odd){border-right:none}
  .pillar:nth-child(even){padding-left:0}
  .pillar{padding-right:0}
  .ngm-aside{position:static}
  .shot.s2{margin-left:0}.shot.s3{margin-left:0;width:100%}
  .foot-grid{grid-template-columns:1fr 1fr}
}
/* ============================================================ SHOWCASE / GALLERY */
.showcase{background:var(--paper)}
.gal-group{margin-top:72px}
.gal-group:first-of-type{margin-top:4px}
.gal-label{max-width:680px;margin-bottom:26px}
.gal-label .kicker{margin-bottom:10px}
.gal-label p{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--ink-3);margin:0}
.gal{display:grid;gap:24px}
.gal-2{grid-template-columns:1fr 1fr}
.gal-3{grid-template-columns:repeat(3,1fr)}
.gcard{margin:0;border:1px solid var(--rule-light);border-radius:3px;overflow:hidden;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.06);display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.gcard:hover{border-color:var(--rule);box-shadow:0 6px 28px rgba(0,0,0,.09)}
.gcard img{width:100%;display:block;background:#fafafa}
.gcard.slide img{background:var(--paper)}
.gcard figcaption{font-family:var(--font-ui);font-size:12px;color:var(--ink-3);padding:13px 18px;border-top:1px solid var(--rule-light);display:flex;gap:8px;align-items:baseline;margin-top:auto}
.gcard figcaption .t{color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:10px;white-space:nowrap;flex-shrink:0}

/* ============================================================ CONTACT FORM */
.contact-form{max-width:560px;margin:0 auto 52px;text-align:left;display:flex;flex-direction:column;gap:14px}
.cf-row{display:flex;gap:12px}
.contact-form input,.contact-form textarea{
  font-family:var(--font-ui);font-size:15px;width:100%;flex:1;
  background:var(--paper);border:1px solid var(--rule);color:var(--ink);
  padding:13px 15px;border-radius:2px;outline:none;transition:border-color .2s}
.contact-form textarea{resize:vertical;min-height:122px;line-height:1.55}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--ink-4)}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent)}
.contact-form button{
  font-family:var(--font-ui);font-size:14px;font-weight:600;cursor:pointer;align-self:flex-start;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:2px;padding:14px 28px;transition:background .2s,border-color .2s}
.contact-form button:hover{background:var(--vermillion);border-color:var(--vermillion)}
.contact-form button:disabled{opacity:.6;cursor:default}
.cf-msg{font-family:var(--font-ui);font-size:14px;min-height:20px}
.cf-msg.ok{color:var(--green)}
.cf-msg.err{color:var(--vermillion)}
.cf-note{font-family:var(--font-ui);font-size:12px;color:var(--ink-4)}

@media(max-width:920px){
  .gal-2,.gal-3{grid-template-columns:1fr}
}

@media(max-width:680px){
  .wrap,.reading{padding:0 24px}
  .nav-inner{padding:0 24px}
  .section{padding:72px 0}
  .hero{padding:120px 0 72px}
  .hero .headline{font-size:2.6rem}
  h2,.ngm-head h2,.l26 h2,.news h2,.contact h2{font-size:2rem}
  .dual{grid-template-columns:1fr}
  .shot-pair{grid-template-columns:1fr}
  .pressbar .names span{font-size:1.1rem}
  .pressbar .press-logos{gap:26px !important}
  .pressbar .press-logos .plogo-forbes{font-size:1.32rem}
  .pressbar .press-logos .plogo-fortune,.pressbar .press-logos .plogo-vogue{font-size:1.2rem}
  .pressbar .press-logos .plogo-wsj{font-size:1rem}
  .pressbar .press-logos .plogo-bi{font-size:.92rem}
  .dual .col:first-child{border-right:none;border-bottom:1px solid var(--rule-light)}
  .nl-row{flex-direction:column}
  .cf-row{flex-direction:column}
  .foot-grid{grid-template-columns:1fr}
  .cmethods{gap:32px}
}

/* ============================================================ PRESS BAR (quiet) */
.pressbar-quiet .wrap{gap:18px;padding:18px 40px}
.outlets-quiet{font-family:var(--font-ui);font-size:12.5px;letter-spacing:.05em;color:var(--ink-4)}

/* ============================================================ PRINCIPLES */
.principles{background:var(--paper-warm);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.princ-lede{max-width:640px;margin-bottom:8px}
.princ-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;margin-top:44px;border-top:1px solid var(--rule)}
.princ{display:flex;flex-direction:column;padding:36px 48px 40px 0;border-bottom:1px solid var(--rule-light)}
.princ:nth-child(odd){border-right:1px solid var(--rule-light)}
.princ:nth-child(even){padding-left:48px}
.princ-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.princ .pn{font-family:var(--font-display);font-size:1.05rem;color:var(--accent);letter-spacing:.12em}
.princ-mark{width:62px;height:62px;color:var(--accent);flex-shrink:0}
.princ h3{font-size:1.5rem;font-weight:500;line-height:1.22;margin-bottom:12px;max-width:20ch}
.princ p{font-size:15px;line-height:1.7;color:var(--ink-3);margin:0;max-width:46ch}

/* ============================================================ NGM GALLERY (folded) */
.ngm-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:8px 0}

/* ============================================================ CONFERENCE FEATURE */
.confsec{
  --cpaper:#F7F2E8;--cpaper-soft:#FBF7EE;--cink:#1C1915;--cink2:#3A342C;
  --cink3:#6B6356;--cink4:#9C9384;--crule:#DDD4BF;--cgold:#B0874E;--cgold-soft:#CBA976;--cseal:#A8351F;
  background:var(--cpaper);color:var(--cink2);
  border-top:1px solid var(--crule);border-bottom:1px solid var(--crule);padding:104px 0;
}
.confwrap{max-width:1120px;margin:0 auto;padding:0 40px}
.conf-eyebrow{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cgold);display:inline-flex;align-items:center;gap:12px;margin-bottom:18px}
.conf-eyebrow::before{content:"";width:26px;height:1px;background:var(--cgold)}
.confsec h2,.confsec h3,.confsec h4,.confsec h5{font-family:var(--font-display);color:var(--cink);font-weight:400}

.conf-dateline{display:flex;justify-content:space-between;align-items:baseline;gap:24px;flex-wrap:wrap;font-family:var(--font-ui);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--cink3);margin-bottom:56px}
.conf-dateline .mid{font-family:var(--font-display);font-style:italic;letter-spacing:0;text-transform:none;font-size:16px;color:var(--cgold)}

.conf-head{max-width:860px;margin-bottom:48px}
.conf-head h2{font-size:clamp(48px,6vw,82px);line-height:.98;letter-spacing:-.02em;font-weight:300;margin-bottom:24px}
.conf-head h2 .amp{font-style:italic;color:var(--cgold)}
.conf-lede{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:24px;line-height:1.5;color:var(--cink2);max-width:620px;margin-bottom:36px}
.conf-ctas{display:flex;gap:14px;flex-wrap:wrap}

.confbtn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;padding:15px 26px;transition:background .2s,color .2s,border-color .2s,transform .2s}
.confbtn .arr{transition:transform .25s}
.confbtn:hover{transform:translateY(-1px)}
.confbtn-primary{background:var(--cink);color:var(--cpaper-soft);border:1px solid var(--cink)}
.confbtn-primary:hover{background:var(--cseal);border-color:var(--cseal)}
.confbtn-ghost{background:transparent;color:var(--cink);border:1px solid var(--cink)}
.confbtn-ghost:hover{background:var(--cink);color:var(--cpaper-soft)}

.conf-plate{position:relative;overflow:hidden;background:var(--cink);margin:0}
.conf-plate img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.85) contrast(1.02)}
.conf-plate-hero{aspect-ratio:21/9;margin-top:8px}
.conf-plate-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,21,.05),rgba(28,25,21,.4))}
.plate-tag{position:absolute;top:22px;left:22px;z-index:2;font-family:var(--font-ui);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--cpaper-soft)}
.plate-seal{position:absolute;bottom:24px;right:24px;z-index:2;width:62px;height:62px;border-radius:50%;background:var(--cseal);color:var(--cpaper-soft);display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-display);font-style:italic;font-size:13px;line-height:1}

.conf-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:48px}
.conf-meta .num{font-family:var(--font-ui);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--cgold);margin-bottom:10px;display:block}
.conf-meta .val{font-family:var(--font-display);font-size:26px;color:var(--cink);line-height:1.1}
.conf-meta .val em{font-style:italic;color:var(--cgold)}
.conf-meta .sub{font-size:13px;color:var(--cink3);margin-top:6px;font-style:italic}

.conf-why{display:grid;grid-template-columns:5fr 6fr;gap:64px;align-items:center;margin-top:112px}
.conf-plate-tall{aspect-ratio:4/5}
.conf-why-prose h3{font-size:clamp(28px,3.4vw,40px);line-height:1.08;margin-bottom:20px;max-width:440px}
.conf-why-prose h3 em{color:var(--cgold);font-style:italic}
.conf-why-prose p{font-size:16px;line-height:1.7;color:var(--cink2);max-width:460px;margin-bottom:0}
.conf-stats{display:flex;gap:56px;margin-top:36px}
.cstat .big{font-family:var(--font-display);font-size:48px;line-height:.95;color:var(--cink);font-weight:300}
.cstat .big em{font-style:italic;color:var(--cgold)}
.cstat .lbl{font-family:var(--font-ui);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cink3);margin-top:10px;display:block}

.conf-block{margin-top:112px}
.conf-block>h3{font-size:clamp(28px,3.4vw,40px);line-height:1.05;margin-bottom:40px;font-weight:300}
.conf-agenda{display:grid;grid-template-columns:repeat(3,1fr);gap:36px 40px}
.ag{border-top:1px solid var(--crule);padding-top:20px}
.ag .t{font-family:var(--font-ui);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cgold);display:block;margin-bottom:10px}
.ag h5{font-size:20px;line-height:1.25;margin-bottom:8px}
.ag p{font-size:14px;line-height:1.6;color:var(--cink3);margin:0}
.conf-topics{display:flex;flex-wrap:wrap;gap:10px;margin-top:44px}
.conf-topics span{font-family:var(--font-ui);font-size:12px;letter-spacing:.04em;color:var(--cink2);border:1px solid var(--crule);padding:8px 16px;border-radius:999px}

.conf-plate-venue{aspect-ratio:21/9;margin-top:112px}
.conf-plate-venue::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,21,0) 40%,rgba(28,25,21,.7))}
.venue-cap{position:absolute;left:32px;right:32px;bottom:32px;z-index:2;color:var(--cpaper-soft);display:grid;grid-template-columns:1fr auto;align-items:end;gap:24px}
.venue-cap .jp{font-family:var(--font-display);font-style:italic;font-size:32px;color:var(--cgold-soft);line-height:1}
.venue-cap .en{font-family:var(--font-display);font-size:32px;color:var(--cpaper-soft);line-height:1;margin-top:6px}
.venue-cap .coords{font-family:var(--font-ui);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,242,232,.72);text-align:right;line-height:1.7}

.conf-faculty{display:grid;grid-template-columns:repeat(3,1fr);gap:56px 48px}
.fac{margin:0}
.fac-portrait{aspect-ratio:4/5;background:var(--cpaper-soft);overflow:hidden;margin-bottom:20px}
.fac-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:saturate(.88) contrast(1.03)}
.fac h4{font-size:20px;line-height:1.25;margin-bottom:6px}
.fac-role{font-family:var(--font-ui);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cgold);display:block;margin-bottom:12px}
.fac-bio{font-size:14px;line-height:1.6;color:var(--cink3);margin:0}

.conf-invite{text-align:center;max-width:760px;margin:112px auto 0}
.conf-invite .mark{font-family:var(--font-display);font-style:italic;font-size:92px;color:var(--cgold);line-height:.4;font-weight:300;margin-bottom:26px}
.conf-invite blockquote{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(26px,3.2vw,34px);line-height:1.3;color:var(--cink);margin:0 auto 24px;max-width:640px}
.conf-invite cite{display:block;font-family:var(--font-ui);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cink4);font-style:normal;margin-bottom:36px}

@media(max-width:920px){
  .princ-list{grid-template-columns:1fr}
  .princ:nth-child(odd){border-right:none}
  .princ:nth-child(even){padding-left:0}
  .princ{padding-right:0}
  .conf-why{grid-template-columns:1fr;gap:36px}
  .conf-plate-tall{aspect-ratio:3/2}
  .conf-agenda{grid-template-columns:1fr 1fr}
  .conf-faculty{grid-template-columns:1fr 1fr;gap:40px 28px}
  .conf-meta{gap:28px}
}
@media(max-width:680px){
  .ngm-gallery{grid-template-columns:1fr}
  .confsec{padding:72px 0}
  .confwrap{padding:0 24px}
  .conf-head h2{font-size:clamp(40px,12vw,60px)}
  .conf-lede{font-size:20px}
  .conf-plate-hero,.conf-plate-venue{aspect-ratio:4/3}
  .conf-meta{grid-template-columns:1fr;gap:22px}
  .conf-agenda{grid-template-columns:1fr}
  .conf-faculty{grid-template-columns:1fr 1fr;gap:30px 18px}
  .conf-why,.conf-block,.conf-plate-venue,.conf-invite{margin-top:72px}
  .conf-stats{gap:36px}
  .conf-dateline{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:36px}
  .venue-cap{left:18px;right:18px;bottom:18px;grid-template-columns:1fr;gap:10px}
  .venue-cap .coords{text-align:left}
  .conf-plate-hero .plate-seal{width:52px;height:52px;font-size:11px}
}

/* ============================================================ NGM PLATFORM SHOWCASES */
.showcases{display:flex;flex-direction:column;gap:104px;margin:24px 0 0}
.sc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:56px;margin-bottom:44px;flex-wrap:wrap}
.sc-title{min-width:0}
.sc-title .role{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);margin-bottom:14px;display:flex;align-items:baseline;gap:9px}
.sc-title .role .rn{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.06em;color:var(--accent);text-transform:none}
.sc-title h3{font-size:2rem;line-height:1.1}
.sc-desc{font-family:var(--font-body);font-size:15.5px;line-height:1.7;color:var(--ink-3);max-width:440px;margin:0;padding-bottom:6px}

/* ---------- conveyor belts: screenshots flow horizontally, continuously ---------- */
.belt{
  position:relative;width:100vw;margin-left:calc(50% - 50vw);overflow:hidden;padding:10px 0;
  -webkit-mask:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
          mask:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.belt-track{display:flex;gap:30px;width:max-content;will-change:transform;animation:beltL 60s linear infinite}
.belt.belt-rev .belt-track{animation-name:beltR}
.belt-card{
  flex:0 0 auto;height:400px;background:var(--paper);
  border:1px solid var(--rule-light);border-radius:8px;
  box-shadow:0 18px 48px rgba(0,0,0,.11),0 2px 5px rgba(0,0,0,.04);
  padding:18px;overflow:hidden;display:flex;
}
.belt-card img{height:100%;width:auto;display:block;object-fit:contain;border-radius:3px}
@keyframes beltL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes beltR{from{transform:translateX(-50%)}to{transform:translateX(0)}}

@media(max-width:760px){
  .sc-head{gap:14px}
  .sc-title h3{font-size:1.6rem}
  .belt-card{height:300px;padding:14px}
  .belt-track{gap:20px}
}
@media (prefers-reduced-motion: reduce){
  .belt-track{animation:none}
  .belt{overflow-x:auto;-webkit-overflow-scrolling:touch}
}
html.motion-off .belt-track{animation:none}
html.motion-off .belt{overflow-x:auto}

/* ============================================================ CONF PROGRAM (trimmed) */
.conf-agenda-2{grid-template-columns:repeat(2,1fr);max-width:840px;gap:40px 56px}
.conf-program-link{margin-top:38px;color:var(--cink);border-color:var(--crule)}
.conf-program-link:hover{color:var(--cgold);border-color:var(--cgold)}

/* ============================================================ SPEAKING PHOTOS */
.spk-head{max-width:720px;margin-bottom:8px}
.spk-head h2{margin-bottom:16px}
.spk-head .lead{margin:0}
.spk-photos{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:repeat(2,1fr);gap:20px;margin-top:48px;height:560px}
.spk-slot{width:100%;height:100%;margin:0;border:1px solid var(--rule-light);border-radius:3px;overflow:hidden;background:var(--paper);box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.06))}
.spk-slot img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.9) contrast(1.02)}
.spk-slot-lg{grid-row:1 / span 2}

@media(max-width:920px){
  .conf-agenda-2{grid-template-columns:1fr;gap:32px}
  .spk-photos{grid-template-columns:1fr;grid-template-rows:none;height:auto}
  .spk-slot{height:300px}
  .spk-slot-lg{grid-row:auto;height:380px}
}

/* ============================================================
   MOTION LAYER — scroll reveals, image wipes, parallax
   All hidden states are gated behind html.reveal-on, which is
   only set when motion is enabled AND prefers-reduced-motion
   is not requested. Without it, every element renders normally.
   ============================================================ */

/* fade + rise */
.reveal-on .reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1);
  transition-delay:calc(var(--ri,0) * 85ms);
}
.reveal-on .reveal.in{opacity:1;transform:none}

/* image curtain wipe (top-down) + a slow settle on the picture */
.reveal-on .reveal-img{
  clip-path:inset(0 0 101% 0);
  transition:clip-path 1.05s cubic-bezier(.22,.61,.36,1);
  transition-delay:calc(var(--ri,0) * 85ms);
}
.reveal-on .reveal-img.in{clip-path:inset(0 0 0 0)}
.reveal-on .reveal-zoom img{transform:scale(1.07);transition:transform 1.5s cubic-bezier(.22,.61,.36,1)}
.reveal-on .reveal-zoom.in img{transform:scale(1)}

/* the editorial hairline that draws itself in */
.reveal-on .eyebrow-rule::after{transform:scaleX(0);transform-origin:left center;transition:transform .95s cubic-bezier(.22,.61,.36,1) .15s}
.reveal-on .eyebrow-rule.in::after{transform:scaleX(1)}

/* principle marks sketch themselves on entry */
.reveal-on .princ .princ-mark line,
.reveal-on .princ .princ-mark path,
.reveal-on .princ .princ-mark polyline,
.reveal-on .princ .princ-mark rect{
  stroke-dasharray:240;stroke-dashoffset:240;
  transition:stroke-dashoffset 1.1s cubic-bezier(.33,.1,.25,1) calc(.2s + var(--ri,0) * 85ms);
}
.reveal-on .princ.in .princ-mark line,
.reveal-on .princ.in .princ-mark path,
.reveal-on .princ.in .princ-mark polyline,
.reveal-on .princ.in .princ-mark rect{stroke-dashoffset:0}
.reveal-on .princ .princ-mark circle{opacity:0;transition:opacity .6s ease calc(.7s + var(--ri,0) * 85ms)}
.reveal-on .princ.in .princ-mark circle{opacity:1}

/* parallax headroom — these images are over-scaled so a small drift never exposes an edge */
[data-parallax]{will-change:transform;transform:scale(1.12)}

/* feature-image parallax headroom retained above */

