/* ============================================================
   DAILY MEDIA GROUP — Landing
   Editorial dark theme, glass mockups, premium micro-motion
   ============================================================ */

:root{
  --bg: #0a0a0a;
  --bg-2: #0f0f0f;
  --bg-card: #131313;
  --bg-light: #f4f0e8;
  --bg-light-2: #ece5d6;

  --ink: #f4f0e8;
  --ink-dim: #cbc5b7;
  --ink-on-light: #0a0a0a;

  --muted: #8a857c;
  --muted-on-light: #5a554b;

  --line: rgba(244,240,232,0.10);
  --line-mid: rgba(244,240,232,0.16);
  --line-strong: rgba(244,240,232,0.28);
  --line-light: rgba(10,10,10,0.12);

  --amber: #d4a574;
  --amber-bright: #e6b988;
  --amber-soft: rgba(212,165,116,0.14);
  --signal: #ff5a3c;

  --glass-bg: rgba(244,240,232,0.045);
  --glass-bg-strong: rgba(244,240,232,0.07);
  --glass-border: rgba(244,240,232,0.12);
  --glass-hl: rgba(244,240,232,0.22);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background: var(--bg);
  color: var(--ink);
  font-family: 'Geist', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}
body.no-scroll{ overflow: hidden; }
::selection{ background: var(--amber); color: var(--bg); }

a{ color: inherit; }

/* ---------- Grain + ambient ---------- */
.grain{
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: 0.04;
  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='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.96  0 0 0 0 0.94  0 0 0 0 0.91  0 0 0 0.85 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.ambient{ position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.orb{ position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.55; }
.orb-1{ width: 720px; height: 720px; top: -260px; right: -240px; background: radial-gradient(circle, rgba(212,165,116,0.18), transparent 70%); animation: drift1 22s ease-in-out infinite; }
.orb-2{ width: 600px; height: 600px; bottom: -200px; left: -200px; background: radial-gradient(circle, rgba(212,165,116,0.10), transparent 70%); animation: drift2 28s ease-in-out infinite; }
@keyframes drift1{ 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(-40px, 30px); } }
@keyframes drift2{ 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(50px, -40px); } }

.wrap{ max-width: 1380px; margin: 0 auto; padding: 0 40px; position: relative; }
@media (max-width: 640px){ .wrap{ padding: 0 22px; } }

section{ position: relative; z-index: 1; }

/* ============================================================
   NAV
   ============================================================ */
nav.top{
  position: sticky; top: 0;
  z-index: 50;
  background: rgba(10,10,10,0.5);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border-bottom: 1px solid var(--line);
  transition: background 0.4s, border-color 0.4s, padding 0.4s;
}
nav.top.scrolled{ background: rgba(10,10,10,0.72); border-bottom-color: var(--line-mid); }
.nav-row{
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 40px;
  max-width: 1440px; margin: 0 auto;
  gap: 24px;
}
@media (max-width: 640px){ .nav-row{ padding: 14px 22px; } }

.brand{
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--ink);
  transition: transform 0.5s cubic-bezier(.2,1,.3,1);
}
.brand .mark{
  width: 36px; height: 36px;
  border: 1px solid var(--line-mid);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--ink);
  background: rgba(244,240,232,0.02);
  transition: border-color 0.3s, background 0.3s;
}
.brand:hover .mark{ border-color: var(--amber); background: var(--amber-soft); color: var(--amber); }
.brand-name{ font-family: 'Geist'; font-weight: 500; font-size: 14.5px; letter-spacing: -0.005em; }

.nav-links{
  display: flex; gap: 28px;
  font-family: 'Geist Mono', monospace;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.nav-links a{
  color: var(--muted); text-decoration: none;
  transition: color 0.25s;
  position: relative;
}
.nav-links a::after{
  content: ''; position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 1px; background: var(--amber);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.35s cubic-bezier(.2,1,.3,1);
}
.nav-links a:hover{ color: var(--ink); }
.nav-links a:hover::after{ transform: scaleX(1); }

.nav-end{ display: flex; align-items: center; gap: 18px; }

.now-reading{
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--line-mid);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  background: rgba(244,240,232,0.02);
  backdrop-filter: blur(6px);
}
.now-reading .pulse{
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; background: var(--signal);
  box-shadow: 0 0 0 0 rgba(255,90,60,0.5);
  animation: pulse 1.8s ease-in-out infinite;
}
.now-reading .nr-num{ color: var(--ink); font-variant-numeric: tabular-nums; }
@keyframes pulse{ 0%,100%{ box-shadow: 0 0 0 0 rgba(255,90,60,0.5); opacity:1; } 50%{ box-shadow: 0 0 0 8px rgba(255,90,60,0); opacity:0.6; } }

.nav-cta{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--bg);
  background: var(--ink);
  text-decoration: none;
  padding: 11px 18px;
  border-radius: 999px;
  transition: background 0.3s, color 0.3s, transform 0.5s cubic-bezier(.2,1,.3,1);
}
.nav-cta:hover{ background: var(--amber); color: var(--bg); }

.menu-toggle{
  display: none;
  background: transparent;
  border: 1px solid var(--line-mid);
  border-radius: 50%;
  width: 38px; height: 38px;
  cursor: pointer;
  position: relative;
  padding: 0;
}
.menu-toggle .bar{
  position: absolute; left: 10px; right: 10px;
  height: 1px; background: var(--ink);
  transition: transform 0.3s, opacity 0.3s;
}
.menu-toggle .bar:nth-child(1){ top: 13px; }
.menu-toggle .bar:nth-child(2){ top: 19px; }
.menu-toggle .bar:nth-child(3){ top: 25px; }
body.menu-open .menu-toggle .bar:nth-child(1){ transform: translateY(6px) rotate(45deg); }
body.menu-open .menu-toggle .bar:nth-child(2){ opacity: 0; }
body.menu-open .menu-toggle .bar:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 1180px){
  .nav-links{ display: none; }
  .now-reading{ display: none; }
}
@media (max-width: 880px){
  .nav-cta{ display: none; }
  .menu-toggle{ display: block; }
}

.mobile-menu{
  position: fixed; inset: 0;
  background: rgba(10,10,10,0.96);
  backdrop-filter: blur(24px);
  z-index: 49;
  overflow-y: auto;
  transform: translateY(-100%);
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  display: flex; flex-direction: column;
  padding: 100px 28px 40px;
}
body.menu-open .mobile-menu{ transform: translateY(0); }
.mobile-menu a{
  color: var(--ink); text-decoration: none;
  font-family: 'Instrument Serif', serif;
  font-size: 38px; line-height: 1.4;
  border-bottom: 1px solid var(--line);
  padding: 12px 0; display: block;
  transition: color 0.2s, padding-left 0.3s;
}
.mobile-menu a:hover{ color: var(--amber); padding-left: 8px; }
.mobile-menu .mobile-cta{
  margin-top: 36px;
  padding: 18px 24px;
  background: var(--ink); color: var(--bg);
  text-align: center;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  border-bottom: none;
  border-radius: 999px;
}
.menu-foot{
  margin-top: auto;
  padding-top: 32px;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding: 64px 0 70px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.hero::before{
  content: ''; position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 500px at 78% 30%, rgba(212,165,116,0.08), transparent 70%),
    radial-gradient(600px 400px at 12% 80%, rgba(212,165,116,0.05), transparent 70%);
  pointer-events: none;
}
.hero .wrap{ position: relative; z-index: 1; }

.hero-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 56px;
  align-items: center;
  min-height: 0;
  padding-top: 40px;
}
.hero-left{ min-width: 0; }
@media (max-width: 1080px){
  .hero-grid{ grid-template-columns: 1fr; gap: 48px; min-height: 0; }
}

/* Hero editorial image (right column) */
.hero-figure{ margin: 0; min-width: 0; }
.hero-figure-inner{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: 0 40px 90px -45px rgba(0,0,0,0.85), 0 1px 0 rgba(244,240,232,0.08) inset;
  aspect-ratio: 5 / 6;
  background: var(--bg-2);
}
.hero-figure-inner img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(1.02) contrast(1.02);
  transition: transform 1.2s cubic-bezier(.2,1,.3,1);
}
.hero-figure:hover .hero-figure-inner img{ transform: scale(1.04); }
.hero-figure-grad{
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 80% at 50% 0%, transparent 40%, rgba(10,10,10,0.15) 100%),
    linear-gradient(180deg, rgba(10,10,10,0.10) 0%, transparent 30%, rgba(10,10,10,0.55) 100%);
}
.hero-fig-cap{
  position: absolute;
  left: 18px; bottom: 18px; right: 18px;
  display: flex; align-items: center; gap: 9px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(10,10,10,0.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-dim);
  width: fit-content;
}
.hero-fig-cap em{ font-style: normal; color: var(--amber); }
.hf-dot{
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 0 0 rgba(212,165,116,0.5);
  animation: pulseDot 2.4s ease-out infinite;
  flex: 0 0 auto;
}
@keyframes pulseDot{
  0%, 100%{ box-shadow: 0 0 0 0 rgba(212,165,116,0.5); opacity: 1; }
  50%{ box-shadow: 0 0 0 7px rgba(212,165,116,0); opacity: 0.7; }
}
@media (max-width: 1080px){
  .hero-figure-inner{ aspect-ratio: 16 / 10; }
}

.hero-meta-top{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 14px;
  border: 1px solid var(--line-mid);
  border-radius: 999px;
  background: rgba(244,240,232,0.03);
  backdrop-filter: blur(6px);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 32px;
}
.hero-meta-top .amber{ color: var(--amber); }
.hero-meta-top .sep{ opacity: 0.5; }
.live-dot{
  display: inline-block; width: 7px; height: 7px;
  border-radius: 50%; background: var(--signal);
  animation: blink 1.6s ease-in-out infinite;
}
@keyframes blink{
  0%, 100%{ opacity: 1; box-shadow: 0 0 0 0 rgba(255,90,60,0.55); }
  50%{ opacity: 0.6; box-shadow: 0 0 0 6px rgba(255,90,60,0); }
}

.hero h1{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(40px, 5.2vw, 78px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.hero h1 .it{ font-style: italic; color: var(--amber); }
.hero h1 .block{ display: block; }

.hero-lede{
  margin-top: 36px;
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink-dim);
  max-width: 520px;
}
.hero-lede strong{ color: var(--ink); font-weight: 500; }

.hero-ctas{
  margin-top: 40px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.btn{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.35s cubic-bezier(.2,1,.3,1);
  border: 1px solid transparent;
}
.btn svg{ transition: transform 0.35s cubic-bezier(.2,1,.3,1); }
.btn:hover svg{ transform: translateX(4px); }
.btn-primary{
  background: var(--ink); color: var(--bg);
}
.btn-primary:hover{ background: var(--amber); }
.btn-ghost{
  background: rgba(244,240,232,0.04);
  color: var(--ink);
  border-color: var(--line-mid);
  backdrop-filter: blur(8px);
}
.btn-ghost:hover{ background: rgba(244,240,232,0.08); border-color: var(--line-strong); }

.hero-foot{
  margin-top: 60px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  max-width: 540px;
}
.hf-cell{ display: flex; flex-direction: column; gap: 6px; }
.hf-k{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.hf-v{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.hf-v .it{ font-style: italic; color: var(--amber); }

/* ---- Hero visual: floating glass newsletter stack ---- */
.hero-visual{
  position: relative;
  height: 620px;
  perspective: 1400px;
}
@media (max-width: 1080px){
  .hero-visual{ height: 460px; }
}
@media (max-width: 640px){
  .hero-visual{ height: 380px; }
}

.hv-stage{
  position: absolute; inset: 0;
  transform-style: preserve-3d;
}

.hv-glow{
  position: absolute;
  width: 480px; height: 480px;
  border-radius: 50%;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(212,165,116,0.16), transparent 65%);
  filter: blur(20px);
}

.hv-card{
  position: absolute;
  border-radius: 18px;
  background: rgba(244,240,232,0.04);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  border: 1px solid var(--glass-border);
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.6),
    0 0 0 1px rgba(244,240,232,0.03) inset,
    0 1px 0 rgba(244,240,232,0.08) inset;
  padding: 22px 24px;
  width: 360px;
  transition: transform 0.6s cubic-bezier(.2,1,.3,1);
  will-change: transform;
}

.hv-c1{
  top: 8%; right: 8%;
  transform: rotate(4deg);
  animation: float1 9s ease-in-out infinite;
}
.hv-c2{
  top: 28%; right: 2%;
  width: 400px;
  background: rgba(244,240,232,0.06);
  z-index: 2;
  animation: float2 11s ease-in-out infinite;
}
.hv-c3{
  bottom: 6%; right: 14%;
  transform: rotate(-3deg);
  animation: float3 10s ease-in-out infinite;
}

@keyframes float1{ 0%,100%{ transform: translate(0,0) rotate(4deg); } 50%{ transform: translate(-4px,-12px) rotate(4.5deg); } }
@keyframes float2{ 0%,100%{ transform: translate(0,0) rotate(0deg); } 50%{ transform: translate(6px,-8px) rotate(-0.5deg); } }
@keyframes float3{ 0%,100%{ transform: translate(0,0) rotate(-3deg); } 50%{ transform: translate(-6px,10px) rotate(-3.5deg); } }

.hv-bar{
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 14px;
}
.hv-dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--amber); }
.hv-meta{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  flex: 1;
}
.hv-tag{
  font-family: 'Geist Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  padding: 3px 7px;
  border: 1px solid var(--line-mid);
  color: var(--ink-dim);
  border-radius: 4px;
}
.hv-tag.tag-amber{ color: var(--amber); border-color: rgba(212,165,116,0.4); background: var(--amber-soft); }

.hv-sub{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 14px;
}
.hv-c2 .hv-sub{ font-size: 26px; }

.hv-lines{ display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.ln{ height: 6px; border-radius: 3px; background: rgba(244,240,232,0.10); }
.ln.w90{ width: 90%; }.ln.w95{ width: 95%; }.ln.w85{ width: 85%; }.ln.w80{ width: 80%; }.ln.w70{ width: 70%; }.ln.w65{ width: 65%; }.ln.w60{ width: 60%; }.ln.w50{ width: 50%; }.ln.w40{ width: 40%; }

.hv-foot{
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.hv-foot .dot{ width: 3px; height: 3px; border-radius: 50%; background: var(--amber); display: inline-block; }

.hv-chart{ margin: 4px 0 4px; opacity: 0.95; }

.hv-quote{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink-dim);
  border-left: 1px solid var(--amber);
  padding-left: 12px;
  margin-top: 8px;
}

.hv-chip{
  position: absolute;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(244,240,232,0.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--glass-border);
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.5);
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 8px;
  z-index: 3;
  transform: translate(var(--px, 0), var(--py, 0));
  transition: transform 0.4s cubic-bezier(.2,1,.3,1);
}
.hv-chip .chip-dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--signal); animation: blink 1.6s ease-in-out infinite; }
.chip-1{ top: 14%; left: 4%; }
.chip-2{ bottom: 18%; left: -2%; color: var(--amber); }
.chip-2 svg{ color: var(--amber); }

@media (max-width: 1080px){
  .hv-c1{ width: 300px; }
  .hv-c2{ width: 340px; }
  .hv-c3{ width: 300px; bottom: 8%; }
}
@media (max-width: 640px){
  .hv-c1, .hv-c2, .hv-c3{ width: 78%; }
  .hv-c1{ top: 0; right: 4%; }
  .hv-c2{ top: 22%; right: 0; }
  .hv-c3{ bottom: 0; right: 8%; }
  .chip-1, .chip-2{ display: none; }
}

/* Brand marquee */
.brand-marquee{
  grid-column: 1 / -1;
  margin-top: 80px;
  padding: 28px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 32px;
  overflow: hidden;
}
.bm-label{
  flex-shrink: 0;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  padding-right: 32px;
  border-right: 1px solid var(--line);
}
.bm-track{
  flex: 1;
  overflow: hidden;
  position: relative;
}
.bm-track::before,
.bm-track::after{
  content: ''; position: absolute; top: 0; bottom: 0;
  width: 80px; z-index: 2;
  pointer-events: none;
}
.bm-track::before{ left: 0; background: linear-gradient(to right, var(--bg), transparent); }
.bm-track::after{ right: 0; background: linear-gradient(to left, var(--bg), transparent); }

.bm-inner{
  display: inline-flex; align-items: center; gap: 28px;
  font-family: 'Instrument Serif', serif;
  font-size: 28px;
  line-height: 1;
  color: var(--ink);
  white-space: nowrap;
  animation: marquee 50s linear infinite;
  letter-spacing: -0.01em;
}
.bm-inner span{ display: inline-block; }
.bm-inner em{ font-style: italic; color: var(--amber); }
.bm-inner i{
  font-family: 'Geist Mono', monospace;
  font-style: normal;
  font-size: 14px;
  color: var(--muted);
}
@keyframes marquee{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }

@media (max-width: 640px){
  .brand-marquee{ flex-direction: column; align-items: flex-start; gap: 16px; }
  .bm-label{ padding-right: 0; border-right: none; padding-bottom: 0; }
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.section-head{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 60px;
  margin-bottom: 60px;
  align-items: baseline;
}
.section-head .label{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 8px;
}
.section-head .label .num{ color: var(--amber); }
.section-head h2{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(30px, 3.6vw, 52px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.section-head h2 .it{ font-style: italic; color: var(--amber); }
@media (max-width: 820px){
  .section-head{ grid-template-columns: 1fr; gap: 20px; margin-bottom: 60px; }
}

/* ============================================================
   THESIS
   ============================================================ */
.thesis{
  padding: 110px 0 100px;
  border-bottom: 1px solid var(--line);
}
.thesis-points{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 60px;
}
.thesis-aside{
  position: sticky;
  top: 120px;
  align-self: start;
  padding: 24px;
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
}
.ta-line{ width: 28px; height: 1px; background: var(--amber); margin-bottom: 14px; }
.ta-title{
  font-family: 'Instrument Serif', serif;
  font-size: 19px;
  line-height: 1.35;
  color: var(--ink);
  letter-spacing: -0.005em;
  margin-bottom: 18px;
}
.ta-meta{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.thesis-list{ display: flex; flex-direction: column; }
.thesis-item{
  padding: 36px 0;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 32px;
  align-items: start;
  transition: padding-left 0.4s cubic-bezier(.2,1,.3,1);
}
.thesis-item:last-child{ border-bottom: 1px solid var(--line); }
.thesis-item:hover{ padding-left: 12px; }
.thesis-item:hover h4{ color: var(--amber); }
.thesis-item .n{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--amber);
  padding-top: 10px;
  letter-spacing: 0.06em;
}
.thesis-item h4{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin-bottom: 14px;
  color: var(--ink);
  transition: color 0.3s;
}
.thesis-item p{
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--muted);
  max-width: 620px;
}
@media (max-width: 820px){
  .thesis-points{ grid-template-columns: 1fr; gap: 32px; }
  .thesis-aside{ position: static; }
  .thesis-item{ grid-template-columns: 40px 1fr; gap: 16px; }
}

/* ============================================================
   BRANDS / CATEGORIES
   ============================================================ */
.brands{
  padding: 110px 0;
  border-bottom: 1px solid var(--line);
}
.cat-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
@media (max-width: 980px){
  .cat-grid{ grid-template-columns: 1fr; }
}

.cat{
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  background: var(--bg-2);
  transition: border-color 0.4s, transform 0.5s cubic-bezier(.2,1,.3,1);
  display: flex; flex-direction: column;
}
.cat:hover{ border-color: var(--line-strong); transform: translateY(-4px); }
.cat:hover .cat-name{ color: var(--amber); }
.cat:hover .cm-glass{ transform: translateY(-6px) scale(1.01); }

.cat-mock{
  position: relative;
  height: 280px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.cm-bg{ position: absolute; inset: 0; }
.cm-bg-health{
  background:
    radial-gradient(800px 400px at 30% 30%, rgba(212,165,116,0.25), transparent 60%),
    linear-gradient(135deg, #2a1f12 0%, #1a1208 60%, #0a0a0a 100%);
}
.cm-bg-mind{
  background:
    radial-gradient(600px 400px at 70% 40%, rgba(140,158,180,0.22), transparent 60%),
    linear-gradient(135deg, #1a2030 0%, #0f141d 60%, #0a0a0a 100%);
}
.cm-bg-work{
  background:
    radial-gradient(700px 400px at 50% 60%, rgba(244,240,232,0.10), transparent 60%),
    linear-gradient(135deg, #1d1d1a 0%, #131311 60%, #0a0a0a 100%);
}
.cm-bg-meaning{
  background:
    radial-gradient(700px 400px at 50% 50%, rgba(180,158,120,0.20), transparent 60%),
    linear-gradient(155deg, #221c14 0%, #14110b 60%, #0a0a0a 100%);
}
.cm-bg::before{
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(244,240,232,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,240,232,0.04) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: 0.6;
  mask: radial-gradient(circle at 50% 50%, black 30%, transparent 80%);
  -webkit-mask: radial-gradient(circle at 50% 50%, black 30%, transparent 80%);
}

.cm-glass{
  position: absolute;
  left: 32px; right: 32px;
  top: 28px; bottom: 28px;
  border-radius: 12px;
  background: rgba(244,240,232,0.045);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border: 1px solid var(--glass-border);
  box-shadow:
    0 20px 50px -25px rgba(0,0,0,0.7),
    0 1px 0 rgba(244,240,232,0.08) inset;
  padding: 18px 20px;
  display: flex; flex-direction: column;
  transition: transform 0.6s cubic-bezier(.2,1,.3,1);
}
.cm-top{
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 12px;
}
.cm-mast{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.cm-mast em{ font-style: italic; color: var(--amber); }
.cm-stamp{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.cm-headline{
  font-family: 'Instrument Serif', serif;
  font-size: 18px;
  line-height: 1.25;
  color: var(--ink);
  margin-bottom: 12px;
  letter-spacing: -0.005em;
}
.cm-chart{ flex: 1; min-height: 0; display: flex; align-items: flex-end; }
.cm-foot{
  margin-top: 10px;
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.cm-foot .dot{ width: 3px; height: 3px; border-radius: 50%; background: var(--amber); display: inline-block; }

/* Mind: pills + quote */
.cm-pill-row{ display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.cm-pill{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid var(--line-mid);
  color: var(--ink-dim);
}
.cm-quote{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 13px;
  line-height: 1.45;
  color: var(--ink-dim);
  border-left: 1px solid var(--amber);
  padding-left: 10px;
  margin-bottom: auto;
}

/* Work: data table */
.cm-table{ display: flex; flex-direction: column; gap: 7px; margin-bottom: auto; }
.cmt-row{
  display: grid;
  grid-template-columns: 70px 1fr 40px;
  gap: 10px;
  align-items: center;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-dim);
}
.cmt-bar{
  height: 4px; border-radius: 2px;
  background: rgba(244,240,232,0.08);
  position: relative; overflow: hidden;
}
.cmt-bar i{
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--amber);
  border-radius: 2px;
  transform-origin: left;
  animation: barIn 1.4s cubic-bezier(.2,1,.3,1) both;
}
@keyframes barIn{ from{ transform: scaleX(0); } to{ transform: scaleX(1); } }
.cmt-row span:last-child{ color: var(--amber); text-align: right; }

/* Meaning: letter lines */
.cm-lines{ display: flex; flex-direction: column; gap: 6px; margin-bottom: auto; }
.cm-ln{ height: 5px; border-radius: 2px; background: rgba(244,240,232,0.10); }
.cm-ln.w90{ width: 90%; }.cm-ln.w95{ width: 95%; }.cm-ln.w85{ width: 85%; }.cm-ln.w70{ width: 70%; }.cm-ln.w60{ width: 60%; }
.cm-sig{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 12px;
  color: var(--amber);
  margin-bottom: 10px;
}

.cat-body{
  padding: 36px 36px 36px;
  display: flex; flex-direction: column;
  flex: 1;
}
.cat-head{
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.cat-num{ font-family: 'Geist Mono', monospace; font-size: 10.5px; color: var(--amber); letter-spacing: 0.1em; }
.cat-tag{ font-family: 'Geist Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.cat-name{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(26px, 2.6vw, 38px);
  line-height: 1.02;
  letter-spacing: -0.022em;
  margin-bottom: 18px;
  color: var(--ink);
  transition: color 0.3s;
}
.cat-name .it{ font-style: italic; }
.cat-desc{
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
  margin-bottom: 24px;
}
.cat-foot{
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  flex-wrap: wrap;
}
.cat-foot .focus-item{ color: var(--ink); }
.cat-foot .dot{ width: 3px; height: 3px; border-radius: 50%; background: var(--amber); display: inline-block; }

@media (max-width: 640px){
  .cat-body{ padding: 28px 24px; }
  .cm-glass{ left: 18px; right: 18px; top: 18px; bottom: 18px; }
}

/* ============================================================
   FORMATS
   ============================================================ */
.formats{
  padding: 110px 0;
  border-bottom: 1px solid var(--line);
}
.fmt-tabs{
  display: flex;
  gap: 0;
  padding: 6px;
  border: 1px solid var(--line-mid);
  border-radius: 999px;
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  width: fit-content;
  margin-bottom: 48px;
}
.fmt-tab{
  appearance: none;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 12px 22px;
  border-radius: 999px;
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--muted);
  transition: color 0.3s, background 0.3s;
  font-family: 'Geist Mono', monospace;
}
.fmt-tab .tab-num{ font-size: 10px; letter-spacing: 0.08em; opacity: 0.7; }
.fmt-tab .tab-name{
  font-family: 'Instrument Serif', serif;
  font-size: 18px;
  text-transform: none;
  letter-spacing: -0.005em;
}
.fmt-tab .tab-status{
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 3px 8px;
  border: 1px solid var(--line-mid);
  border-radius: 999px;
  color: var(--muted);
}
.fmt-tab:hover{ color: var(--ink); }
.fmt-tab.is-active{
  background: var(--ink);
  color: var(--bg);
}
.fmt-tab.is-active .tab-status{
  border-color: rgba(10,10,10,0.2);
  color: rgba(10,10,10,0.65);
}
@media (max-width: 760px){
  .fmt-tabs{ flex-direction: column; width: 100%; border-radius: 14px; }
  .fmt-tab{ justify-content: flex-start; }
}

.fmt-stage{
  position: relative;
}
.fmt-panel{
  display: none;
}
.fmt-panel.is-active{
  display: block;
  animation: panelIn 0.6s cubic-bezier(.2,1,.3,1);
}
@keyframes panelIn{ from{ opacity: 0; transform: translateY(12px); } to{ opacity: 1; transform: translateY(0); } }

.fmt-panel-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 80px;
  align-items: center;
}
@media (max-width: 1080px){
  .fmt-panel-grid{ grid-template-columns: 1fr; gap: 48px; }
}

.fmt-copy .fmt-panel-num{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--amber);
  margin-bottom: 20px;
}
.fmt-copy h3{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1;
  letter-spacing: -0.022em;
  margin-bottom: 24px;
}
.fmt-copy h3 .it{ font-style: italic; color: var(--amber); }
.fmt-copy p{
  font-size: 17px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 480px;
  margin-bottom: 40px;
}
.fmt-copy p strong{ color: var(--ink); font-weight: 500; }

.fmt-stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.fs-cell{ display: flex; flex-direction: column; gap: 6px; }
.fs-k{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.fs-v{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.fs-v .it{ font-style: italic; color: var(--amber); }

/* --- Inbox visual --- */
.fmt-visual{
  position: relative;
}
.inbox{
  border-radius: 18px;
  background: rgba(244,240,232,0.045);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  border: 1px solid var(--glass-border);
  box-shadow:
    0 40px 80px -40px rgba(0,0,0,0.7),
    0 1px 0 rgba(244,240,232,0.08) inset;
  overflow: hidden;
}
.inbox-head{
  display: flex; align-items: center; gap: 16px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(10,10,10,0.3);
}
.ih-dots{ display: flex; gap: 6px; }
.ih-dots span{
  width: 9px; height: 9px; border-radius: 50%;
  background: rgba(244,240,232,0.18);
}
.ih-search{
  flex: 1;
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border-radius: 6px;
  background: rgba(244,240,232,0.06);
  color: var(--muted);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
}
.ih-count{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--amber);
}

.inbox-list{ display: flex; flex-direction: column; }
.ix{
  display: grid;
  grid-template-columns: 200px 1fr 60px;
  gap: 18px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  align-items: center;
  transition: background 0.3s, padding-left 0.4s;
  cursor: pointer;
}
.ix:last-child{ border-bottom: none; }
.ix:hover{ background: rgba(244,240,232,0.03); padding-left: 24px; }
.ix-sender{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  display: flex; align-items: center; gap: 8px;
}
.ix.is-unread .ix-sender{ color: var(--ink); }
.ix-tag{
  font-size: 9px;
  letter-spacing: 0.14em;
  padding: 2px 6px;
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  color: var(--muted);
}
.ix.is-unread .ix-tag{ color: var(--amber); border-color: rgba(212,165,116,0.4); }
.ix-subj{
  font-family: 'Instrument Serif', serif;
  font-size: 16px;
  line-height: 1.3;
  color: var(--ink-dim);
  letter-spacing: -0.005em;
}
.ix.is-unread .ix-subj{ color: var(--ink); }
.ix-time{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  text-align: right;
}
.ix.is-now{
  position: relative;
}
.ix.is-now::before{
  content: ''; position: absolute;
  left: 0; top: 0; bottom: 0; width: 2px;
  background: var(--amber);
}
@media (max-width: 720px){
  .ix{ grid-template-columns: 1fr; gap: 4px; }
  .ix-time{ text-align: left; }
}

/* --- Shop visual --- */
.shop{
  border-radius: 18px;
  background: rgba(244,240,232,0.045);
  backdrop-filter: blur(20px) saturate(1.5);
  -webkit-backdrop-filter: blur(20px) saturate(1.5);
  border: 1px solid var(--glass-border);
  box-shadow: 0 40px 80px -40px rgba(0,0,0,0.7), 0 1px 0 rgba(244,240,232,0.08) inset;
  padding: 24px;
}
.shop-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
.prod{
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: rgba(10,10,10,0.4);
  transition: transform 0.4s cubic-bezier(.2,1,.3,1), border-color 0.3s;
  cursor: pointer;
}
.prod:hover{ transform: translateY(-4px); border-color: var(--line-strong); }
.prod-img{
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.prod-meta{
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 4px;
}
.prod-name{
  font-family: 'Instrument Serif', serif;
  font-size: 15px;
  line-height: 1.25;
  color: var(--ink);
}
.prod-price{
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  color: var(--amber);
}
.shop-foot{
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.shop-cta{ color: var(--amber); cursor: pointer; }

/* --- Commerce: shoppable categories (revision brief #4) --- */
.shop-cat-grid{
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 18px;
}
.shop-cat{
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(10,10,10,0.4);
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.4s cubic-bezier(.2,1,.3,1), border-color 0.3s, background 0.3s;
}
.shop-cat:hover{
  transform: translateY(-4px);
  border-color: rgba(212,165,116,0.45);
  background: rgba(212,165,116,0.06);
}
.sc-thumb{
  display: block;
  position: relative;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.sc-thumb img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.7s cubic-bezier(.2,1,.3,1);
}
.shop-cat:hover .sc-thumb img{ transform: scale(1.07); }
.sc-meta{
  display: flex; flex-direction: column; gap: 5px;
  padding: 14px 16px 16px;
}
.sc-name{
  font-family: 'Instrument Serif', serif;
  font-size: 20px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.sc-name .it{ font-style: italic; color: var(--amber); }
.sc-desc{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  line-height: 1.5;
}
@media (prefers-reduced-motion: reduce){
  .shop-cat:hover .sc-thumb img{ transform: none; }
}
@media (max-width: 640px){
  .shop-cat-grid{ grid-template-columns: 1fr; }
}

/* --- Phones visual --- */
.phones{
  position: relative;
  height: 560px;
  display: flex; align-items: center; justify-content: center;
}
.phone{
  width: 240px;
  height: 480px;
  border-radius: 36px;
  border: 1px solid var(--glass-border);
  background: rgba(244,240,232,0.05);
  backdrop-filter: blur(20px) saturate(1.5);
  box-shadow:
    0 40px 80px -30px rgba(0,0,0,0.8),
    0 0 0 1px rgba(244,240,232,0.04) inset;
  padding: 12px;
  position: absolute;
}
.phone-back{
  transform: rotate(-6deg) translateX(-70px) translateY(8px);
  opacity: 0.92;
}
.phone-front{
  transform: rotate(4deg) translateX(60px);
  z-index: 2;
}
.phone-screen{
  width: 100%; height: 100%;
  border-radius: 26px;
  background: #0a0a0a;
  padding: 22px 18px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.phone-screen.ps-light{
  background: var(--bg-light);
  color: var(--ink-on-light);
}
.ps-status{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
  opacity: 0.7;
}
.ps-mast{
  font-family: 'Instrument Serif', serif;
  font-size: 24px;
  line-height: 1;
  margin-bottom: 16px;
}
.ps-mast em{ font-style: italic; color: var(--amber); }
.ps-light .ps-mast em{ color: #6b4d2a; }
.ps-section{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-bottom: 14px;
}
.ps-card{
  background: rgba(244,240,232,0.06);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 10px;
}
.ps-card-min{ padding: 10px 14px; }
.ps-tag{
  font-family: 'Geist Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--amber);
  margin-bottom: 8px;
}
.ps-headline{
  font-family: 'Instrument Serif', serif;
  font-size: 17px;
  line-height: 1.2;
  letter-spacing: -0.005em;
}
.ps-headline-sm{
  font-family: 'Instrument Serif', serif;
  font-size: 13.5px;
  line-height: 1.25;
}
.ps-day{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-on-light);
  margin-bottom: 18px;
}
.ps-meditation{
  flex: 1;
  display: flex; align-items: center; justify-content: center;
}
.ps-circle{
  width: 160px; height: 160px;
  position: relative;
}
.ps-circle svg{ width: 100%; height: 100%; }
.ps-circle-text{
  position: absolute;
  inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-family: 'Instrument Serif', serif;
  font-size: 28px;
  line-height: 1;
  color: var(--ink-on-light);
}
.ps-circle-text span{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--muted-on-light);
  text-transform: uppercase;
  margin-top: 4px;
}
.ps-cta{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-align: center;
  padding: 12px;
  border: 1px solid rgba(10,10,10,0.2);
  border-radius: 999px;
  color: var(--ink-on-light);
}
@media (max-width: 720px){
  .phones{ height: 440px; }
  .phone{ width: 200px; height: 400px; }
  .phone-back{ transform: rotate(-6deg) translateX(-50px); }
  .phone-front{ transform: rotate(4deg) translateX(50px); }
}

/* ============================================================
   READERSHIP
   ============================================================ */
.readership{
  padding: 110px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.readership::before{
  content:''; position: absolute;
  top: 10%; right: -10%;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(212,165,116,0.06), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.readership .wrap{ position: relative; z-index: 1; }

.reader-statement{ max-width: 1100px; margin-bottom: 64px; }
.reader-statement .label-row{
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 32px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.reader-statement .label-row::before{
  content:''; width: 36px; height: 1px; background: var(--amber);
}
.reader-statement .label-row .num{ color: var(--amber); }
.reader-statement h2{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 64px);
  line-height: 0.98;
  letter-spacing: -0.025em;
}

/* Audience pill (inspired by AI agency site's social-proof element) */
.audience-pill{
  margin-top: 32px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 8px 16px 8px 8px;
  background: var(--glass-bg);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid var(--glass-border);
  border-radius: 999px;
}
.ap-stack{ display: inline-flex; }
.ap-avatar{
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 2px solid var(--bg);
  display: inline-block;
  margin-left: -9px;
  position: relative;
  overflow: hidden;
  background: rgba(244,240,232,0.08);
  z-index: 1;
  transition: transform 0.35s cubic-bezier(.2,1,.3,1), box-shadow 0.35s, z-index 0s;
}
.ap-avatar img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.ap-avatar.a-1{ margin-left: 0; }
.ap-avatar:hover{
  transform: scale(1.3) translateY(-3px);
  z-index: 6;
  box-shadow: 0 10px 22px -8px rgba(0,0,0,0.75);
}
.ap-text{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.ap-text .ap-count{ color: var(--amber); }
.ap-text .ap-em{ color: var(--ink); }
@media (max-width: 520px){
  .audience-pill{ padding: 8px 14px 8px 8px; }
  .ap-text{ font-size: 10px; }
}
.reader-statement h2 .it{ font-style: italic; color: var(--amber); }

.reader-split{
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: 60px;
  align-items: start;
}
@media (max-width: 1080px){
  .reader-split{ grid-template-columns: 1fr; }
}

.audience-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--line);
}
.audience-cell{
  padding: 28px 20px 28px 0;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  transition: background 0.3s, padding-left 0.4s;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
}
.audience-cell:nth-child(2n){ border-right: none; padding-right: 0; }
.audience-cell:hover{ background: rgba(212,165,116,0.04); padding-left: 12px; }
.audience-cell .a-num{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  color: var(--amber);
  letter-spacing: 0.08em;
  padding-top: 6px;
}
.audience-cell .a-name{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(20px, 1.9vw, 26px);
  line-height: 1.15;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.audience-cell .a-name .it{ font-style: italic; }
.audience-cell .a-count{
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  color: var(--amber);
  letter-spacing: 0.04em;
  text-align: right;
}
@media (max-width: 520px){
  .audience-grid{ grid-template-columns: 1fr; }
  .audience-cell{ border-right: none !important; padding: 24px 0; }
}

/* Globe */
.globe-wrap{
  border-radius: 18px;
  background: var(--glass-bg);
  backdrop-filter: blur(14px);
  border: 1px solid var(--glass-border);
  padding: 24px;
  position: relative;
}
.globe-label{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 8px;
}
.globe-label::after{
  content:''; width: 6px; height: 6px;
  border-radius: 50%; background: var(--signal);
  animation: blink 1.6s ease-in-out infinite;
}
.globe{
  position: relative;
  aspect-ratio: 1;
  max-width: 380px;
  margin: 0 auto;
}
.globe svg{
  width: 100%; height: 100%;
  animation: globeSpin 80s linear infinite;
  transform-origin: center;
}
@keyframes globeSpin{ to{ transform: rotate(360deg); } }

.pulse-ring{ transform-origin: center; transform-box: fill-box; animation: ringPulse 2.4s ease-out infinite; }
.pulse-ring.p2{ animation-delay: 0.8s; }
.pulse-ring.p3{ animation-delay: 1.6s; }
@keyframes ringPulse{
  0%{ r: 3; opacity: 1; }
  100%{ r: 16; opacity: 0; }
}

.globe-meta{
  margin-top: 18px;
  border-top: 1px solid var(--line);
  padding-top: 14px;
  display: flex; flex-direction: column; gap: 8px;
}
.gm-row{
  display: grid;
  grid-template-columns: 70px 90px 1fr;
  gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--muted);
  animation: gmIn 0.6s cubic-bezier(.2,1,.3,1) both;
}
.gm-row:nth-child(2){ animation-delay: 0.12s; }
.gm-row:nth-child(3){ animation-delay: 0.24s; }
.gm-row:nth-child(4){ animation-delay: 0.36s; }
@keyframes gmIn{ from{ opacity: 0; transform: translateX(-8px); } to{ opacity: 1; transform: translateX(0); } }
.gm-time{ color: var(--amber); }
.gm-city{ color: var(--ink); text-transform: uppercase; letter-spacing: 0.1em; }
.gm-act{ opacity: 0.7; }

.reader-foot{
  margin-top: 80px;
  padding-top: 40px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.reader-foot .rf-cell{ display: flex; flex-direction: column; gap: 10px; }
.reader-foot .rf-k{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}
.reader-foot .rf-v{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(26px, 2.8vw, 38px);
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.reader-foot .rf-v .it{ font-style: italic; color: var(--amber); }
@media (max-width: 820px){
  .reader-foot{ grid-template-columns: 1fr; gap: 24px; }
}

/* ============================================================
   PLATFORM (LIGHT)
   ============================================================ */
.light-section{
  background: var(--bg-light);
  color: var(--ink-on-light);
  padding: 110px 0 120px;
  position: relative;
  overflow: hidden;
}
.light-section::before{
  content: ''; position: absolute;
  inset: 0;
  background:
    radial-gradient(600px 400px at 10% 10%, rgba(212,165,116,0.18), transparent 60%),
    radial-gradient(700px 500px at 90% 90%, rgba(212,165,116,0.10), transparent 60%);
  pointer-events: none;
}
.light-section .wrap{ position: relative; z-index: 1; }
.light-section .section-head .label{ color: var(--muted-on-light); }
.light-section .section-head .label .num{ color: var(--ink-on-light); }
.light-section .section-head h2{ color: var(--ink-on-light); }
.light-section .section-head h2 .it{ color: var(--ink-on-light); font-style: italic; }

.principle{
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 40px;
  padding: 50px 0;
  border-top: 1px solid rgba(10,10,10,0.16);
  align-items: start;
  transition: padding-left 0.4s cubic-bezier(.2,1,.3,1);
}
.principle:hover{ padding-left: 16px; }
.principle:last-child{ border-bottom: 1px solid rgba(10,10,10,0.16); }
.principle .p-num{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--muted-on-light);
  letter-spacing: 0.08em;
  padding-top: 28px;
  text-transform: uppercase;
}
.principle .p-body{
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items: start;
}
.principle .p-name{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(36px, 4.8vw, 76px);
  line-height: 0.96;
  letter-spacing: -0.03em;
}
.principle .p-name .it{ font-style: italic; }
.principle .p-desc{
  padding-top: 14px;
  font-size: 16.5px;
  line-height: 1.65;
  max-width: 440px;
}
.principle .p-desc strong{ font-weight: 500; }
@media (max-width: 1080px){
  .principle .p-body{ grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 820px){
  .principle{ grid-template-columns: 1fr; gap: 18px; padding: 50px 0; }
  .principle .p-num{ padding-top: 0; }
}

/* ============================================================
   TEAM
   ============================================================ */
.team-section{
  padding: 110px 0;
  border-bottom: 1px solid var(--line);
}
.team-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 980px){
  .team-grid{ grid-template-columns: 1fr; gap: 60px; }
}

.team-left .t-label{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.team-left .t-label .num{ color: var(--amber); }
.team-left h3{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(30px, 3.6vw, 48px);
  line-height: 1.02;
  letter-spacing: -0.022em;
  margin-top: 24px;
}
.team-left h3 .it{ font-style: italic; color: var(--amber); }
.team-left .body{
  margin-top: 32px;
  font-size: 16px;
  line-height: 1.7;
  color: var(--muted);
  max-width: 460px;
}
.team-left .body + .body{ margin-top: 16px; }

.team-stats{
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.ts{ display: flex; flex-direction: column; gap: 6px; }
.ts-v{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(32px, 3.4vw, 44px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.ts-v .it{ font-style: italic; color: var(--amber); }
.ts-k{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.disciplines{ border-top: 1px solid var(--line-strong); }
.d-label{
  padding: 16px 0;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 50px 1fr 40px;
  gap: 18px;
}
.d-label span:last-child{ text-align: right; }
.discipline{
  padding: 24px 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 50px 1fr 40px;
  gap: 18px;
  align-items: start;
  transition: background 0.3s, padding-left 0.4s;
}
.discipline:hover{ background: rgba(212,165,116,0.03); padding-left: 12px; }
.discipline:hover .name .it{ color: var(--amber); }
.discipline .num{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.05em;
  padding-top: 4px;
}
.discipline .name{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
}
.discipline .name .it{ font-style: italic; transition: color 0.3s; }
.discipline .name .sub{
  display: block;
  font-family: 'Geist', sans-serif;
  font-size: 13px;
  color: var(--muted);
  margin-top: 6px;
  line-height: 1.5;
}
.discipline .size{
  font-family: 'Geist Mono', monospace;
  font-size: 14px;
  color: var(--amber);
  text-align: right;
  padding-top: 4px;
}

/* ============================================================
   CAREERS
   ============================================================ */
.careers{
  padding: 110px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.careers::before{
  content:''; position: absolute;
  top: 30%; left: 50%;
  transform: translate(-50%, -50%);
  width: 900px; height: 900px;
  background: radial-gradient(circle, rgba(212,165,116,0.08), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.careers .wrap{ position: relative; z-index: 2; }
.careers-head{
  text-align: center;
  max-width: 1100px;
  margin: 0 auto;
}
.careers-head .label{
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  margin-bottom: 28px;
  padding: 6px 14px;
  border: 1px solid var(--line-mid);
  border-radius: 999px;
  background: rgba(244,240,232,0.03);
  backdrop-filter: blur(8px);
}
.careers-head h2{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 66px);
  line-height: 1;
  letter-spacing: -0.025em;
  text-wrap: balance;
}
.careers-head h2 .it{ font-style: italic; color: var(--amber); }
.careers-head .sub{
  margin-top: 32px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 600px;
  margin-left: auto; margin-right: auto;
}

.role-list{
  margin-top: 80px;
  max-width: 980px;
  margin-left: auto; margin-right: auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(244,240,232,0.02);
  backdrop-filter: blur(8px);
  overflow: hidden;
}
.role-head{
  display: grid;
  grid-template-columns: 1fr 200px 160px 40px;
  gap: 18px;
  padding: 16px 24px;
  border-bottom: 1px solid var(--line);
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.role{
  display: grid;
  grid-template-columns: 1fr 200px 160px 40px;
  gap: 18px;
  padding: 22px 24px;
  border-bottom: 1px solid var(--line);
  align-items: center;
  transition: padding-left 0.4s, background 0.3s;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.role:last-child{ border-bottom: none; }
.role:hover{ padding-left: 36px; background: rgba(212,165,116,0.04); }
.role:hover .role-title{ color: var(--amber); }
.role:hover .role-arrow{ transform: translateX(6px); color: var(--amber); }
.role-title{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: -0.005em;
  transition: color 0.3s;
}
.role-team,
.role-loc{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.role-arrow{
  text-align: right;
  color: var(--muted);
  font-family: 'Geist Mono', monospace;
  transition: transform 0.35s cubic-bezier(.2,1,.3,1), color 0.3s;
}
@media (max-width: 820px){
  .role-head{ display: none; }
  .role{ grid-template-columns: 1fr 40px; gap: 6px; padding: 18px 20px; }
  .role-team, .role-loc{ display: none; }
  .role:hover{ padding-left: 28px; }
}

/* ----- Role expandable (details/summary) override ----- */
details.role{
  display: block;
  padding: 0 !important;
  cursor: default;
  transition: background 0.3s;
}
details.role:hover{
  padding-left: 0 !important;
  background: transparent;
}
details.role:hover .role-title{ color: var(--ink); }

details.role > summary.role-row{
  display: grid;
  grid-template-columns: 1fr 200px 160px 40px;
  gap: 18px;
  padding: 22px 24px;
  align-items: center;
  cursor: pointer;
  list-style: none;
  transition: padding-left 0.4s cubic-bezier(.2,1,.3,1), background 0.3s;
  user-select: none;
}
details.role > summary.role-row::-webkit-details-marker{ display: none; }
details.role > summary.role-row::marker{ display: none; content: ''; }

details.role > summary.role-row:hover{
  padding-left: 36px;
  background: rgba(212,165,116,0.04);
}
details.role > summary.role-row:hover .role-title{ color: var(--amber); }

details.role[open] > summary.role-row{
  background: rgba(212,165,116,0.05);
  padding-left: 36px;
}
details.role[open] > summary.role-row .role-title{ color: var(--amber); }

/* Round +/× arrow */
.role-arrow{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  border: 1px solid var(--line-mid);
  border-radius: 50%;
  font-family: 'Geist Mono', monospace;
  font-size: 14px;
  line-height: 1;
  color: var(--muted);
  text-align: center;
  justify-self: end;
  transition: transform 0.4s cubic-bezier(.2,1,.3,1), color 0.3s, border-color 0.3s;
}
details.role[open] .role-arrow{
  transform: rotate(45deg);
  color: var(--amber);
  border-color: var(--amber);
}
details.role > summary.role-row:hover .role-arrow{
  color: var(--amber);
  border-color: var(--amber);
}

/* Expanded panel */
.role-panel{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 28px;
  padding: 4px 32px 28px 36px;
  border-bottom: 1px solid rgba(212,165,116,0.16);
  background: rgba(212,165,116,0.025);
  animation: rolePanelIn 0.35s cubic-bezier(.2,1,.3,1) both;
}
@keyframes rolePanelIn{
  from{ opacity: 0; transform: translateY(-4px); }
  to{ opacity: 1; transform: translateY(0); }
}
.role-desc{
  font-family: 'Geist', sans-serif;
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-dim);
  max-width: 560px;
  margin: 0;
  grid-column: 1 / 2;
  text-wrap: pretty;
}
.role-meta{
  grid-column: 1 / 2;
  margin-top: 12px;
  display: grid;
  grid-template-columns: auto 1fr auto 1fr;
  column-gap: 14px;
  row-gap: 4px;
  align-items: baseline;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.role-meta .rm-k{ color: var(--muted); }
.role-meta .rm-v{
  color: var(--ink);
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
}
.role-apply{
  grid-column: 2 / 3;
  grid-row: 1 / 3;
  align-self: center;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 22px;
  background: var(--ink);
  color: var(--bg);
  text-decoration: none;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border: 1px solid var(--ink);
  border-radius: 999px;
  transition: background 0.3s, color 0.3s, border-color 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
  white-space: nowrap;
}
.role-apply:hover{
  background: var(--amber);
  border-color: var(--amber);
}
.role-apply span{ transition: transform 0.3s; display: inline-block; }
.role-apply:hover span{ transform: translateX(4px); }

@media (max-width: 820px){
  details.role > summary.role-row{
    grid-template-columns: 1fr 40px;
    gap: 6px;
    padding: 18px 20px;
  }
  details.role > summary.role-row:hover,
  details.role[open] > summary.role-row{ padding-left: 28px; }
  .role-panel{
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 4px 20px 22px 28px;
  }
  .role-apply{
    grid-column: 1 / -1;
    grid-row: auto;
    justify-self: start;
  }
  .role-meta{ grid-template-columns: auto 1fr; }
}

.careers-cta-wrap{ text-align: center; margin-top: 56px; }
.careers-cta{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 32px;
  background: var(--ink);
  color: var(--bg);
  text-decoration: none;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  border-radius: 999px;
  transition: background 0.3s, color 0.3s, transform 0.5s cubic-bezier(.2,1,.3,1);
}
.careers-cta:hover{ background: var(--amber); color: var(--bg); }
.careers-cta .arrow{
  display: inline-flex;
  transition: transform 0.35s cubic-bezier(.2,1,.3,1);
}
.careers-cta:hover .arrow{ transform: translateX(6px); }

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  padding: 70px 0 36px;
  background: var(--bg);
  position: relative;
  z-index: 1;
}
.foot-top{
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 60px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--line);
}
.foot-brand p{
  margin-top: 24px;
  max-width: 380px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--muted);
}
.foot-brand .signature{
  margin-top: 32px;
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 28px;
  line-height: 1;
  color: var(--amber);
}
.foot-col h4{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-bottom: 22px;
  font-weight: 500;
}
.foot-col ul{ list-style: none; display: flex; flex-direction: column; gap: 12px; }
.foot-col a{
  color: var(--ink);
  text-decoration: none;
  font-size: 15px;
  transition: color 0.2s, padding-left 0.3s;
}
.foot-col a:hover{ color: var(--amber); padding-left: 6px; }

.foot-mega{
  padding: 60px 0;
  border-bottom: 1px solid var(--line);
  text-align: center;
  overflow: hidden;
}
.foot-mega .mega{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(48px, 10vw, 160px);
  line-height: 1.12;
  padding-bottom: 0.1em;
  letter-spacing: -0.04em;
  white-space: nowrap;
  background: linear-gradient(180deg, var(--ink) 0%, rgba(244,240,232,0.6) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.foot-mega .mega .it{ font-style: italic; color: var(--amber); -webkit-text-fill-color: var(--amber); }

.foot-bottom{
  margin-top: 32px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  flex-wrap: wrap; gap: 14px;
}
.foot-bottom .legal{ display: flex; gap: 24px; }
.foot-bottom .legal a{ color: var(--muted); text-decoration: none; }
.foot-bottom .legal a:hover{ color: var(--ink); }
@media (max-width: 820px){
  .foot-top{ grid-template-columns: 1fr 1fr; }
  .foot-brand{ grid-column: 1 / -1; }
}

/* ============================================================
   ANIMATIONS / REVEAL
   ============================================================ */
.fade-up{ opacity: 0; transform: translateY(20px); animation: fadeUp 1s cubic-bezier(0.22, 1, 0.36, 1) forwards; }
.d1{ animation-delay: 0.05s; }
.d2{ animation-delay: 0.18s; }
.d3{ animation-delay: 0.32s; }
.d4{ animation-delay: 0.48s; }
@keyframes fadeUp{ to{ opacity: 1; transform: translateY(0); } }

.reveal{
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.in{ opacity: 1; transform: translateY(0); }
.reveal.in.delay-1{ transition-delay: 0.1s; }
.reveal.in.delay-2{ transition-delay: 0.2s; }
.reveal.in.delay-3{ transition-delay: 0.3s; }

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation: none !important; transition: none !important; }
  .reveal{ opacity: 1; transform: none; }
}

/* ============================================================
   ADDITIONS — Clock visual, commerce feature, glass stats,
   compounding bars (new platform visual)
   ============================================================ */

/* --- 24h publishing rhythm clock (hero card 2) --- */
.hv-clock{
  position: relative;
  margin: 4px auto 10px;
  width: 100%;
  max-width: 220px;
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.hv-clock svg{ width: 100%; height: 100%; overflow: visible; }

.clk-hand{
  transform-origin: 100px 100px;
  transform-box: view-box;
  animation: clkSweep 24s linear infinite;
}
@keyframes clkSweep{ from{ transform: rotate(0deg); } to{ transform: rotate(360deg); } }

.clk-dot{ transform-origin: center; transform-box: fill-box; animation: clkPulse 3.6s ease-in-out infinite; }
.clk-dot.d-1{ animation-delay: 0s; }
.clk-dot.d-2{ animation-delay: 0.4s; }
.clk-dot.d-3{ animation-delay: 0.8s; }
.clk-dot.d-4{ animation-delay: 1.2s; }
.clk-dot.d-5{ animation-delay: 1.6s; }
.clk-dot.d-6{ animation-delay: 2.0s; }
.clk-dot.d-7{ animation-delay: 2.4s; }
.clk-dot.d-8{ animation-delay: 2.8s; }
@keyframes clkPulse{
  0%, 70%, 100%{ opacity: 0.6; filter: drop-shadow(0 0 0 rgba(212,165,116,0)); }
  20%, 35%{ opacity: 1; filter: drop-shadow(0 0 6px rgba(212,165,116,0.7)); }
}

.hv-clock-foot{
  display: flex; align-items: center; gap: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  flex-wrap: wrap;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  justify-content: center;
}
.hv-clock-foot .dot{ width: 3px; height: 3px; border-radius: 50%; background: var(--amber); display: inline-block; }

/* --- Commerce featured banner --- */
.shop-feature{
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
  margin-bottom: 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: rgba(10,10,10,0.4);
  transition: border-color 0.3s;
}
.shop-feature:hover{ border-color: var(--line-strong); }
.sf-img{
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 2;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.sf-meta{
  padding: 16px 18px;
  display: flex; flex-direction: row; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.sf-tag{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--amber);
}
.sf-name{
  font-family: 'Instrument Serif', serif;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.sf-price{
  font-family: 'Geist Mono', monospace;
  font-size: 13px;
  color: var(--ink-dim);
}
@media (max-width: 520px){
  .shop-feature{ grid-template-columns: 1fr; }
  .sf-img{ aspect-ratio: 4 / 3; }
}

/* Equalize panel heights across tabs */
.fmt-visual{ min-height: 600px; display: flex; flex-direction: column; }
.fmt-visual > *{ flex: 1; display: flex; flex-direction: column; }
.inbox-list{ flex: 1; }
.shop > .shop-row:last-of-type{ margin-bottom: auto; }
/* Phones has its own fixed height — don't let the flex:1 stretch it to 0 at narrow widths */
.phones{ flex: 0 0 auto !important; }
@media (max-width: 1080px){
  .fmt-visual{ min-height: 0; }
}

/* --- Glass stat cards: hero foot, team stats, reader foot --- */
.hero-foot{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 56px;
  padding-top: 0;
  border-top: none;
}
.hero-foot .hf-cell{
  background: var(--glass-bg);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 8px;
  transition: background 0.3s, border-color 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
}
.hero-foot .hf-cell:hover{
  background: var(--glass-bg-strong);
  border-color: var(--glass-hl);
  transform: translateY(-2px);
}

.team-stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 48px;
  padding-top: 0;
  border-top: none;
}
.team-stats .ts{
  background: var(--glass-bg);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 20px 16px;
  display: flex; flex-direction: column; gap: 8px;
  transition: background 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
}
.team-stats .ts:hover{ background: var(--glass-bg-strong); transform: translateY(-2px); }

.reader-foot{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 80px;
  padding-top: 40px;
  border-top: 1px solid var(--line);
}
.reader-foot .rf-cell{
  background: var(--glass-bg);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 22px 20px;
  display: flex; flex-direction: column; gap: 10px;
  transition: background 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
}
.reader-foot .rf-cell:hover{ background: var(--glass-bg-strong); transform: translateY(-2px); }

/* --- Glass audience cells (more cohesive) --- */
.audience-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  border-top: none;
}
.audience-cell{
  padding: 20px 18px;
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  border-right: 1px solid var(--glass-border) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  transition: background 0.3s, border-color 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
}
.audience-cell:hover{
  background: var(--glass-bg-strong);
  border-color: var(--glass-hl);
  transform: translateY(-2px);
  padding-left: 18px;
}

/* --- Glass thesis aside + thesis items --- */
.thesis-item{
  padding: 30px 28px;
  margin-bottom: 12px;
  border: 1px solid var(--glass-border);
  border-top: 1px solid var(--glass-border);
  background: var(--glass-bg);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 12px;
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 28px;
  align-items: start;
  transition: background 0.3s, border-color 0.3s, padding-left 0.4s cubic-bezier(.2,1,.3,1), transform 0.4s cubic-bezier(.2,1,.3,1);
}
.thesis-item:last-child{ border-bottom: 1px solid var(--glass-border); }
.thesis-item:hover{
  background: var(--glass-bg-strong);
  border-color: var(--glass-hl);
  padding-left: 40px;
  transform: translateY(-1px);
}

/* --- Glass role list --- */
.role-list{
  background: var(--glass-bg);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--glass-border);
}

/* --- NEW SECOND VISUAL: Compounding bars in Platform section --- */
.compounding{
  margin: 0 0 60px;
  padding: 40px 36px;
  background: rgba(10,10,10,0.04);
  border: 1px solid rgba(10,10,10,0.10);
  border-radius: 14px;
  backdrop-filter: blur(8px);
  position: relative;
  overflow: hidden;
}
.compounding::before{
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(600px 200px at 20% 0%, rgba(212,165,116,0.18), transparent 60%);
  pointer-events: none;
}
.compounding-head{
  position: relative;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 32px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(10,10,10,0.12);
  flex-wrap: wrap;
}
.compounding-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted-on-light);
}
.compounding-title{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.15;
  color: var(--ink-on-light);
  letter-spacing: -0.01em;
}
.compounding-title em{ font-style: italic; }
.compounding-meta{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted-on-light);
}
.compounding-meta::before{
  content: ''; display: inline-block;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ink-on-light);
  margin-right: 8px;
  vertical-align: middle;
  animation: blink 2s ease-in-out infinite;
}

.compounding-bars{
  position: relative;
  display: grid;
  grid-template-columns: 110px 1fr 60px;
  gap: 14px 18px;
  align-items: center;
}
.cb-row{ display: contents; }
.cb-name{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 18px;
  color: var(--ink-on-light);
}
.cb-track{
  position: relative;
  height: 10px;
  border-radius: 5px;
  background: rgba(10,10,10,0.08);
  overflow: hidden;
}
.cb-fill{
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 100%;
  background: linear-gradient(90deg, #b88958, #d4a574);
  border-radius: 5px;
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 1.2s cubic-bezier(.2,1,.3,1);
}
.compounding.in .cb-fill{ transform: scaleX(var(--w, 0.5)); }
.cb-row:nth-child(1) .cb-fill{ transition-delay: 0.05s; }
.cb-row:nth-child(2) .cb-fill{ transition-delay: 0.18s; }
.cb-row:nth-child(3) .cb-fill{ transition-delay: 0.31s; }
.cb-row:nth-child(4) .cb-fill{ transition-delay: 0.44s; }
.cb-row:nth-child(5) .cb-fill{ transition-delay: 0.57s; }
.cb-row:nth-child(6) .cb-fill{ transition-delay: 0.70s; }
.cb-val{
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  color: var(--ink-on-light);
  text-align: right;
  letter-spacing: 0.04em;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 0.5s, transform 0.5s;
}
.compounding.in .cb-val{ opacity: 1; transform: translateX(0); }
.cb-row:nth-child(1) .cb-val{ transition-delay: 0.50s; }
.cb-row:nth-child(2) .cb-val{ transition-delay: 0.63s; }
.cb-row:nth-child(3) .cb-val{ transition-delay: 0.76s; }
.cb-row:nth-child(4) .cb-val{ transition-delay: 0.89s; }
.cb-row:nth-child(5) .cb-val{ transition-delay: 1.02s; }
.cb-row:nth-child(6) .cb-val{ transition-delay: 1.15s; }
.compounding-foot{
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(10,10,10,0.10);
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted-on-light);
  display: flex; align-items: center; gap: 10px;
}
.compounding-foot strong{ color: var(--ink-on-light); font-weight: 500; }
@media (max-width: 640px){
  .compounding{ padding: 28px 22px; }
  .compounding-bars{ grid-template-columns: 90px 1fr 50px; gap: 10px 12px; }
  .cb-name{ font-size: 16px; }
}

/* ============================================================
   TWEAKS — Mood / Atmosphere / Display
   ============================================================ */

/* ---------- MOOD ---------- */

/* warm (default) — uses :root values, no overrides needed */

/* cool — shift accent + ambient toward steel-blue */
body.mood-cool{
  --amber: #8aa6c4;
  --amber-bright: #a4bcd6;
  --amber-soft: rgba(138,166,196,0.14);
}
body.mood-cool .orb-1{ background: radial-gradient(circle, rgba(138,166,196,0.20), transparent 70%); }
body.mood-cool .orb-2{ background: radial-gradient(circle, rgba(138,166,196,0.12), transparent 70%); }
body.mood-cool .hero::before{
  background:
    radial-gradient(800px 500px at 78% 30%, rgba(138,166,196,0.10), transparent 70%),
    radial-gradient(600px 400px at 12% 80%, rgba(138,166,196,0.06), transparent 70%);
}
body.mood-cool .readership::before{ background: radial-gradient(circle, rgba(138,166,196,0.08), transparent 70%); }
body.mood-cool .careers::before{ background: radial-gradient(circle, rgba(138,166,196,0.10), transparent 70%); }
body.mood-cool .light-section::before{
  background:
    radial-gradient(600px 400px at 10% 10%, rgba(138,166,196,0.18), transparent 60%),
    radial-gradient(700px 500px at 90% 90%, rgba(138,166,196,0.10), transparent 60%);
}
body.mood-cool .cb-fill{ background: linear-gradient(90deg, #6d8bab, #8aa6c4); }
body.mood-cool .cm-bg-health{ background: radial-gradient(800px 400px at 30% 30%, rgba(138,166,196,0.22), transparent 60%), linear-gradient(135deg, #1a2230 0%, #0f141d 60%, #0a0a0a 100%); }
body.mood-cool .cm-bg-meaning{ background: radial-gradient(700px 400px at 50% 50%, rgba(138,166,196,0.20), transparent 60%), linear-gradient(155deg, #1a212e 0%, #11151c 60%, #0a0a0a 100%); }
body.mood-cool .hv-glow{ background: radial-gradient(circle, rgba(138,166,196,0.18), transparent 65%); }
body.mood-cool .compounding::before{ background: radial-gradient(600px 200px at 20% 0%, rgba(138,166,196,0.20), transparent 60%); }
body.mood-cool .signature,
body.mood-cool .foot-mega .mega .it{ color: var(--amber); -webkit-text-fill-color: var(--amber); }

/* mono — restrained, monochrome cream */
body.mono-mono,
body.mood-mono{
  --amber: #d6d2c6;
  --amber-bright: #e8e3d6;
  --amber-soft: rgba(214,210,198,0.10);
}
body.mood-mono .orb-1{ background: radial-gradient(circle, rgba(244,240,232,0.08), transparent 70%); }
body.mood-mono .orb-2{ background: radial-gradient(circle, rgba(244,240,232,0.05), transparent 70%); }
body.mood-mono .hero::before{
  background:
    radial-gradient(800px 500px at 78% 30%, rgba(244,240,232,0.04), transparent 70%),
    radial-gradient(600px 400px at 12% 80%, rgba(244,240,232,0.03), transparent 70%);
}
body.mood-mono .readership::before{ background: radial-gradient(circle, rgba(244,240,232,0.04), transparent 70%); }
body.mood-mono .careers::before{ background: radial-gradient(circle, rgba(244,240,232,0.05), transparent 70%); }
body.mood-mono .light-section::before{
  background:
    radial-gradient(600px 400px at 10% 10%, rgba(214,210,198,0.18), transparent 60%),
    radial-gradient(700px 500px at 90% 90%, rgba(214,210,198,0.10), transparent 60%);
}
body.mood-mono .cb-fill{ background: linear-gradient(90deg, #948f80, #b8b3a4); }
body.mood-mono .cm-bg-health,
body.mood-mono .cm-bg-meaning,
body.mood-mono .cm-bg-mind,
body.mood-mono .cm-bg-work{
  background:
    radial-gradient(700px 400px at 50% 50%, rgba(244,240,232,0.08), transparent 60%),
    linear-gradient(135deg, #1a1a1a 0%, #121212 60%, #0a0a0a 100%);
}
body.mood-mono .hv-glow{ background: radial-gradient(circle, rgba(244,240,232,0.10), transparent 65%); }
body.mood-mono .compounding::before{ background: radial-gradient(600px 200px at 20% 0%, rgba(214,210,198,0.18), transparent 60%); }
/* italic accent shouldn't be loud in mono */
body.mood-mono .hero h1 .it,
body.mood-mono .section-head h2 .it,
body.mood-mono .reader-statement h2 .it,
body.mood-mono .careers-head h2 .it,
body.mood-mono .team-left h3 .it,
body.mood-mono .signature,
body.mood-mono .foot-mega .mega .it{ color: var(--ink); -webkit-text-fill-color: var(--ink); }
body.mood-mono .clk-dot{ fill: var(--ink-dim) !important; }
body.mood-mono .clk-hand{ stroke: var(--ink-dim); }

/* ---------- ATMOSPHERE ---------- */

/* refined (default) — current */

/* glassy — more blur, brighter glass, brighter orbs */
body.atmosphere-glassy{
  --glass-bg: rgba(244,240,232,0.08);
  --glass-bg-strong: rgba(244,240,232,0.13);
  --glass-border: rgba(244,240,232,0.22);
  --glass-hl: rgba(244,240,232,0.32);
}
body.atmosphere-glassy .orb-1{ opacity: 0.85; filter: blur(60px); width: 820px; height: 820px; }
body.atmosphere-glassy .orb-2{ opacity: 0.7; filter: blur(60px); }
body.atmosphere-glassy nav.top{ backdrop-filter: blur(28px) saturate(1.6); -webkit-backdrop-filter: blur(28px) saturate(1.6); background: rgba(10,10,10,0.35); }
body.atmosphere-glassy nav.top.scrolled{ background: rgba(10,10,10,0.55); }
body.atmosphere-glassy .hv-card{ backdrop-filter: blur(28px) saturate(1.7); -webkit-backdrop-filter: blur(28px) saturate(1.7); }
body.atmosphere-glassy .hv-chip{ backdrop-filter: blur(20px) saturate(1.5); -webkit-backdrop-filter: blur(20px) saturate(1.5); }
body.atmosphere-glassy .cm-glass{ backdrop-filter: blur(26px) saturate(1.6); -webkit-backdrop-filter: blur(26px) saturate(1.6); }
body.atmosphere-glassy .inbox,
body.atmosphere-glassy .shop,
body.atmosphere-glassy .phone{ backdrop-filter: blur(28px) saturate(1.7); -webkit-backdrop-filter: blur(28px) saturate(1.7); }
body.atmosphere-glassy .globe-wrap,
body.atmosphere-glassy .thesis-aside,
body.atmosphere-glassy .audience-pill,
body.atmosphere-glassy .role-list,
body.atmosphere-glassy .thesis-item,
body.atmosphere-glassy .audience-cell,
body.atmosphere-glassy .reader-foot .rf-cell,
body.atmosphere-glassy .hero-foot .hf-cell,
body.atmosphere-glassy .team-stats .ts{
  backdrop-filter: blur(22px) saturate(1.4);
  -webkit-backdrop-filter: blur(22px) saturate(1.4);
}

/* solid — minimal glass, flat backgrounds, orbs off */
body.atmosphere-solid{
  --glass-bg: rgba(244,240,232,0.02);
  --glass-bg-strong: rgba(244,240,232,0.04);
  --glass-border: var(--line-mid);
  --glass-hl: var(--line-strong);
}
body.atmosphere-solid .ambient{ display: none; }
body.atmosphere-solid .hero::before,
body.atmosphere-solid .readership::before,
body.atmosphere-solid .careers::before{ display: none; }
body.atmosphere-solid nav.top{ backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(10,10,10,0.92); }
body.atmosphere-solid nav.top.scrolled{ background: rgba(10,10,10,0.96); }
body.atmosphere-solid .hv-card,
body.atmosphere-solid .hv-chip,
body.atmosphere-solid .cm-glass,
body.atmosphere-solid .inbox,
body.atmosphere-solid .shop,
body.atmosphere-solid .phone,
body.atmosphere-solid .globe-wrap,
body.atmosphere-solid .thesis-aside,
body.atmosphere-solid .audience-pill,
body.atmosphere-solid .role-list,
body.atmosphere-solid .thesis-item,
body.atmosphere-solid .audience-cell,
body.atmosphere-solid .reader-foot .rf-cell,
body.atmosphere-solid .hero-foot .hf-cell,
body.atmosphere-solid .team-stats .ts,
body.atmosphere-solid .fmt-tabs,
body.atmosphere-solid .now-reading,
body.atmosphere-solid .btn-ghost,
body.atmosphere-solid .hero-meta-top,
body.atmosphere-solid .careers-head .label{
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: var(--bg-card);
  border-color: var(--line-mid);
}
body.atmosphere-solid .hv-glow{ display: none; }
body.atmosphere-solid .compounding::before{ display: none; }
body.atmosphere-solid .light-section::before{ display: none; }
body.atmosphere-solid .grain{ opacity: 0.02; }

/* ---------- DISPLAY ---------- */

/* editorial (default) — Instrument Serif headlines, italic accents */

/* modern — Geist sans-serif headlines, no italic accents, tighter tracking */
body.display-modern .hero h1,
body.display-modern .section-head h2,
body.display-modern .careers-head h2,
body.display-modern .reader-statement h2,
body.display-modern .cat-name,
body.display-modern .principle .p-name,
body.display-modern .fmt-copy h3,
body.display-modern .team-left h3,
body.display-modern .compounding-title,
body.display-modern .cb-name,
body.display-modern .thesis-item h4,
body.display-modern .cm-mast,
body.display-modern .ps-mast,
body.display-modern .ps-headline,
body.display-modern .ps-headline-sm,
body.display-modern .hv-sub,
body.display-modern .a-name,
body.display-modern .role-title,
body.display-modern .discipline .name,
body.display-modern .ix-subj,
body.display-modern .sf-name,
body.display-modern .prod-name,
body.display-modern .cm-headline,
body.display-modern .ta-title,
body.display-modern .signature,
body.display-modern .bm-inner,
body.display-modern .foot-mega .mega{
  font-family: 'Geist', sans-serif;
  font-weight: 500;
  letter-spacing: -0.035em;
}
body.display-modern .hv-quote,
body.display-modern .cm-quote,
body.display-modern .cm-sig{
  font-family: 'Geist', sans-serif;
  font-style: normal;
  font-weight: 400;
}
body.display-modern .hf-v,
body.display-modern .fs-v,
body.display-modern .rf-v,
body.display-modern .ts-v,
body.display-modern .metric .v{
  font-family: 'Geist', sans-serif;
  font-weight: 600;
  letter-spacing: -0.04em;
}
/* Drop italic accents — render as upright */
body.display-modern .it,
body.display-modern em{
  font-style: normal;
}
body.display-modern .hero h1 .it,
body.display-modern .section-head h2 .it,
body.display-modern .reader-statement h2 .it,
body.display-modern .careers-head h2 .it,
body.display-modern .team-left h3 .it,
body.display-modern .cat-name .it,
body.display-modern .principle .p-name .it,
body.display-modern .fmt-copy h3 .it{
  font-style: normal;
  color: var(--amber);
}
body.display-modern .ps-light .ps-mast em{ color: #6b4d2a; }


/* ============================================================
   ABSTRACT GLASS GLYPHS — replacement for named mastheads
   ============================================================ */
.hv-glyph{
  display: flex; align-items: center; justify-content: flex-start;
  padding: 4px 0 14px;
}
.hv-glyph svg{ opacity: 0.92; }

.cm-glyph{
  width: 36px; height: 36px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(244,240,232,0.04);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(6px);
}
.cm-lines-top{ margin-bottom: 14px; }
.cm-lines-top .cm-ln{ height: 7px; }
.cm-lines-top .cm-ln:first-child{ background: rgba(244,240,232,0.18); }

/* Inbox sender marks */
.ix-mark{
  display: inline-block;
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1px solid var(--glass-border);
  background: rgba(244,240,232,0.04);
  backdrop-filter: blur(6px);
  position: relative;
  flex-shrink: 0;
}
.ix-mark::after{
  content: '';
  position: absolute; inset: 5px;
  border-radius: 50%;
  background: var(--amber);
  opacity: 0.7;
}
.ix-mark.m-1::after{ background: #d4a574; }
.ix-mark.m-2::after{ background: #e6b988; opacity: 0.55; }
.ix-mark.m-3::after{ background: #f4f0e8; opacity: 0.7; }
.ix-mark.m-4::after{ background: transparent; box-shadow: inset 0 0 0 1px #d4a574; }
.ix-sender{ display: inline-flex; align-items: center; gap: 10px; }

/* Phone screen abstract masthead */
.ps-mast-glyph{
  display: flex; align-items: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(244,240,232,0.05);
  border: 1px solid var(--glass-border);
  justify-content: center;
  margin-bottom: 16px;
  backdrop-filter: blur(6px);
}
.ps-light .ps-mast-glyph{
  background: rgba(10,10,10,0.04);
  border-color: rgba(10,10,10,0.12);
}


/* ============================================================
   HERO VISUAL — VARIANTS (added: masthead / stack / dispatch / clock)
   ============================================================ */

.hv-variant{
  position: absolute; inset: 0;
  display: none;
}
.hv-variant .hv-glow{
  position: absolute;
  width: 480px; height: 480px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(212,165,116,0.16), transparent 65%);
  filter: blur(20px);
  pointer-events: none;
  z-index: 0;
}

/* default + body-class switching */
body[class*="hero-"] .hv-variant{ display: none; }
body.hero-masthead .hv-variant[data-variant="masthead"],
body.hero-stack    .hv-variant[data-variant="stack"],
body.hero-dispatch .hv-variant[data-variant="dispatch"],
body.hero-clock    .hv-variant[data-variant="clock"]{
  display: block;
}
/* fallback if no body class: show masthead */
body:not([class*="hero-"]) .hv-variant[data-variant="masthead"]{ display: block; }

/* ───── reusable: amber tag look (already exists via .hv-tag) ───── */

/* ============================================================
   VARIANT 1 — MASTHEAD INDEX (the editorial TOC card)
   ============================================================ */
.mh-card{
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, 96%);
  background: linear-gradient(180deg, rgba(244,240,232,0.05) 0%, rgba(244,240,232,0.025) 100%);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  box-shadow:
    0 30px 80px rgba(0,0,0,0.55),
    0 2px 0 rgba(244,240,232,0.04) inset;
  padding: 28px 30px 22px;
  z-index: 1;
  animation: mhFloat 12s ease-in-out infinite;
}
@keyframes mhFloat{
  0%,100%{ transform: translate(-50%, -50%); }
  50%{ transform: translate(-50%, calc(-50% - 6px)); }
}

.mh-card-head{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.mh-mark{
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(244,240,232,0.05);
  border: 1px solid var(--glass-border);
  color: var(--ink);
}
.mh-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-bottom: 4px;
}
.mh-name{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.mh-folio{
  display: flex; flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  text-align: right;
}
.mh-folio span:first-child{ color: var(--amber); }

.mh-list{
  display: flex; flex-direction: column;
}
.mh-row{
  display: grid;
  grid-template-columns: 44px 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 16px 0;
  border-bottom: 1px dashed var(--line);
  position: relative;
}
.mh-row:last-child{ border-bottom: none; }
.mh-row::before{
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 30%;
  border-left: 1px solid transparent;
  transition: border-color 0.5s, width 0.5s;
}
.mh-row:hover::before{ border-color: var(--amber); }
.mh-num{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.mh-cat-name{
  font-family: 'Instrument Serif', serif;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 4px;
}
.mh-cat-name em{ font-style: italic; color: var(--amber); }
.mh-beats{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--muted);
  text-transform: none;
}
.mh-time{
  display: flex; flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  min-width: 60px;
  text-align: right;
}
.mh-time-h{
  font-family: 'Instrument Serif', serif;
  font-size: 17px;
  font-style: italic;
  color: var(--ink);
}
.mh-time-k{
  font-family: 'Geist Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}

/* cadence pill — replaces specific times */
.mh-cad{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--amber);
  padding: 5px 10px;
  border: 1px solid rgba(212,165,116,0.32);
  background: var(--amber-soft);
  border-radius: 999px;
  min-width: 64px;
  text-align: center;
}
body.mood-cool .mh-cad{ color: #8aa6c4; border-color: rgba(138,166,196,0.32); background: rgba(138,166,196,0.10); }
body.mood-mono .mh-cad{ color: var(--ink-dim); border-color: var(--line-mid); background: rgba(244,240,232,0.04); }

.mh-foot{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  padding-top: 18px;
  margin-top: 6px;
  border-top: 1px solid var(--line);
}
.mh-foot-cell{ display: flex; flex-direction: column; gap: 3px; }
.mh-foot-k{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.mh-foot-v{
  font-family: 'Instrument Serif', serif;
  font-size: 18px;
  font-style: italic;
  color: var(--ink);
}
.mh-foot-v.amber{ color: var(--amber); }

.mh-stamp{
  position: absolute;
  left: 0; bottom: 4%;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  line-height: 1.4;
  z-index: 2;
  animation: chipBob 6s ease-in-out infinite;
}
@keyframes chipBob{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-4px); } }
.mh-stamp-dot{
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 12px rgba(212,165,116,0.6);
}

/* responsive */
@media (max-width: 1080px){
  .mh-card{ width: min(520px, 100%); padding: 22px 22px 18px; }
  .mh-cat-name{ font-size: 21px; }
  .mh-stamp{ left: 50%; bottom: -2%; transform: translateX(-50%); }
}
@media (max-width: 640px){
  .mh-card{ padding: 18px 18px 16px; }
  .mh-cat-name{ font-size: 18px; }
  .mh-beats{ font-size: 9.5px; }
  .mh-row{ grid-template-columns: 32px 1fr auto; gap: 10px; padding: 12px 0; }
  .mh-foot{ gap: 10px; }
  .mh-foot-v{ font-size: 14px; }
  .mh-stamp{ display: none; }
}

/* ============================================================
   VARIANT 2 — PORTFOLIO STACK (fanned brand covers)
   ============================================================ */
.stk-stage{
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  perspective: 1400px;
}
.stk-card{
  position: absolute;
  width: 380px;
  background: linear-gradient(170deg, rgba(244,240,232,0.06) 0%, rgba(244,240,232,0.02) 100%);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  box-shadow: 0 20px 60px rgba(0,0,0,0.55);
  padding: 22px 24px;
  transform-origin: center bottom;
  transition: transform 0.6s cubic-bezier(.2,1,.3,1);
  will-change: transform;
}

/* fan layout */
.stk-card-1{ transform: rotate(-9deg) translate(-90px, 60px); z-index: 1; opacity: 0.55; }
.stk-card-2{ transform: rotate(-4deg) translate(-44px, 28px); z-index: 2; opacity: 0.75; }
.stk-card-3{ transform: rotate(2deg)  translate(20px, 8px); z-index: 3; opacity: 0.9; }
.stk-card-4{
  transform: rotate(6deg) translate(70px, -20px);
  z-index: 4;
  background: linear-gradient(170deg, rgba(212,165,116,0.10) 0%, rgba(244,240,232,0.04) 100%);
  border-color: rgba(212,165,116,0.32);
  box-shadow:
    0 30px 80px rgba(0,0,0,0.65),
    0 2px 0 rgba(244,240,232,0.06) inset;
}

/* hover: fan out slightly */
.stk-stage:hover .stk-card-1{ transform: rotate(-12deg) translate(-110px, 60px); }
.stk-stage:hover .stk-card-2{ transform: rotate(-6deg)  translate(-56px, 28px); }
.stk-stage:hover .stk-card-3{ transform: rotate(3deg)   translate(28px, 6px); }
.stk-stage:hover .stk-card-4{ transform: rotate(8deg)   translate(86px, -22px); }

.stk-bar{
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 14px;
}
.stk-dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--amber); flex-shrink: 0; }
.stk-meta{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  flex: 1;
}
.stk-tag{
  font-family: 'Geist Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-dim);
  padding: 3px 8px;
  border: 1px solid var(--line-mid);
  border-radius: 4px;
}
.stk-tag.tag-amber{ color: var(--amber); border-color: rgba(212,165,116,0.4); background: var(--amber-soft); }

.stk-cat-name{
  font-family: 'Instrument Serif', serif;
  font-size: 38px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 14px;
}
.stk-card-4 .stk-cat-name{ font-size: 44px; }
.stk-cat-name em{ font-style: italic; color: var(--amber); }

.stk-beats{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.stk-card-foot{
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--amber);
}
.stk-fdot{ width: 3px; height: 3px; border-radius: 50%; background: var(--muted); }

.stk-corner-stamp{
  position: absolute;
  right: 0; top: 6%;
  text-align: right;
  z-index: 5;
}
.stk-cs-k{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  margin-bottom: 6px;
}
.stk-cs-v{
  font-family: 'Instrument Serif', serif;
  font-size: 18px;
  line-height: 1.1;
  color: var(--ink);
}
.stk-cs-v em{ font-style: italic; color: var(--amber); }

@media (max-width: 1080px){
  .stk-card{ width: 320px; padding: 18px 20px; }
  .stk-cat-name{ font-size: 30px; }
  .stk-card-4 .stk-cat-name{ font-size: 34px; }
  .stk-card-1{ transform: rotate(-9deg) translate(-50px, 50px); }
  .stk-card-2{ transform: rotate(-4deg) translate(-22px, 22px); }
  .stk-card-3{ transform: rotate(2deg)  translate(14px, 4px); }
  .stk-card-4{ transform: rotate(6deg)  translate(50px, -14px); }
  .stk-corner-stamp{ display: none; }
}
@media (max-width: 640px){
  .stk-card{ width: 78%; padding: 14px 16px; }
  .stk-cat-name{ font-size: 24px; }
  .stk-card-4 .stk-cat-name{ font-size: 28px; }
  .stk-card-1{ transform: rotate(-6deg) translate(-30%, 40px); }
  .stk-card-2{ transform: rotate(-3deg) translate(-12%, 20px); }
  .stk-card-3{ transform: rotate(2deg)  translate(8%, 4px); }
  .stk-card-4{ transform: rotate(5deg)  translate(24%, -14px); }
}

/* ============================================================
   VARIANT 3 — TODAY'S DISPATCH (editorial reading-list feed)
   ============================================================ */
.td-card{
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(580px, 96%);
  background: linear-gradient(180deg, rgba(244,240,232,0.05) 0%, rgba(244,240,232,0.025) 100%);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  box-shadow:
    0 30px 80px rgba(0,0,0,0.55),
    0 2px 0 rgba(244,240,232,0.04) inset;
  padding: 24px 28px 18px;
  z-index: 1;
  animation: mhFloat 12s ease-in-out infinite;
}

.td-head{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: flex-end;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.td-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-bottom: 8px;
}
.td-title{
  font-family: 'Instrument Serif', serif;
  font-size: 36px;
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.td-title em{ font-style: italic; color: var(--amber); }

.td-head-r{
  text-align: right;
  display: flex; flex-direction: column; align-items: flex-end; gap: 10px;
}
.td-live{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 10px;
  border: 1px solid rgba(212,165,116,0.35);
  background: var(--amber-soft);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--amber);
}
.td-live-dot{
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--signal);
  animation: blink 1.6s ease-in-out infinite;
}
.td-count{ display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.td-count-n{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 22px;
  color: var(--amber);
  letter-spacing: -0.01em;
}
.td-count-k{
  font-family: 'Geist Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}

.td-feed{
  list-style: none;
  margin: 0; padding: 0;
}
.td-row{
  display: grid;
  grid-template-columns: 52px 130px 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--line);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-dim);
}
.td-row:last-child{ border-bottom: none; }
.td-time{
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  color: var(--amber);
  letter-spacing: 0.06em;
}
.td-cat{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}
.td-headline{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 16px;
  letter-spacing: -0.005em;
  color: var(--ink);
  line-height: 1.3;
  text-transform: none;
}
.td-status{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  padding: 4px 9px;
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  display: inline-flex; align-items: center; gap: 6px;
}
.td-row-sent .td-status{ color: var(--muted); opacity: 0.7; }
.td-row-queued .td-status{ color: var(--ink-dim); border-style: dashed; }
.td-status-active{
  color: var(--amber) !important;
  border-color: rgba(212,165,116,0.5) !important;
  background: var(--amber-soft);
  opacity: 1 !important;
}
.td-pulse{
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 0 0 rgba(212,165,116,0.6);
  animation: tdPulse 1.6s ease-in-out infinite;
}
@keyframes tdPulse{
  0%,100%{ box-shadow: 0 0 0 0 rgba(212,165,116,0.6); }
  50%{ box-shadow: 0 0 0 6px rgba(212,165,116,0); }
}
.td-row-active{
  background: linear-gradient(90deg, rgba(212,165,116,0.06), transparent 70%);
  border-radius: 8px;
  margin: 0 -8px;
  padding-left: 8px;
  padding-right: 8px;
}

.td-foot{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  padding-top: 16px;
  margin-top: 6px;
  border-top: 1px solid var(--line);
}
.td-foot-cell{ display: flex; flex-direction: column; gap: 3px; }
.td-foot-k{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.td-foot-v{
  font-family: 'Instrument Serif', serif;
  font-size: 17px;
  font-style: italic;
  color: var(--ink);
}
.td-foot-v.amber{ color: var(--amber); }

@media (max-width: 1080px){
  .td-card{ width: min(540px, 100%); padding: 20px 22px 16px; }
  .td-row{ grid-template-columns: 46px 110px 1fr auto; gap: 12px; }
  .td-headline{ font-size: 14px; }
  .td-title{ font-size: 30px; }
}
@media (max-width: 640px){
  .td-card{ padding: 16px 16px 14px; }
  .td-head{ grid-template-columns: 1fr; gap: 10px; padding-bottom: 14px; }
  .td-head-r{ flex-direction: row; justify-content: space-between; align-items: center; width: 100%; text-align: left; }
  .td-row{ grid-template-columns: 1fr; gap: 4px; padding: 12px 0; }
  .td-cat{ font-size: 9px; }
  .td-headline{ font-size: 14px; }
  .td-status{ align-self: flex-start; }
  .td-foot{ gap: 10px; }
  .td-foot-v{ font-size: 14px; }
}

/* ============================================================
   ATMOSPHERE / MOOD INTEGRATION for new variants
   ============================================================ */
body.atmosphere-glassy .mh-card,
body.atmosphere-glassy .stk-card,
body.atmosphere-glassy .td-card{
  backdrop-filter: blur(28px) saturate(1.7);
  -webkit-backdrop-filter: blur(28px) saturate(1.7);
}
body.atmosphere-solid .mh-card,
body.atmosphere-solid .stk-card,
body.atmosphere-solid .td-card{
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: var(--bg-card);
}
body.atmosphere-solid .hv-glow{ display: none; }

body.mood-cool .mh-foot-v.amber,
body.mood-cool .td-foot-v.amber,
body.mood-cool .td-count-n,
body.mood-cool .td-live,
body.mood-cool .td-time,
body.mood-cool .stk-cat-name em,
body.mood-cool .mh-cat-name em,
body.mood-cool .td-title em,
body.mood-cool .stk-cs-v em,
body.mood-cool .mh-folio span:first-child{
  color: #8aa6c4;
}
body.mood-cool .mh-stamp-dot,
body.mood-cool .td-pulse{ background: #8aa6c4; box-shadow: 0 0 12px rgba(138,166,196,0.55); }
body.mood-cool .stk-card-4{ border-color: rgba(138,166,196,0.32); background: linear-gradient(170deg, rgba(138,166,196,0.10) 0%, rgba(244,240,232,0.04) 100%); }
body.mood-cool .td-live{ background: rgba(138,166,196,0.14); border-color: rgba(138,166,196,0.35); }
body.mood-cool .td-row-active{ background: linear-gradient(90deg, rgba(138,166,196,0.06), transparent 70%); }
body.mood-cool .td-status-active{ background: rgba(138,166,196,0.14); border-color: rgba(138,166,196,0.5) !important; }

body.mood-mono .mh-foot-v.amber,
body.mood-mono .td-foot-v.amber,
body.mood-mono .td-count-n,
body.mood-mono .td-live,
body.mood-mono .td-time,
body.mood-mono .stk-cat-name em,
body.mood-mono .mh-cat-name em,
body.mood-mono .td-title em,
body.mood-mono .stk-cs-v em,
body.mood-mono .mh-folio span:first-child{
  color: var(--ink);
}
body.mood-mono .stk-card-4{ border-color: var(--line-strong); background: linear-gradient(170deg, rgba(244,240,232,0.10) 0%, rgba(244,240,232,0.04) 100%); }
body.mood-mono .td-live{ background: rgba(244,240,232,0.08); border-color: var(--line-mid); color: var(--ink); }
body.mood-mono .td-status-active{ background: rgba(244,240,232,0.08); border-color: var(--line-strong) !important; color: var(--ink) !important; }
body.mood-mono .mh-stamp-dot,
body.mood-mono .td-pulse{ background: var(--ink); box-shadow: 0 0 12px rgba(244,240,232,0.4); }

/* modern display swap */
body.display-modern .mh-name,
body.display-modern .mh-cat-name,
body.display-modern .stk-cat-name,
body.display-modern .td-title,
body.display-modern .td-headline,
body.display-modern .stk-cs-v,
body.display-modern .mh-foot-v,
body.display-modern .td-foot-v,
body.display-modern .mh-time-h,
body.display-modern .td-count-n{
  font-family: 'Geist', sans-serif;
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.025em;
}
body.display-modern .mh-cat-name em,
body.display-modern .stk-cat-name em,
body.display-modern .td-title em,
body.display-modern .stk-cs-v em{
  font-style: normal;
  font-weight: 400;
}

/* ============================================================
   WORDMARK LOGO — official Daily Media Group lockup
   ============================================================ */
.brand-wordmark{
  gap: 0;
  display: inline-flex;
  align-items: center;
}
.brand-logo{
  height: 44px;
  width: auto;
  display: block;
  opacity: 0.96;
  transition: opacity 0.35s ease, transform 0.5s cubic-bezier(.2,1,.3,1);
  /* logo is solid white; let it sit on the warm dark canvas as-is */
}
.brand-wordmark:hover .brand-logo{ opacity: 1; }

/* Hero masthead card — wordmark sits where the round mark + name lived */
.mh-id-wordmark{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  grid-column: 1 / -1;
}
.mh-wordmark{
  height: 38px;
  width: auto;
  display: block;
  opacity: 0.95;
}

/* Footer — slightly larger lockup, sits above the descriptive paragraph */
.brand-wordmark-foot{
  margin-bottom: 18px;
}
.brand-logo-foot{
  height: 56px;
}

@media (max-width: 900px){
  .brand-logo{ height: 36px; }
  .mh-wordmark{ height: 32px; }
  .brand-logo-foot{ height: 44px; }
}
@media (max-width: 640px){
  .brand-logo{ height: 30px; }
  .mh-wordmark{ height: 28px; }
  .brand-logo-foot{ height: 38px; }
}

/* ============================================================
   LEADER — editorial "From the company" two-column block
   sits in the hero, between the headline and the marquee
   ============================================================ */
.leader{
  margin-top: 56px;
  max-width: 740px;
}

/* Header strip: rule — eyebrow — rule */
.leader-head{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 18px;
  margin-bottom: 36px;
}
.leader-head .leader-rule{
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line-mid), transparent);
}
.leader-head .leader-rule:first-child{
  background: linear-gradient(to left, var(--line-mid), transparent);
}
.leader-head .leader-rule:last-child{
  background: linear-gradient(to right, var(--line-mid), transparent);
}
.leader-eyebrow{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--muted);
  white-space: nowrap;
}

/* Body grid: col · divider · col */
.leader-body{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  align-items: start;
}

/* Vertical divider with centered asterism */
.leader-divide{
  width: 56px;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
}
.leader-divide::before,
.leader-divide::after{
  content: '';
  flex: 1;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--line-mid) 30%, var(--line-mid) 70%, transparent);
}
.leader-asterism{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  line-height: 1;
  color: var(--amber);
  padding: 14px 0;
  letter-spacing: 0.05em;
  opacity: 0.85;
}

/* Each column */
.leader-col{
  padding: 0 8px;
}
.leader-folio{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 18px;
  color: var(--amber);
  letter-spacing: 0.02em;
  margin-bottom: 6px;
  opacity: 0.92;
}
.leader-h{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0 0 18px;
}
.leader-stop{
  color: var(--amber);
  margin-left: 0.04em;
}
.leader-p{
  font-family: 'Geist', sans-serif;
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-dim);
  margin: 0;
  text-wrap: pretty;
}
.leader-p em{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 1.05em;
  color: var(--ink);
  letter-spacing: -0.005em;
}

/* Drop cap — proper float for inline text wrap */
.leader-p .dropcap{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 54px;
  line-height: 0.85;
  color: var(--amber);
  float: left;
  margin: 6px 10px -2px 0;
  letter-spacing: -0.02em;
}

/* Mobile / tablet — collapse to single column with horizontal divider */
@media (max-width: 880px){
  .leader{ margin-top: 44px; max-width: none; }
  .leader-body{
    grid-template-columns: 1fr;
    gap: 0;
  }
  .leader-col{ padding: 0; }
  .leader-divide{
    width: auto;
    height: 44px;
    flex-direction: row;
  }
  .leader-divide::before,
  .leader-divide::after{
    height: 1px;
    width: auto;
    background: linear-gradient(to right, transparent, var(--line-mid) 30%, var(--line-mid) 70%, transparent);
  }
  .leader-asterism{ padding: 0 14px; }
}

@media (max-width: 560px){
  .leader-h{ font-size: 22px; }
  .leader-p{ font-size: 14.5px; line-height: 1.65; }
  .leader-p .dropcap{ font-size: 44px; margin-right: 8px; }
  .leader-eyebrow{ font-size: 10px; letter-spacing: 0.14em; }
}

/* ============================================================
   PLATFORM SECTION — re-cast as warm dark (was light)
   Redefines on-light tokens locally so all child styles inherit.
   ============================================================ */
.light-section{
  --bg-light: #100d09;             /* slightly deeper than --bg, gives rhythm */
  --ink-on-light: var(--ink);
  --muted-on-light: var(--muted);
  border-bottom: 1px solid var(--line);
}
.light-section::before{
  /* warm ambient glow instead of the cool light gradient */
  background:
    radial-gradient(700px 460px at 12% 18%, rgba(212,165,116,0.10), transparent 60%),
    radial-gradient(560px 380px at 88% 82%, rgba(244,240,232,0.04), transparent 60%) !important;
  opacity: 1;
}
/* Fix principle separators that were hardcoded dark-on-light */
.principle{ border-top-color: var(--line) !important; }
.principle:last-child{ border-bottom-color: var(--line) !important; }
.principle .p-desc{ color: var(--ink-dim); }
.principle .p-desc strong{ color: var(--ink); }

/* ============================================================
   PLATES — typographic + photographic editorial breaks
   ============================================================ */
.plate{
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.plate-type-tight{ padding: 90px 0; }

.pl-rule{
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line-mid) 8%, var(--line-mid) 92%, transparent);
}
.pl-top,
.pl-bot{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 0;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
}
.pl-numeral{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 16px;
  letter-spacing: 0.02em;
  color: var(--amber);
  text-transform: none;
}
.pl-meta{ color: var(--muted); }

.pl-stack{
  padding: 40px 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pl-stack-tight{ padding: 24px 0; gap: 0; }

.pl-line{
  display: grid;
  grid-template-columns: minmax(120px, 18%) 1fr;
  align-items: baseline;
  gap: 36px;
  padding: 18px 0;
}
.pl-stack-tight .pl-line{ padding: 14px 0; }

.pl-k{
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  padding-top: 14px;
  align-self: start;
}
.pl-em{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(54px, 10vw, 140px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.pl-em em{ font-style: italic; }
.pl-amber em{ color: var(--amber); }

/* Plate-photo */
.plate-photo{ padding: 80px 0; }
.plate-photo-frame{
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}
.plate-photo-frame image-slot{
  display: block;
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: 4px;
  overflow: hidden;
}
.pp-caption{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 18px;
  margin-top: 18px;
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  flex-wrap: wrap;
}
.pp-mark{ color: var(--amber); }
.pp-line{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 16px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-dim);
  flex: 1;
  text-align: center;
}

@media (max-width: 720px){
  .plate{ padding: 80px 0; }
  .pl-line{ grid-template-columns: 1fr; gap: 4px; padding: 14px 0; }
  .pl-k{ padding-top: 0; }
  .pp-caption{ gap: 8px; }
  .pp-line{ text-align: left; flex: 0 0 100%; }
}

/* ============================================================
   ORG DIAGRAM — Platform section
   ============================================================ */
.orgdiag{
  margin-top: 40px;
  padding: 36px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(244,240,232,0.025), rgba(244,240,232,0.01));
  backdrop-filter: blur(8px);
}
.orgdiag-head{
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  padding-bottom: 28px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.orgdiag-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-bottom: 10px;
}
.orgdiag-title{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  max-width: 640px;
}
.orgdiag-title em{ font-style: italic; color: var(--amber); }
.orgdiag-meta{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  white-space: nowrap;
}

.orgdiag-board{
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.org-row{ display: grid; gap: 14px; }
.org-row-parent{ grid-template-columns: 1fr; }
.org-row-services{ grid-template-columns: repeat(6, 1fr); }
.org-row-titles{ grid-template-columns: repeat(4, 1fr); }

.org-node{
  position: relative;
  border: 1px solid var(--line-mid);
  border-radius: 12px;
  padding: 22px 20px;
  background: rgba(244,240,232,0.025);
  transition: border-color 0.3s, background 0.3s, transform 0.4s cubic-bezier(.2,1,.3,1);
}
.org-node:hover{
  border-color: var(--line-strong);
  background: rgba(244,240,232,0.05);
  transform: translateY(-2px);
}

/* Parent node */
.org-parent{
  padding: 36px 28px;
  background: linear-gradient(180deg, rgba(212,165,116,0.06), rgba(212,165,116,0.015));
  border-color: rgba(212,165,116,0.32);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.on-corner{
  position: absolute;
  width: 10px; height: 10px;
  border: 1px solid var(--amber);
  opacity: 0.55;
}
.on-corner-tl{ top: 8px; left: 8px; border-right: none; border-bottom: none; }
.on-corner-tr{ top: 8px; right: 8px; border-left: none; border-bottom: none; }
.on-corner-bl{ bottom: 8px; left: 8px; border-right: none; border-top: none; }
.on-corner-br{ bottom: 8px; right: 8px; border-left: none; border-top: none; }
.on-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--amber);
}
.on-title{
  font-family: 'Instrument Serif', serif;
  font-size: clamp(24px, 2.8vw, 38px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.on-title em{ font-style: italic; color: var(--amber); }
.on-sub{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

/* Service nodes */
.org-service{
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 124px;
}
.os-tag{
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
}
.os-name{
  font-family: 'Instrument Serif', serif;
  font-size: 22px;
  line-height: 1.1;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.os-count{
  font-family: 'Geist Mono', monospace;
  font-size: 22px;
  color: var(--amber);
  margin-top: auto;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.os-desc{
  font-family: 'Geist', sans-serif;
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink-dim);
}

/* Title nodes */
.org-title{
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px 20px;
  background: rgba(244,240,232,0.04);
}
.ot-num{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--amber);
}
.ot-name{
  font-family: 'Instrument Serif', serif;
  font-size: 24px;
  line-height: 1.05;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.ot-name em{ font-style: italic; color: var(--amber); }
.ot-cad{
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  margin-top: auto;
  padding-top: 6px;
  border-top: 1px solid var(--line);
}

/* Trunk connectors */
.org-trunk{
  position: relative;
  height: 56px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.org-trunk::before{
  content: '';
  width: 1px;
  height: 100%;
  background: linear-gradient(to bottom, var(--line-mid), var(--line));
  position: absolute;
  left: 50%;
}
.org-trunk-tag{
  position: relative;
  background: var(--bg-light, #100d09);
  padding: 4px 14px;
  font-family: 'Geist Mono', monospace;
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  z-index: 1;
}
.light-section .org-trunk-tag{ background: var(--bg-light); }

.orgdiag-foot{
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 18px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  text-align: center;
}
.orgdiag-foot strong{ color: var(--ink); font-weight: 500; }
.orgdiag-foot-sep{ color: var(--amber); opacity: 0.7; }

@media (max-width: 1080px){
  .org-row-services{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px){
  .orgdiag{ padding: 22px; }
  .org-row-services{ grid-template-columns: repeat(2, 1fr); }
  .org-row-titles{ grid-template-columns: repeat(2, 1fr); }
  .orgdiag-head{ flex-direction: column; align-items: flex-start; }
  .orgdiag-meta{ white-space: normal; }
}

/* ============================================================
   GLOBE SCRUBBER — hour-of-day drag control under the globe
   ============================================================ */
.globe-scrub{
  margin-top: 22px;
  padding: 18px 18px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(244,240,232,0.025);
}
.gs-head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.gs-kicker{
  font-family: 'Geist Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.gs-readout{
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.gs-readout-sep{ color: var(--amber); opacity: 0.7; }
#gsZoneLabel{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 14px;
  color: var(--amber);
  letter-spacing: 0.005em;
}

.gs-track-wrap{
  position: relative;
  padding: 14px 0 6px;
}
.gs-track{
  position: relative;
  height: 4px;
  background: var(--line);
  border-radius: 999px;
  overflow: visible;
}
.gs-track-fill{
  position: absolute;
  inset: 0 auto 0 0;
  width: 26%;
  background: linear-gradient(to right, rgba(212,165,116,0.15), var(--amber));
  border-radius: 999px;
}
.gs-handle{
  position: absolute;
  top: 50%;
  left: 26%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 0 4px rgba(212,165,116,0.18), 0 0 16px rgba(212,165,116,0.45);
  pointer-events: none;
  transition: box-shadow 0.25s;
}
.globe-scrub.is-dragging .gs-handle{
  box-shadow: 0 0 0 6px rgba(212,165,116,0.22), 0 0 22px rgba(212,165,116,0.6);
}

/* Native range slider on top — invisible but interactive */
#gsInput{
  position: absolute;
  inset: 8px 0;
  width: 100%;
  height: 24px;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  cursor: grab;
  margin: 0;
  z-index: 2;
}
#gsInput:active{ cursor: grabbing; }
#gsInput::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: transparent;
  cursor: grab;
}
#gsInput::-moz-range-thumb{
  width: 24px; height: 24px;
  border: none;
  border-radius: 50%;
  background: transparent;
  cursor: grab;
}
#gsInput::-moz-range-track{ background: transparent; }

.gs-ticks{
  position: relative;
  margin-top: 14px;
  height: 16px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.08em;
}
.gs-ticks span{
  position: absolute;
  top: 0;
  transform: translateX(-50%);
}
.gs-ticks span:first-child{ transform: translateX(0); }
.gs-ticks span:last-child{ transform: translateX(-100%); }

.gs-foot{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  font-family: 'Geist', sans-serif;
  font-size: 12.5px;
  color: var(--ink-dim);
}
.gs-foot em{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  color: var(--amber);
  font-size: 13.5px;
}
.gs-foot-dot{
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--amber);
  flex: 0 0 auto;
}

@media (max-width: 640px){
  .gs-head{ flex-direction: column; align-items: flex-start; gap: 6px; }
  .gs-foot{ font-size: 11.5px; }
}

/* Principles wrapper spacing */
.principles{ margin-top: 56px; }
@media (max-width: 720px){ .principles{ margin-top: 40px; } }

/* ============================================================
   METRICS — at-a-glance bar between hero and thesis
   ============================================================ */
.metrics{
  border-bottom: 1px solid var(--line);
}
.metrics-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  max-width: 1360px;
  margin: 0 auto;
}
.metric{
  padding: 60px 40px;
  border-right: 1px solid var(--line);
}
.metric:last-child{ border-right: none; }
.metric .k{
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
}
.metric .k::before{
  content: '';
  width: 5px; height: 5px;
  background: var(--amber);
}
.metric .v{
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-size: clamp(44px, 5.4vw, 76px);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.metric .v .it{
  font-style: italic;
  color: var(--amber);
  margin-left: 4px;
}
.metric .sub{
  margin-top: 14px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
  max-width: 300px;
}
@media (max-width: 820px){
  .metrics-grid{ grid-template-columns: 1fr; }
  .metric{
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 40px 24px;
  }
  .metric:last-child{ border-bottom: none; }
}

/* Metric hover-lift + amber rule underline */
.metric{
  position: relative;
  transition: background 0.4s ease;
}
.metric::after{
  content: '';
  position: absolute;
  left: 40px; right: 40px; bottom: 0;
  height: 1px;
  background: var(--amber);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.7s cubic-bezier(.2,1,.3,1);
}
.metric:hover{ background: rgba(212,165,116,0.025); }
.metric:hover::after{ transform: scaleX(1); }
.metric .v{ transition: color 0.3s ease, transform 0.5s cubic-bezier(.2,1,.3,1); display: inline-block; }
.metric:hover .v{ transform: translateY(-2px); }

/* ============================================================
   IMAGE-SLOT FRAMES — feature strip, team photo, careers photo
   ============================================================ */
.feature-strip{
  padding: 80px 0 100px;
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.feature-strip::before{
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 500px at 20% 30%, rgba(212,165,116,0.05), transparent 60%),
    radial-gradient(700px 400px at 80% 70%, rgba(244,240,232,0.025), transparent 60%);
  pointer-events: none;
}
.feature-strip .wrap{ position: relative; z-index: 1; }
.fs-frame{
  position: relative;
}
.fs-frame image-slot{
  display: block;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 21 / 9;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.fs-caption{
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: baseline;
  margin-top: 22px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
.fs-mark{ color: var(--amber); }
.fs-line{
  text-align: center;
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 18px;
  color: var(--ink-dim);
  letter-spacing: 0;
  text-transform: none;
}
.fs-meta{ text-align: right; }
@media (max-width: 720px){
  .feature-strip{ padding: 50px 0 60px; }
  .fs-frame image-slot{ aspect-ratio: 4 / 3 !important; }
  .fs-caption{ grid-template-columns: 1fr; gap: 6px; }
  .fs-line{ text-align: left; }
  .fs-meta{ text-align: left; }
}

/* Team workspace photo */
.team-photo{
  position: relative;
  margin-bottom: 100px;
}
.team-photo image-slot{
  display: block;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 21 / 9;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.team-photo-cap{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 18px;
  margin-top: 18px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
  flex-wrap: wrap;
}
.tp-mark{ color: var(--amber); }
.tp-line{
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 16px;
  color: var(--ink-dim);
  letter-spacing: 0;
  text-transform: none;
}
@media (max-width: 720px){
  .team-photo{ margin-bottom: 60px; }
  .team-photo image-slot{ aspect-ratio: 4 / 3 !important; }
}

/* Careers workspace photo */
.careers-photo{
  margin-top: 70px;
  margin-bottom: 70px;
}
.careers-photo image-slot{
  display: block;
  width: 100% !important;
  height: auto !important;
  max-width: 1100px;
  margin: 0 auto;
  aspect-ratio: 16 / 7;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--line);
}
@media (max-width: 720px){
  .careers-photo{ margin: 50px 0; }
  .careers-photo image-slot{ aspect-ratio: 4 / 3 !important; }
}

/* ============================================================
   IMAGE-SLOT POLISH — premium feel on placeholders
   subtle inner gradient & corner ornaments before user drops
   ============================================================ */
image-slot{
  background:
    linear-gradient(135deg, rgba(244,240,232,0.04), rgba(244,240,232,0.01)),
    repeating-linear-gradient(
      135deg,
      rgba(244,240,232,0.02) 0,
      rgba(244,240,232,0.02) 12px,
      transparent 12px,
      transparent 24px
    );
  position: relative;
  transition: border-color 0.4s, background 0.4s;
}
image-slot::part(empty),
image-slot::part(placeholder){
  font-family: 'Geist Mono', monospace !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: var(--muted) !important;
}
.fs-frame image-slot:hover,
.team-photo image-slot:hover,
.careers-photo image-slot:hover{
  border-color: rgba(212,165,116,0.45);
}

/* ============================================================
   Skip-to-content link (a11y / SEO)
   ============================================================ */
.skip-link{
  position: fixed;
  top: -100px;
  left: 12px;
  z-index: 9999;
  padding: 10px 16px;
  background: var(--ink);
  color: var(--ink-on-light);
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.04em;
  text-decoration: none;
  border-radius: 4px;
  transition: top 0.2s ease;
}
.skip-link:focus{
  top: 12px;
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}

/* ============================================================
   Per-category accent colors (revision brief #3)
   Each card reads as a distinct vertical at a glance.
   ============================================================ */
.cat{ --accent: #d4a574; --accent-rgb: 212,165,116; }
.cat.acc-amber{ --accent: #d4a574; --accent-rgb: 212,165,116; }   /* Health & Wellness */
.cat.acc-slate{ --accent: #8fb3d9; --accent-rgb: 143,179,217; }   /* Mental Health */
.cat.acc-green{ --accent: #7bbd97; --accent-rgb: 123,189,151; }   /* Professional & B2B */
.cat.acc-gold{  --accent: #d9c27a; --accent-rgb: 217,194,122; }   /* Spirituality & Meaning */
.cat.acc-plum{  --accent: #c79bd0; --accent-rgb: 199,155,208; }   /* Recovery & Inner Life */

/* Distinct header art background per card, derived from its accent */
.cat .cm-bg{
  background:
    radial-gradient(760px 380px at 35% 28%, rgba(var(--accent-rgb), 0.24), transparent 60%),
    linear-gradient(140deg, rgba(var(--accent-rgb), 0.12) 0%, rgba(10,10,10,0.55) 55%, #0a0a0a 100%);
}

/* Accent-tinted hover + accented detail elements */
.cat:hover{ border-color: rgba(var(--accent-rgb), 0.40); }
.cat:hover .cat-name{ color: var(--accent); }
.cat .cat-num{ color: var(--accent); }
.cat .cm-glyph{ color: var(--accent); }
.cat .cm-chart{ color: var(--accent); }
.cat .cm-foot .dot,
.cat .cat-foot .dot{ background: var(--accent); }
.cat .cm-quote{ border-left-color: var(--accent); }
.cat .cmt-bar i{ background: var(--accent); }
.cat .cmt-row span:last-child{ color: var(--accent); }
.cat .cm-sig{ color: var(--accent); }

/* Recovery & Inner Life — concentric "breathing" rings motif */
.cm-rings{
  flex: 1; min-height: 0;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: auto;
  color: var(--accent);
}
.cm-rings svg{ width: 116px; height: 116px; max-height: 100%; }
.cm-rings .rr{
  transform-box: fill-box;
  transform-origin: center;
  animation: ringPulse 4.5s ease-in-out infinite;
}
.cm-rings .rr-2{ animation-delay: 0.6s; }
.cm-rings .rr-3{ animation-delay: 1.2s; }
@keyframes ringPulse{
  0%, 100%{ opacity: 0.45; transform: scale(1); }
  50%{ opacity: 1; transform: scale(1.05); }
}
@media (prefers-reduced-motion: reduce){
  .cm-rings .rr{ animation: none; }
}

/* ============================================================
   Category card photo headers (real imagery)
   ============================================================ */
.cat-mock{
  position: relative;
  height: 290px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.cm-photo{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform 1.1s cubic-bezier(.2,1,.3,1);
}
.cat:hover .cm-photo{ transform: scale(1.08); }
.cm-overlay{
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.50) 0%, transparent 30%, rgba(10,10,10,0.06) 58%, rgba(10,10,10,0.86) 100%),
    radial-gradient(130% 95% at 50% 118%, rgba(var(--accent-rgb), 0.34), transparent 62%);
}
.cat-mock > .cm-top{
  position: absolute; top: 0; left: 0; right: 0;
  z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px;
  margin: 0; border: 0;
}
.cat-mock > .cm-top .cm-glyph{
  color: var(--accent);
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 10px;
  background: rgba(10,10,10,0.48);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(244,240,232,0.16);
}
.cat-mock > .cm-top .cm-stamp{
  color: var(--ink);
  background: rgba(10,10,10,0.48);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(244,240,232,0.16);
  padding: 7px 11px; border-radius: 999px;
  font-size: 9.5px;
}
@media (prefers-reduced-motion: reduce){
  .cm-photo, .cat:hover .cm-photo{ transition: none; transform: none; }
}

/* ============================================================
   Readership portraits (RandomUser, served locally)
   Circular frames; the portrait grows inside on hover.
   ============================================================ */
.audience-cell .a-photo{
  width: 52px; height: 52px;
  border-radius: 50%;
  overflow: hidden;
  flex: 0 0 auto;
  border: 1px solid var(--glass-border);
  background: rgba(244,240,232,0.06);
  position: relative;
}
.audience-cell .a-photo img{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s cubic-bezier(.2,1,.3,1);
}
.audience-cell:hover .a-photo img{ transform: scale(1.18); }
.audience-cell:hover .a-photo{ border-color: rgba(212,165,116,0.5); }
.a-info{ display: flex; flex-direction: column; gap: 8px; min-width: 0; }
@media (prefers-reduced-motion: reduce){
  .audience-cell:hover .a-photo img,
  .ap-avatar:hover{ transform: none; }
}

/* ============================================================
   Team section editorial banner
   ============================================================ */
.team-figure{ margin: 0 0 64px; }
.team-figure-inner{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: 0 40px 90px -50px rgba(0,0,0,0.85), 0 1px 0 rgba(244,240,232,0.08) inset;
  aspect-ratio: 21 / 9;
  background: var(--bg-2);
}
.team-figure-inner img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 50% 38%;
  transition: transform 1.2s cubic-bezier(.2,1,.3,1);
}
.team-figure:hover .team-figure-inner img{ transform: scale(1.04); }
.team-figure-grad{
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,0.20) 0%, transparent 35%, rgba(10,10,10,0.62) 100%);
}
.team-fig-cap{
  position: absolute;
  left: 20px; bottom: 20px; right: 20px;
  display: flex; align-items: center; gap: 9px;
  padding: 10px 15px;
  width: fit-content; max-width: calc(100% - 40px);
  border-radius: 999px;
  background: rgba(10,10,10,0.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-dim);
}
.team-fig-cap em{ font-style: normal; color: var(--amber); }
@media (max-width: 760px){
  .team-figure{ margin-bottom: 44px; }
  .team-figure-inner{ aspect-ratio: 16 / 10; }
}
@media (prefers-reduced-motion: reduce){
  .team-figure:hover .team-figure-inner img{ transform: none; }
}
