/* ============================================================
   NUMI — design system
   ============================================================ */

:root {
  /* Surfaces */
  --bg:        oklch(97% 0.008 80);      /* warm ivory */
  --bg-2:      oklch(94% 0.014 80);      /* deeper cream */
  --bg-3:      oklch(99% 0.005 80);      /* near-white */
  --paper:     oklch(98% 0.006 80);

  /* Ink */
  --ink:       oklch(20% 0.025 295);     /* purple-black */
  --ink-2:     oklch(38% 0.03 295);
  --ink-3:     oklch(55% 0.025 295);
  --ink-4:     oklch(72% 0.02 295);
  --hairline:  oklch(86% 0.015 295);

  /* Brand */
  --purple:        oklch(38% 0.14 300);
  --purple-deep:   oklch(22% 0.10 300);
  --purple-soft:   oklch(88% 0.035 300);
  --purple-tint:   oklch(94% 0.018 300);
  --purple-ink:    oklch(96% 0.02 80);   /* text used on purple bg */

  --gold:          oklch(76% 0.14 82);
  --gold-deep:     oklch(62% 0.13 70);
  --gold-soft:     oklch(92% 0.05 85);

  --radius:    18px;
  --radius-sm: 10px;
  --radius-lg: 28px;

  --shadow-1: 0 1px 0 oklch(85% 0.02 295 / .6), 0 10px 30px -16px oklch(20% 0.10 295 / .18);
  --shadow-2: 0 30px 60px -30px oklch(20% 0.10 295 / .35);

  --maxw: 1280px;
  --maxw-narrow: 980px;
  --pad-x: clamp(20px, 4vw, 56px);

  --font-display: "Cormorant Garamond", "Cormorant", "Source Serif Pro", Georgia, serif;
  --font-body:    "Manrope", ui-sans-serif, system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }

button { font: inherit; cursor: pointer; }

/* ============================================================
   Typography utilities
   ============================================================ */

.display {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.012em;
  line-height: 1.1;
  text-wrap: balance;
}
.display em { font-style: italic; color: var(--purple); font-weight: 400; }

.h-xl  { font-size: clamp(48px, 7.5vw, 112px); }
.h-lg  { font-size: clamp(40px, 5.6vw, 80px); }
.h-md  { font-size: clamp(32px, 3.6vw, 54px); }
.h-sm  { font-size: clamp(24px, 2.4vw, 36px); }

.lede {
  font-size: clamp(17px, 1.4vw, 21px);
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 60ch;
  text-wrap: pretty;
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 22px;
  height: 1px;
  background: currentColor;
  opacity: .55;
}

.section-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--ink-4);
  text-transform: uppercase;
}

/* ============================================================
   Buttons
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  border: 1px solid transparent;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.btn .arr { transition: transform .25s ease; }
.btn:hover .arr { transform: translateX(3px); }

.btn-primary { background: var(--ink); color: var(--bg); }
.btn-primary:hover { background: var(--purple); }

.btn-gold { background: var(--gold); color: var(--purple-deep); }
.btn-gold:hover { background: var(--gold-deep); color: #fff; }

.btn-outline {
  border-color: var(--ink);
  color: var(--ink);
  background: transparent;
}
.btn-outline:hover { background: var(--ink); color: var(--bg); }

.btn-ghost {
  border-color: oklch(85% 0.02 295);
  background: var(--bg-3);
  color: var(--ink);
}
.btn-ghost:hover { border-color: var(--ink); }

.btn-on-dark {
  background: var(--bg);
  color: var(--purple-deep);
}
.btn-on-dark:hover { background: var(--gold); }

.btn-outline-light {
  border: 1px solid oklch(80% 0.03 300 / .45);
  color: var(--bg);
  background: transparent;
}
.btn-outline-light:hover { background: oklch(100% 0 0 / .08); }

/* ============================================================
   Layout
   ============================================================ */

.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}

.container-narrow {
  max-width: var(--maxw-narrow);
  margin: 0 auto;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}

.section { padding: clamp(72px, 9vw, 140px) 0; position: relative; }
.section-tight { padding: clamp(48px, 6vw, 96px) 0; }

.rule {
  height: 1px;
  background: var(--hairline);
  width: 100%;
}

/* ============================================================
   Navigation
   ============================================================ */

.announcement {
  background: var(--purple-deep);
  color: var(--purple-ink);
  font-size: 13px;
  text-align: center;
  padding: 10px 24px;
  letter-spacing: 0.01em;
}
.announcement .dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  margin: 0 12px;
  vertical-align: middle;
}
.announcement a { color: var(--gold); border-bottom: 1px solid oklch(76% 0.14 82 / .4); }

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: oklch(97% 0.008 80 / .82);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--hairline);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 18px 0;
}
.logo {
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 0.18em;
  font-weight: 500;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.logo-mark {
  width: 28px; height: 28px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, var(--gold) 0 30%, transparent 31%),
    radial-gradient(circle at 60% 65%, var(--purple) 0 60%, transparent 61%),
    var(--purple-deep);
  box-shadow: inset 0 0 0 1px oklch(76% 0.14 82 / .6);
}
.nav-links {
  display: flex;
  gap: 28px;
  font-size: 14px;
  color: var(--ink-2);
}
.nav-links a { transition: color .15s; padding: 8px 0; }
.nav-links a:hover { color: var(--purple); }
.nav-links a.active { color: var(--ink); }
.nav-cta { display: flex; gap: 10px; align-items: center; }

/* ============================================================
   Hero
   ============================================================ */

.hero {
  position: relative;
  padding: clamp(72px, 9vw, 140px) 0 clamp(56px, 7vw, 100px);
  overflow: hidden;
  background: var(--bg);
}
.hero::before {
  content: "";
  position: absolute;
  inset: -20% -10% auto auto;
  width: 70vw; height: 70vw;
  background: radial-gradient(circle, oklch(80% 0.10 300 / .25), transparent 60%);
  filter: blur(40px);
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto auto -30% -10%;
  width: 50vw; height: 50vw;
  background: radial-gradient(circle, oklch(80% 0.12 82 / .18), transparent 60%);
  filter: blur(30px);
  pointer-events: none;
}
.hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}
.hero-eyebrow-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.hero-eyebrow-row .pill {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 12px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  color: var(--ink-2);
  background: var(--paper);
}
.hero h1 {
  margin: 0 0 24px;
}
.hero .lede { margin-bottom: 36px; }
.hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}
.hero-meta {
  margin-top: 36px;
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  align-items: center;
}
.hero-meta .stat {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.hero-meta .stat strong {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 500;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: -0.01em;
  text-transform: none;
  display: block;
  line-height: 1;
  margin-bottom: 4px;
}

/* Hero phone wrapper — centers the phone in the hero column */
.hero-phone {
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero-phone .phone-anim {
  width: min(360px, 100%);
}

/* Animation layers */
.hm-ring-outer {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 90s linear infinite;
}
.hm-ring-mid {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 50s linear infinite reverse;
}
.hm-ring-inner {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 30s linear infinite;
}
.hm-orbit-1 {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 18s linear infinite;
}
.hm-orbit-2 {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 24s linear infinite reverse;
}
.hm-orbit-3 {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 36s linear infinite;
}
.hm-orbit-4 {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 22s linear infinite reverse;
}
.hm-shimmer {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-spin 14s linear infinite;
  mix-blend-mode: screen;
}
.hm-core {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-breathe 6s ease-in-out infinite;
}
.hm-aura {
  transform-origin: 300px 300px;
  transform-box: fill-box;
  animation: hm-aura-pulse 5s ease-in-out infinite alternate;
}
.hm-spark {
  animation: hm-spark 3s ease-in-out infinite;
}

@keyframes hm-spin   { to { transform: rotate(360deg); } }
@keyframes hm-breathe {
  0%, 100% { transform: scale(1);    filter: brightness(1); }
  50%      { transform: scale(1.025); filter: brightness(1.06); }
}
@keyframes hm-aura-pulse {
  0%   { opacity: .55; transform: scale(.96); }
  100% { opacity: 1;   transform: scale(1.08); }
}
@keyframes hm-spark {
  0%, 100% { opacity: .6; }
  50%      { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .hm-ring-outer, .hm-ring-mid, .hm-ring-inner,
  .hm-orbit-1, .hm-orbit-2, .hm-orbit-3, .hm-orbit-4,
  .hm-shimmer, .hm-core, .hm-aura, .hm-spark {
    animation: none !important;
  }
}

/* ============================================================
   Trust bar
   ============================================================ */

.trustbar {
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 32px 0;
  background: var(--paper);
}
.trustbar-inner {
  display: flex;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
  justify-content: space-between;
}
.trustbar .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  max-width: 200px;
}
.trustbar .logos {
  display: flex;
  gap: clamp(28px, 4vw, 56px);
  flex-wrap: wrap;
  align-items: center;
}
.logo-chip {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  font-weight: 500;
  opacity: .8;
  transition: opacity .2s, color .2s;
}
.logo-chip:hover { opacity: 1; color: var(--ink); }
.logo-chip .small {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  display: block;
  color: var(--ink-4);
  text-transform: uppercase;
  margin-top: 2px;
  font-weight: 400;
}

/* ============================================================
   Section header (eyebrow + huge headline)
   ============================================================ */

.sec-head {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(24px, 4vw, 64px);
  margin-bottom: clamp(40px, 5vw, 72px);
  align-items: end;
}
.sec-head .left .section-num { display: block; margin-bottom: 12px; }
.sec-head .left .eyebrow { color: var(--purple); }
.sec-head .right h2 { margin: 0; }
.sec-head .right .lede { margin-top: 18px; }

/* ============================================================
   Why NUMI / problem
   ============================================================ */

.why { background: var(--bg); }
.why .pull {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.18;
  max-width: 22ch;
  text-wrap: balance;
  color: var(--ink);
}
.why .pull em { font-style: italic; color: var(--purple); }
.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  margin-top: clamp(48px, 6vw, 80px);
  border-top: 1px solid var(--hairline);
  padding-top: 48px;
}
.why-grid .item {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.why-grid .item .n {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--gold-deep);
  text-transform: uppercase;
}
.why-grid .item h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 26px;
  margin: 0;
  line-height: 1.15;
}
.why-grid .item p {
  margin: 0;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.55;
}

/* ============================================================
   Four pillars
   ============================================================ */

.pillars { background: var(--bg-2); }
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}
.pillar {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3.5vw, 44px);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.pillar:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-1);
  border-color: oklch(78% 0.04 300);
}
.pillar .glyph {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--purple-tint);
  display: grid; place-items: center;
  position: relative;
}
.pillar .glyph::before {
  content: "";
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--purple);
}
.pillar .glyph::after {
  content: "";
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--gold);
  top: 14px; right: 14px;
}
.pillar.p-wealth .glyph::after  { background: var(--gold); }
.pillar.p-rel    .glyph::after  { background: oklch(70% 0.16 350); }
.pillar.p-health .glyph::after  { background: oklch(75% 0.14 160); }
.pillar.p-biz    .glyph::after  { background: var(--purple); }

.pillar .num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink-4);
  text-transform: uppercase;
  position: absolute;
  top: 24px; right: 24px;
}
.pillar h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(28px, 2.6vw, 38px);
  margin: 0;
  line-height: 1.1;
}
.pillar p {
  margin: 0;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.6;
  max-width: 50ch;
}
.pillar ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}
.pillar ul li {
  font-size: 14px;
  color: var(--ink-2);
  padding-left: 22px;
  position: relative;
}
.pillar ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 9px;
  width: 12px; height: 1px;
  background: var(--gold-deep);
}

/* ============================================================
   How it works (journey)
   ============================================================ */

.journey { background: var(--bg); }
.journey-rail {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  position: relative;
  margin-top: 32px;
}
.journey-rail::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 26px;
  height: 1px;
  background: repeating-linear-gradient(to right, var(--hairline) 0 6px, transparent 6px 12px);
}
.step {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  padding-top: 0;
}
.step .badge {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--paper);
  border: 1px solid var(--hairline);
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--purple);
  position: relative;
  z-index: 1;
}
.step .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.step h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
  margin: 0;
  line-height: 1.15;
}
.step p {
  margin: 0;
  font-size: 14.5px;
  color: var(--ink-2);
  line-height: 1.55;
}

/* ============================================================
   App preview
   ============================================================ */

.app {
  background:
    radial-gradient(60% 80% at 80% 20%, oklch(50% 0.14 300 / .12), transparent 60%),
    radial-gradient(50% 60% at 0% 80%, oklch(76% 0.14 82 / .12), transparent 60%),
    var(--bg);
}
.app-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}
.app-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 28px;
  margin-top: 36px;
}
.feat {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--hairline);
}
.feat .k {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--purple);
  text-transform: uppercase;
}
.feat h5 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
}
.feat p {
  margin: 0;
  font-size: 14.5px;
  color: var(--ink-2);
  line-height: 1.5;
}

.phone {
  position: relative;
  width: min(360px, 100%);
  margin: 0 auto;
  aspect-ratio: 9 / 18.5;
  background: var(--ink);
  border-radius: 44px;
  padding: 14px;
  box-shadow: var(--shadow-2);
}
.phone::before {
  content: "";
  position: absolute;
  top: 26px; left: 50%;
  transform: translateX(-50%);
  width: 110px; height: 28px;
  background: oklch(15% 0.02 295);
  border-radius: 999px;
  z-index: 3;
}
.phone-screen {
  position: relative;
  width: 100%; height: 100%;
  border-radius: 32px;
  overflow: hidden;
  background:
    radial-gradient(120% 80% at 50% 0%, oklch(50% 0.14 300) 0%, oklch(22% 0.10 300) 60%, oklch(18% 0.08 300) 100%);
  display: flex;
  flex-direction: column;
  padding: 60px 20px 22px;
  color: oklch(96% 0.02 80);
}
.phone-screen .top {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(80% 0.05 82 / .7);
  margin-bottom: 4px;
}
.phone-screen .greeting {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.15;
  margin-bottom: 18px;
  font-weight: 500;
}
.phone-screen .greeting em { color: var(--gold); font-style: italic; }
.phone-orb {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, oklch(94% 0.06 82 / .8), transparent 55%),
    radial-gradient(circle at 65% 75%, oklch(70% 0.14 320 / .7), transparent 60%),
    radial-gradient(circle, oklch(76% 0.14 82 / .3), oklch(38% 0.14 300 / .2));
  margin: 4px auto 16px;
  box-shadow:
    inset 0 0 0 1px oklch(94% 0.06 82 / .35),
    inset 0 -20px 50px oklch(22% 0.10 300 / .7);
  max-width: 70%;
}
.phone-cards {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: auto;
}
.phone-card {
  background: oklch(100% 0 0 / .07);
  border: 1px solid oklch(94% 0.04 82 / .15);
  border-radius: 12px;
  padding: 10px 12px;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11.5px;
}
.phone-card .name { font-family: var(--font-display); font-size: 14px; }
.phone-card .val  { font-family: var(--font-mono); font-size: 10.5px; color: var(--gold); letter-spacing: 0.1em; }

/* ============================================================
   Academy + Products (split rows)
   ============================================================ */

.split { background: var(--bg-2); }
.split-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
}
.split-row + .split-row { margin-top: clamp(64px, 8vw, 120px); }
.split-row.reverse .split-media { order: 2; }
.split-media {
  aspect-ratio: 4 / 3.4;
  border-radius: var(--radius-lg);
  background: var(--paper);
  border: 1px solid var(--hairline);
  position: relative;
  overflow: hidden;
}
.split-media.academy-art {
  background:
    radial-gradient(140% 90% at 50% 0%, oklch(50% 0.14 300) 0%, oklch(28% 0.10 300) 55%, oklch(20% 0.10 300) 100%);
  overflow: hidden;
}
.split-media.academy-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(.9) contrast(1.02);
  transition: transform 1.2s ease;
}
.split-media.academy-art:hover img {
  transform: scale(1.03);
}
.split-media.products-art {
  background:
    linear-gradient(180deg, oklch(96% 0.03 85), oklch(90% 0.05 85)),
    var(--paper);
}
.split-media .placeholder-tag {
  position: absolute; left: 18px; bottom: 16px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(94% 0.04 82 / .7);
  background: oklch(20% 0.05 295 / .35);
  padding: 6px 10px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
}
.split-media.products-art .placeholder-tag { color: var(--ink-3); background: oklch(100% 0 0 / .6); }
.split-media .stripes {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg,
    oklch(100% 0 0 / .06) 0 2px,
    transparent 2px 14px);
}
.split-media .floater {
  position: absolute;
  border-radius: 50%;
}
.split-media .floater.f1 {
  width: 60%; aspect-ratio: 1;
  top: 18%; left: 20%;
  background: radial-gradient(circle at 35% 35%, oklch(94% 0.06 82 / .85), oklch(76% 0.14 82 / .2) 60%, transparent 70%);
}
.split-media.products-art .floater.f1 {
  width: 50%; top: 12%; left: 12%;
  background: radial-gradient(circle, oklch(86% 0.06 295), oklch(70% 0.08 295) 60%, transparent 70%);
  box-shadow: 0 30px 60px -20px oklch(40% 0.08 295 / .35);
}
.split-media.products-art .floater.f2 {
  width: 38%; aspect-ratio: 1; top: 38%; right: 14%;
  background: radial-gradient(circle, var(--gold), var(--gold-deep) 60%, transparent 70%);
  box-shadow: 0 20px 50px -20px oklch(60% 0.13 70 / .5);
}
.split-media.products-art .floater.f3 {
  width: 32%; aspect-ratio: 1; bottom: 8%; left: 28%;
  background: radial-gradient(circle, oklch(82% 0.08 300), oklch(62% 0.12 300) 60%, transparent 70%);
}

.split-copy .eyebrow { color: var(--purple); }
.split-copy h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(34px, 3.6vw, 54px);
  margin: 18px 0 22px;
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.split-copy p { color: var(--ink-2); max-width: 50ch; font-size: 16px; }
.split-copy .tags {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 22px;
}
.split-copy .tags span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  color: var(--ink-2);
  background: var(--paper);
}
.split-copy .btn { margin-top: 32px; }

/* ============================================================
   Partner pathway
   ============================================================ */

.partner {
  background:
    radial-gradient(70% 90% at 80% 30%, oklch(40% 0.14 300) 0%, oklch(22% 0.10 300) 60%, oklch(18% 0.08 300) 100%);
  color: oklch(96% 0.02 80);
  position: relative;
  overflow: hidden;
}
.partner::before {
  content: "";
  position: absolute;
  width: 600px; height: 600px;
  top: -200px; left: -150px;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(76% 0.14 82 / .14), transparent 65%);
  filter: blur(20px);
}
.partner-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  position: relative;
}
.partner-copy .eyebrow { color: var(--gold); }
.partner-copy .eyebrow::before { background: var(--gold); }
.partner-copy h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 72px);
  margin: 16px 0 24px;
  line-height: 1.02;
  letter-spacing: -0.01em;
}
.partner-copy h2 em { color: var(--gold); font-style: italic; }
.partner-copy p { color: oklch(96% 0.02 80 / .75); max-width: 50ch; }
.partner-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 36px;
}
.partner-list li {
  list-style: none;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 0;
  border-top: 1px solid oklch(80% 0.04 300 / .15);
  font-size: 14.5px;
  color: oklch(96% 0.02 80 / .85);
}
.partner-list li::before {
  content: "";
  width: 8px; height: 8px;
  margin-top: 9px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.partner-card {
  background: oklch(100% 0 0 / .04);
  border: 1px solid oklch(80% 0.04 300 / .2);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.partner-card .tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}
.partner-card h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  margin: 0;
  color: oklch(96% 0.02 80);
}
.partner-card .row {
  display: flex; justify-content: space-between;
  font-size: 14px;
  padding: 10px 0;
  border-top: 1px solid oklch(80% 0.04 300 / .15);
  color: oklch(96% 0.02 80 / .8);
}
.partner-card .row span:last-child { color: var(--gold); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; }
.partner .btn { margin-top: 28px; }

/* ============================================================
   Testimonials
   ============================================================ */

.testimonials { background: var(--bg); }
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.testi {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 2.6vw, 34px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
}
.testi .stars {
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.16em;
  color: var(--gold-deep);
}
.testi blockquote {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.3;
  color: var(--ink);
  text-wrap: pretty;
  flex: 1;
}
.testi .person {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--hairline);
}
.testi .avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, oklch(94% 0.04 82), oklch(70% 0.10 82) 70%),
    var(--paper);
  border: 1px solid var(--hairline);
  flex-shrink: 0;
}
.testi .avatar.b { background: radial-gradient(circle at 35% 30%, oklch(90% 0.04 300), oklch(60% 0.12 300) 70%); }
.testi .avatar.c { background: radial-gradient(circle at 35% 30%, oklch(90% 0.04 160), oklch(60% 0.12 160) 70%); }
.testi .who {
  display: flex; flex-direction: column;
}
.testi .who strong { font-weight: 600; font-size: 14px; }
.testi .who span { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.08em; }

/* ============================================================
   Vision band
   ============================================================ */

.vision {
  background: var(--paper);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.vision-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
}
.vision-grid .left .eyebrow { color: var(--purple); }
.vision-grid .right .lede {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.3;
  color: var(--ink);
  max-width: 36ch;
}
.vision-grid .right .lede em { color: var(--purple); font-style: italic; }
.vision-signature {
  margin-top: 32px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: var(--ink-3);
  text-transform: uppercase;
}

/* ============================================================
   FAQ
   ============================================================ */

.faq { background: var(--bg); }
.faq-list {
  border-top: 1px solid var(--hairline);
}
.faq-item {
  border-bottom: 1px solid var(--hairline);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 26px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(20px, 1.8vw, 26px);
  color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item .icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--hairline);
  display: grid; place-items: center;
  flex-shrink: 0;
  transition: transform .3s ease, background .2s ease, border-color .2s ease;
  position: relative;
}
.faq-item .icon::before, .faq-item .icon::after {
  content: ""; position: absolute;
  background: var(--ink);
}
.faq-item .icon::before { width: 12px; height: 1.2px; }
.faq-item .icon::after  { width: 1.2px; height: 12px; transition: opacity .2s; }
.faq-item[open] .icon { background: var(--purple); border-color: var(--purple); }
.faq-item[open] .icon::before, .faq-item[open] .icon::after { background: var(--bg); }
.faq-item[open] .icon::after { opacity: 0; }
.faq-item .body {
  color: var(--ink-2);
  font-size: 16px;
  line-height: 1.6;
  padding: 0 60px 28px 0;
  max-width: 75ch;
}

/* ============================================================
   Final CTA
   ============================================================ */

.final-cta {
  background:
    radial-gradient(60% 80% at 20% 30%, oklch(50% 0.14 300) 0%, oklch(22% 0.10 300) 55%, oklch(16% 0.07 300) 100%);
  color: oklch(96% 0.02 80);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.final-cta::before {
  content: "";
  position: absolute;
  inset: -10% -10% auto auto;
  width: 60vw; height: 60vw;
  background: radial-gradient(circle, oklch(76% 0.14 82 / .14), transparent 60%);
  filter: blur(40px);
}
.final-cta .container { position: relative; }
.final-cta .eyebrow { color: var(--gold); }
.final-cta .eyebrow::before { background: var(--gold); }
.final-cta h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(48px, 7vw, 104px);
  line-height: 1.0;
  letter-spacing: -0.015em;
  margin: 24px auto 28px;
  max-width: 18ch;
  text-wrap: balance;
}
.final-cta h2 em { color: var(--gold); font-style: italic; }
.final-cta p { color: oklch(96% 0.02 80 / .75); max-width: 56ch; margin: 0 auto; }
.final-cta .ctas { margin-top: 40px; display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.final-cta .mascot-cameo {
  width: 200px; height: 200px;
  margin: 12px auto 32px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, oklch(94% 0.06 82 / .9), transparent 55%),
    radial-gradient(circle at 65% 75%, oklch(70% 0.14 320 / .7), transparent 60%),
    radial-gradient(circle, oklch(76% 0.14 82 / .35), oklch(38% 0.14 300 / .2));
  box-shadow:
    inset 0 0 0 1px oklch(94% 0.06 82 / .5),
    inset 0 -30px 60px oklch(22% 0.10 300 / .6),
    0 30px 80px oklch(20% 0.10 295 / .4);
}

/* ============================================================
   Footer
   ============================================================ */

.footer {
  background: var(--ink);
  color: oklch(80% 0.02 295);
  padding: clamp(56px, 7vw, 96px) 0 32px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 56px;
}
.footer .logo { color: oklch(96% 0.02 80); }
.footer-tagline {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.25;
  max-width: 28ch;
  margin: 18px 0 28px;
  color: oklch(96% 0.02 80);
}
.footer-col h4 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 18px;
  font-weight: 500;
}
.footer-col a {
  display: block;
  padding: 6px 0;
  font-size: 14.5px;
  color: oklch(80% 0.02 295);
  transition: color .15s;
}
.footer-col a:hover { color: var(--gold); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 24px;
  border-top: 1px solid oklch(40% 0.04 295);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: oklch(70% 0.02 295);
}

/* ============================================================
   Pillar glyph SVGs — geometric primitives (upgraded from CSS dots)
   ============================================================ */

.pillar .glyph {
  width: 80px; height: 80px;
  border-radius: 0;
  background: transparent;
  display: block;
}
.pillar .glyph::before,
.pillar .glyph::after { content: none; }
.pillar .glyph svg { width: 100%; height: 100%; display: block; }

.g-ring   { fill: none; stroke: var(--purple); stroke-width: 1.4; }
.g-square { fill: none; stroke: var(--purple); stroke-width: 1.4; }
.g-dot-g  { fill: var(--gold); }
.g-dot-p  { fill: var(--purple); }
.g-dot-r  { fill: oklch(70% 0.16 350); }
.g-dot-h  { fill: oklch(75% 0.14 160); }

/* ============================================================
   Pattern diagram — signature illustration
   ============================================================ */

.diagram {
  background: var(--bg);
  position: relative;
}
.diagram::before {
  content: "";
  position: absolute;
  inset: 10% 5% auto auto;
  width: 30vw; height: 30vw;
  background: radial-gradient(circle, oklch(80% 0.10 82 / .18), transparent 60%);
  filter: blur(40px);
  pointer-events: none;
}
.diagram-wrap {
  display: flex;
  justify-content: center;
  margin-top: clamp(40px, 5vw, 64px);
  position: relative;
}
.diagram-svg {
  width: 100%;
  max-width: 720px;
  height: auto;
  display: block;
}
.pd-ring   { fill: none; stroke: var(--hairline); }
.pd-mid    { fill: none; stroke: var(--purple); opacity: .35; }
.pd-tick   { stroke: var(--purple); stroke-width: 1.2; }
.pd-line   { stroke: var(--purple); stroke-width: 1; opacity: .35; }
.pd-node   { fill: var(--paper); stroke: var(--purple); stroke-width: 1.4; }
.pd-dot-g  { fill: var(--gold); }
.pd-dot-p  { fill: var(--purple); }
.pd-dot-r  { fill: oklch(70% 0.16 350); }
.pd-dot-h  { fill: oklch(75% 0.14 160); }
.pd-label {
  fill: var(--ink-2);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 3px;
  font-weight: 500;
}
.pd-center-ring { fill: none; stroke: var(--gold); opacity: .55; stroke-width: 1; }
.pd-center-text {
  fill: oklch(96% 0.04 80);
  font-family: var(--font-display);
  font-size: 32px;
  letter-spacing: 6px;
  font-style: italic;
  font-weight: 500;
}
[data-theme="dark"] .pd-node { fill: var(--bg-2); }
[data-theme="dark"] .pd-label { fill: var(--ink-2); }

/* ============================================================
   Photo strip (lifestyle / events placeholder)
   ============================================================ */

.photos { background: var(--bg-2); }
.photos-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: 18px;
  margin-top: clamp(40px, 5vw, 64px);
}
.photo-tile {
  position: relative;
  aspect-ratio: 4 / 3.2;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--hairline);
}
.photo-tile.tall { aspect-ratio: 4 / 5; }
.photo-tile.warm {
  background: linear-gradient(180deg, oklch(94% 0.04 80), oklch(86% 0.06 80));
}
.photo-tile.purple {
  background: radial-gradient(120% 90% at 50% 0%, oklch(50% 0.14 300) 0%, oklch(28% 0.10 300) 60%, oklch(22% 0.10 300) 100%);
}
[data-theme="dark"] .photo-tile.warm {
  background: linear-gradient(180deg, oklch(26% 0.04 80), oklch(20% 0.03 80));
}
.photo-tile .stripes {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg,
    oklch(100% 0 0 / .10) 0 2px,
    transparent 2px 14px);
  pointer-events: none;
}
.photo-tile .ph-tag {
  position: absolute; left: 18px; bottom: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: var(--paper);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
}
.photo-tile.purple .ph-tag {
  color: oklch(94% 0.04 82 / .9);
  background: oklch(20% 0.05 295 / .45);
  border-color: oklch(60% 0.08 300 / .3);
}
.photo-tile .floater {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.photo-tile.purple .floater.f1 {
  width: 55%; aspect-ratio: 1; top: 18%; left: 22%;
  background: radial-gradient(circle at 35% 35%, oklch(94% 0.06 82 / .8), oklch(76% 0.14 82 / .2) 60%, transparent 70%);
}
.photo-tile.warm .floater.f1 {
  width: 45%; aspect-ratio: 1; top: 22%; left: 18%;
  background: radial-gradient(circle, oklch(86% 0.04 295), oklch(70% 0.08 295) 60%, transparent 70%);
}
.photo-tile.warm .floater.f2 {
  width: 28%; aspect-ratio: 1; bottom: 12%; right: 18%;
  background: radial-gradient(circle, var(--gold), var(--gold-deep) 60%, transparent 70%);
}

/* ============================================================
   Ornament dividers
   ============================================================ */

.ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  padding: 24px 0 0;
}
.ornament .l, .ornament .r {
  height: 1px;
  background: var(--hairline);
  flex: 0 1 220px;
}
.ornament .mark {
  width: 12px; height: 12px;
  border: 1px solid var(--purple);
  transform: rotate(45deg);
  display: grid;
  place-items: center;
}
.ornament .mark::before {
  content: "";
  width: 4px; height: 4px;
  background: var(--gold);
  display: block;
}

/* ============================================================
   Responsive
   ============================================================ */

/* ============================================================
   Logo (real image)
   ============================================================ */

.logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}
.logo img {
  height: 32px;
  width: auto;
  display: block;
  transition: filter .25s ease;
}
/* Logo is dark — invert in dark mode so it reads on the dark bg */
[data-theme="dark"] .logo img {
  filter: invert(1) hue-rotate(180deg) brightness(1.05);
}
/* Footer logo always sits on dark, invert there */
.footer .logo img { filter: invert(1) hue-rotate(180deg) brightness(1.05); }

.spline-phone {
  position: relative;
  width: min(420px, 100%);
  margin: 0 auto;
  aspect-ratio: 9 / 18.5;
  border-radius: 44px;
  overflow: hidden;
  background: transparent;
}
.spline-phone iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: transparent;
}
.spline-phone .spline-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  background: var(--bg-2);
  border: 1px dashed var(--purple);
  border-radius: 44px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: var(--ink-3);
  text-transform: uppercase;
  z-index: -1;
}
.spline-phone .spline-fallback strong {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--purple);
  margin-bottom: 8px;
}

.type-word {
  color: var(--purple);
  font-style: italic;
  font-weight: 400;
  white-space: nowrap;
}
.type-caret {
  display: inline-block;
  width: 4px;
  height: 0.78em;
  background: var(--purple);
  vertical-align: -0.04em;
  margin-left: 6px;
  border-radius: 2px;
  animation: caret-blink 1s steps(2, start) infinite;
}
@keyframes caret-blink {
  50% { opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .type-caret { animation: none; }
}

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   Theme toggle button
   ============================================================ */

.theme-toggle {
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1px solid var(--hairline);
  background: var(--paper);
  color: var(--ink);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s, transform .2s;
  flex-shrink: 0;
}
.theme-toggle:hover { border-color: var(--ink); transform: translateY(-1px); }
.theme-toggle svg { width: 18px; height: 18px; display: block; }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* Smooth cross-fade between themes for the most visible surfaces */
body, .nav, .trustbar, .footer,
.pillar, .testi, .f-card, .bento .cell,
.split-media.products-art, .ew-card,
.person-card, .partner-card,
.compare-table, .compare-row > div,
.btn, .theme-toggle, .logo-chip,
.faq-item .icon, .faq-item .icon::before, .faq-item .icon::after,
.hero-eyebrow-row .pill, .split-copy .tags span,
.step .badge {
  transition: background-color .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
}

/* ============================================================
   Dark theme
   ============================================================ */

:root[data-theme="dark"] {
  /* Surfaces — warm purple-black */
  --bg:        oklch(15% 0.018 295);
  --bg-2:      oklch(18% 0.025 295);
  --bg-3:      oklch(13% 0.014 295);
  --paper:     oklch(20% 0.028 295);

  /* Ink — warm cream on dark */
  --ink:       oklch(96% 0.015 80);
  --ink-2:     oklch(82% 0.020 295);
  --ink-3:     oklch(65% 0.020 295);
  --ink-4:     oklch(50% 0.020 295);
  --hairline:  oklch(28% 0.030 295);

  /* Brand — lift purple, brighten gold for legibility on dark */
  --purple:        oklch(72% 0.14 300);
  --purple-soft:   oklch(35% 0.10 300);
  --purple-tint:   oklch(28% 0.07 300);

  --gold:          oklch(82% 0.13 82);
  --gold-deep:     oklch(74% 0.13 75);
  --gold-soft:     oklch(38% 0.08 85);

  --shadow-1: 0 1px 0 oklch(35% 0.04 295 / .5), 0 10px 30px -16px oklch(0% 0 0 / .55);
  --shadow-2: 0 30px 60px -30px oklch(0% 0 0 / .65);
}

/* Sticky nav — translucent over dark bg */
[data-theme="dark"] .nav {
  background: oklch(15% 0.018 295 / .82);
  border-bottom-color: oklch(25% 0.03 295);
}

/* Logo mark gets a little more glow in dark mode */
[data-theme="dark"] .logo-mark {
  box-shadow: inset 0 0 0 1px oklch(82% 0.13 82 / .7), 0 0 18px oklch(72% 0.14 300 / .35);
}

/* Hero ambient glows — slightly more saturated to read on dark */
[data-theme="dark"] .hero::before {
  background: radial-gradient(circle, oklch(60% 0.18 300 / .35), transparent 60%);
}
[data-theme="dark"] .hero::after {
  background: radial-gradient(circle, oklch(72% 0.14 82 / .18), transparent 60%);
}

/* Mascot container — keep dark, add subtle ring for separation from dark bg */
[data-theme="dark"] .hero-mascot {
  box-shadow: var(--shadow-2), 0 0 0 1px oklch(40% 0.06 295 / .35);
}

/* Trust bar — paper surface already covers; lift label */
[data-theme="dark"] .trustbar { background: var(--bg-2); }
[data-theme="dark"] .logo-chip { color: oklch(78% 0.02 295); }
[data-theme="dark"] .logo-chip .small { color: oklch(60% 0.02 295); }

/* Pillar glyph rings — purple lifts in dark */
[data-theme="dark"] .pillar .glyph::before { border-color: var(--purple); }

/* Journey badges */
[data-theme="dark"] .step .badge { background: var(--bg-2); color: var(--purple); }

/* App section ambient */
[data-theme="dark"] .app {
  background:
    radial-gradient(60% 80% at 80% 20%, oklch(50% 0.16 300 / .18), transparent 60%),
    radial-gradient(50% 60% at 0% 80%, oklch(72% 0.14 82 / .10), transparent 60%),
    var(--bg);
}

/* About hero & app hero ambient */
[data-theme="dark"] .about-hero,
[data-theme="dark"] .app-hero {
  background:
    radial-gradient(60% 80% at 80% 10%, oklch(50% 0.16 300 / .30), transparent 60%),
    radial-gradient(40% 60% at 0% 90%, oklch(72% 0.14 82 / .14), transparent 60%),
    var(--bg);
}

/* Products media — warm dark wash instead of cream */
[data-theme="dark"] .split-media.products-art {
  background: linear-gradient(180deg, oklch(24% 0.04 80), oklch(18% 0.03 80));
}
[data-theme="dark"] .split-media.products-art .placeholder-tag {
  color: oklch(90% 0.05 82);
  background: oklch(15% 0.05 295 / .5);
}
[data-theme="dark"] .split-media.products-art .floater.f1 {
  background: radial-gradient(circle, oklch(70% 0.06 295), oklch(45% 0.08 295) 60%, transparent 70%);
}
[data-theme="dark"] .split-media.products-art .floater.f3 {
  background: radial-gradient(circle, oklch(60% 0.10 300), oklch(40% 0.12 300) 60%, transparent 70%);
}

/* East-meets-West light card stays as a "lifted" paper */
[data-theme="dark"] .ew-card:not(.dark) {
  background: var(--bg-2);
}

/* Vision band — keep as a lighter band on dark */
[data-theme="dark"] .vision { background: var(--bg-2); }

/* FAQ icon plus/cross uses var(--ink) which is now light — good. */

/* Primary button: in light mode = dark; in dark mode = light pill on dark — good. */
/* But hover→purple needs darker text against the lifted purple */
[data-theme="dark"] .btn-primary:hover { color: oklch(15% 0.018 295); }

/* Ghost button visibility on dark */
[data-theme="dark"] .btn-ghost {
  background: var(--bg-2);
  border-color: var(--hairline);
}
[data-theme="dark"] .btn-ghost:hover { border-color: var(--ink); }

/* Footer — must stay dark in both themes */
[data-theme="dark"] .footer {
  background: oklch(9% 0.012 295);
  color: oklch(76% 0.02 295);
}
[data-theme="dark"] .footer-bottom {
  border-top-color: oklch(24% 0.03 295);
  color: oklch(58% 0.02 295);
}

/* Announcement bar is brand-purple in both themes — fine. */

/* Compare table x-mark color in dark mode */
[data-theme="dark"] .compare-row .x { color: var(--ink-4); }

@media (max-width: 980px) {
  .nav-links { display: none; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-mascot { aspect-ratio: 4 / 3.2; max-width: 480px; margin: 0 auto; }
  .sec-head { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; gap: 24px; }
  .pillars-grid { grid-template-columns: 1fr; }
  .journey-rail { grid-template-columns: 1fr 1fr; gap: 28px 20px; }
  .journey-rail::before { display: none; }
  .app-grid { grid-template-columns: 1fr; }
  .app-features { grid-template-columns: 1fr 1fr; }
  .split-row { grid-template-columns: 1fr; }
  .split-row.reverse .split-media { order: 0; }
  .partner-grid { grid-template-columns: 1fr; }
  .partner-list { grid-template-columns: 1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .vision-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .photos-grid { grid-template-columns: 1fr; }
  .photo-tile.tall { aspect-ratio: 4 / 3.2; }
  .diagram-svg { max-width: 560px; }
}

@media (max-width: 560px) {
  .trustbar-inner { gap: 24px; }
  .trustbar .logos { gap: 22px; }
  .logo-chip { font-size: 18px; }
  .footer-grid { grid-template-columns: 1fr; }
  .app-features { grid-template-columns: 1fr; }
  .hero-meta { gap: 18px; }
}


/* ============================================================
   Animated phone mockup
   ============================================================ */

.phone-anim {
  position: relative;
  width: min(380px, 100%);
  margin: 0 auto;
  aspect-ratio: 9 / 18.5;
  --phone-bezel: oklch(14% 0.02 295);
  --phone-screen-1: oklch(50% 0.16 300);
  --phone-screen-2: oklch(22% 0.10 300);
  --phone-screen-3: oklch(16% 0.07 300);
  animation: phone-float 7s ease-in-out infinite;
  filter: drop-shadow(0 40px 60px oklch(20% 0.10 295 / .35));
}
.phone-anim.big { width: min(420px, 100%); }

@keyframes phone-float {
  0%, 100% { transform: translateY(0) rotate(-0.4deg); }
  50%      { transform: translateY(-14px) rotate(0.4deg); }
}

.phone-anim::before {
  content: "";
  position: absolute;
  inset: -10% -18% -6% -18%;
  z-index: 0;
  background:
    radial-gradient(60% 50% at 50% 40%, oklch(60% 0.16 300 / .35), transparent 60%),
    radial-gradient(40% 30% at 30% 70%, oklch(76% 0.14 82 / .25), transparent 60%);
  filter: blur(40px);
  animation: phone-aura 6s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes phone-aura {
  0%   { opacity: .6; transform: scale(.96); }
  100% { opacity: 1;  transform: scale(1.04); }
}

.phone-anim .pa-bezel {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: var(--phone-bezel);
  border-radius: 44px;
  padding: 12px;
  box-shadow:
    inset 0 0 0 1.5px oklch(35% 0.04 295),
    inset 0 0 0 3px oklch(8% 0.01 295),
    0 0 0 1px oklch(0% 0 0 / .5);
}
.phone-anim .pa-notch {
  position: absolute;
  top: 24px; left: 50%;
  transform: translateX(-50%);
  width: 110px; height: 28px;
  background: oklch(8% 0.01 295);
  border-radius: 999px;
  z-index: 3;
}
.phone-anim .pa-notch::after {
  content: "";
  position: absolute;
  top: 50%; right: 18px;
  transform: translateY(-50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: oklch(25% 0.04 295);
  box-shadow: inset 0 0 0 1.5px oklch(15% 0.02 295);
}
.phone-anim .pa-side-btn {
  position: absolute;
  background: oklch(10% 0.01 295);
  border-radius: 2px;
  z-index: 0;
}
.phone-anim .pa-side-btn.left  { left: -2px; width: 3px; }
.phone-anim .pa-side-btn.right { right: -2px; width: 3px; }
.phone-anim .pa-side-btn.b1 { top: 16%; height: 32px; }
.phone-anim .pa-side-btn.b2 { top: 24%; height: 50px; }
.phone-anim .pa-side-btn.b3 { top: 34%; height: 50px; }
.phone-anim .pa-side-btn.b4 { top: 22%; height: 70px; }

.phone-anim .pa-screen {
  position: relative;
  width: 100%; height: 100%;
  border-radius: 32px;
  overflow: hidden;
  background:
    radial-gradient(120% 80% at 50% 0%, var(--phone-screen-1) 0%, var(--phone-screen-2) 55%, var(--phone-screen-3) 100%);
  padding: 56px 18px 18px;
  display: flex;
  flex-direction: column;
  color: oklch(96% 0.02 80);
}

.phone-anim .pa-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  top: 18px;
  left: 22px; right: 22px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: oklch(96% 0.02 80 / .85);
  z-index: 2;
}
.phone-anim .pa-status .battery {
  display: inline-block;
  width: 22px; height: 10px;
  border: 1px solid oklch(96% 0.02 80 / .55);
  border-radius: 3px;
  position: relative;
  padding: 1px;
  margin-left: 6px;
  vertical-align: middle;
}
.phone-anim .pa-status .battery::after {
  content: ""; position: absolute;
  right: -3px; top: 50%; transform: translateY(-50%);
  width: 2px; height: 5px;
  background: oklch(96% 0.02 80 / .55);
  border-radius: 0 1px 1px 0;
}
.phone-anim .pa-status .battery::before {
  content: ""; display: block;
  height: 100%; width: 75%;
  background: oklch(96% 0.02 80 / .9);
  border-radius: 1px;
}

.phone-anim .pa-top {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(80% 0.05 82 / .8);
  margin-bottom: 4px;
  opacity: 0;
  transform: translateY(8px);
  animation: pa-rise .8s ease .15s forwards;
}
.phone-anim .pa-greeting {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.18;
  margin-bottom: 16px;
  font-weight: 500;
  opacity: 0;
  transform: translateY(8px);
  animation: pa-rise .9s ease .3s forwards;
}
.phone-anim .pa-greeting em { color: var(--gold); font-style: italic; }

.phone-anim .pa-orb {
  position: relative;
  width: 78%;
  aspect-ratio: 1;
  margin: 4px auto 16px;
  opacity: 0;
  transform: translateY(8px);
  animation: pa-rise 1.1s ease .45s forwards;
}
.phone-anim .pa-orb-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px dashed oklch(94% 0.04 82 / .25);
  animation: pa-spin 22s linear infinite;
}
.phone-anim .pa-orb-ring.r2 {
  inset: 8%;
  border: 1px solid oklch(94% 0.04 82 / .15);
  animation-duration: 18s;
  animation-direction: reverse;
}
.phone-anim .pa-orb-core {
  position: absolute;
  inset: 14%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 28%, oklch(94% 0.06 82 / .9), transparent 55%),
    radial-gradient(circle at 68% 75%, oklch(70% 0.14 320 / .75), transparent 60%),
    radial-gradient(circle, oklch(76% 0.14 82 / .35), oklch(38% 0.14 300 / .25));
  box-shadow:
    inset 0 0 0 1px oklch(94% 0.06 82 / .55),
    inset 0 -28px 60px oklch(22% 0.10 300 / .65),
    0 0 60px oklch(76% 0.14 82 / .25);
  animation: pa-breathe 4s ease-in-out infinite;
}
.phone-anim .pa-orb-shimmer {
  position: absolute;
  inset: 14%;
  border-radius: 50%;
  background: conic-gradient(from 0deg,
    transparent 0deg,
    oklch(94% 0.06 82 / .28) 30deg,
    transparent 90deg,
    oklch(70% 0.14 320 / .28) 220deg,
    transparent 280deg);
  mix-blend-mode: screen;
  animation: pa-spin 14s linear infinite;
  opacity: .6;
}
.phone-anim .pa-orb-dot {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: oklch(94% 0.06 82 / .9);
  box-shadow: 0 0 8px oklch(94% 0.06 82 / .9);
  top: 50%; left: 50%;
  margin: -3px;
  transform-origin: 0 -90px;
  animation: pa-spin 9s linear infinite;
}
.phone-anim .pa-orb-dot.d2 {
  background: oklch(76% 0.14 82 / .9);
  box-shadow: 0 0 10px oklch(76% 0.14 82 / .7);
  transform-origin: 0 -110px;
  animation-duration: 14s;
  animation-direction: reverse;
}

@keyframes pa-spin {
  to { transform: rotate(360deg); }
}
@keyframes pa-breathe {
  0%, 100% { transform: scale(1);    filter: brightness(1); }
  50%      { transform: scale(1.04); filter: brightness(1.08); }
}

.phone-anim .pa-cards {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: auto;
}
.phone-anim .pa-card {
  background: oklch(100% 0 0 / .08);
  border: 1px solid oklch(94% 0.04 82 / .18);
  border-radius: 12px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11.5px;
  opacity: 0;
  transform: translateY(10px);
  animation: pa-rise .8s ease forwards;
}
.phone-anim .pa-card:nth-child(1) { animation-delay: .65s; }
.phone-anim .pa-card:nth-child(2) { animation-delay: .80s; }
.phone-anim .pa-card:nth-child(3) { animation-delay: .95s; }
.phone-anim .pa-card:nth-child(4) { animation-delay: 1.10s; }
.phone-anim .pa-card .nm { font-family: var(--font-display); font-size: 14px; }
.phone-anim .pa-card .vl {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--gold);
  letter-spacing: 0.1em;
  position: relative;
  padding-left: 14px;
}
.phone-anim .pa-card .vl::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  transform: translateY(-50%);
  box-shadow: 0 0 8px var(--gold);
  animation: pa-pulse 2s ease-in-out infinite;
}
.phone-anim .pa-card:nth-child(2) .vl::before { animation-delay: .3s; }
.phone-anim .pa-card:nth-child(3) .vl::before { animation-delay: .6s; }
.phone-anim .pa-card:nth-child(4) .vl::before { animation-delay: .9s; }
@keyframes pa-pulse {
  0%, 100% { opacity: .55; transform: translateY(-50%) scale(.85); }
  50%      { opacity: 1;   transform: translateY(-50%) scale(1.1); }
}
@keyframes pa-rise {
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .phone-anim,
  .phone-anim::before,
  .phone-anim .pa-orb-core,
  .phone-anim .pa-orb-ring,
  .phone-anim .pa-orb-shimmer,
  .phone-anim .pa-orb-dot,
  .phone-anim .pa-card .vl::before {
    animation: none !important;
  }
  .phone-anim .pa-top,
  .phone-anim .pa-greeting,
  .phone-anim .pa-orb,
  .phone-anim .pa-card { opacity: 1; transform: none; }
}


/* ============================================================
   Designed art tiles (replace photo placeholders)
   ============================================================ */

.art-tile {
  position: relative;
  aspect-ratio: 4 / 3.2;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--hairline);
}
.art-tile.tall { aspect-ratio: 4 / 5; }
.art-tile svg { width: 100%; height: 100%; display: block; }

/* Art tile palettes */
.art-tile.t-purple {
  background:
    radial-gradient(120% 90% at 50% 0%, oklch(50% 0.14 300) 0%, oklch(28% 0.10 300) 60%, oklch(22% 0.10 300) 100%);
}
.art-tile.t-cream {
  background: linear-gradient(180deg, oklch(95% 0.04 80), oklch(88% 0.07 80));
}
.art-tile.t-paper {
  background: linear-gradient(180deg, oklch(98% 0.005 80), oklch(94% 0.015 80));
}
[data-theme="dark"] .art-tile.t-cream {
  background: linear-gradient(180deg, oklch(26% 0.04 80), oklch(20% 0.03 80));
}
[data-theme="dark"] .art-tile.t-paper {
  background: linear-gradient(180deg, oklch(22% 0.025 295), oklch(18% 0.025 295));
}

.art-tile .a-caption {
  position: absolute;
  left: 22px; bottom: 18px;
  display: flex; flex-direction: column;
  gap: 4px;
  z-index: 2;
}
.art-tile .a-caption .lab {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: .7;
}
.art-tile .a-caption .nm {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.art-tile.t-purple .a-caption { color: oklch(94% 0.04 82); }
.art-tile.t-cream  .a-caption { color: var(--ink); }
.art-tile.t-paper  .a-caption { color: var(--ink); }
.art-tile.t-purple .a-caption .nm em { color: var(--gold); font-style: italic; }
.art-tile.t-cream  .a-caption .nm em { color: var(--purple); font-style: italic; }
.art-tile.t-paper  .a-caption .nm em { color: var(--purple); font-style: italic; }

/* Drift animation utility */
@keyframes art-drift {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
@keyframes art-spin {
  to { transform: rotate(360deg); }
}

/* ============================================================
   Network diagram (About — Inside NUMI)
   ============================================================ */

.network {
  margin-top: clamp(40px, 5vw, 64px);
  display: flex;
  justify-content: center;
}
.network svg {
  width: 100%;
  max-width: 820px;
  height: auto;
}
.nw-ring   { fill: none; stroke: var(--hairline); }
.nw-line   { stroke: var(--purple); stroke-width: 1; opacity: .35; }
.nw-node   { fill: var(--paper); stroke: var(--purple); stroke-width: 1.4; }
[data-theme="dark"] .nw-node { fill: var(--bg-2); }
.nw-title {
  fill: var(--ink);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  font-weight: 500;
}
.nw-sub {
  fill: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
}
.nw-dot-g { fill: var(--gold); }
.nw-dot-p { fill: var(--purple); }
.nw-pulse { opacity: .35; }

/* ============================================================
   Method vertical (About — The method)
   ============================================================ */

.method-stack {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: clamp(32px, 4vw, 64px);
  margin-top: clamp(40px, 5vw, 64px);
  align-items: start;
}
.method-art {
  position: sticky;
  top: 100px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(120% 90% at 30% 20%, oklch(50% 0.14 300), oklch(22% 0.10 300) 70%);
  display: grid; place-items: center;
  position: relative;
  overflow: hidden;
}
.method-art svg { width: 100%; height: 100%; }
.method-list { display: flex; flex-direction: column; }
.method-row {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 24px;
  padding: 28px 0;
  border-top: 1px solid var(--hairline);
  align-items: start;
}
.method-row:last-child { border-bottom: 1px solid var(--hairline); }
.method-row .m-num {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--gold-deep);
  text-transform: uppercase;
  padding-top: 6px;
}
.method-row h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(24px, 2.4vw, 36px);
  margin: 0;
  line-height: 1.1;
}
.method-row h3 em { color: var(--purple); font-style: italic; }

/* ============================================================
   Phone gallery row (App page — Three modes)
   ============================================================ */

.phone-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 4vw, 56px);
  margin-top: clamp(40px, 5vw, 64px);
  align-items: end;
}
.phone-row .phone-anim { width: 100%; max-width: 280px; }
.phone-col { display: flex; flex-direction: column; align-items: center; gap: 20px; }
.phone-col .ph-cap {
  text-align: center;
  display: flex; flex-direction: column; gap: 4px;
}
.phone-col .ph-cap .lab {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.phone-col .ph-cap .nm {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  font-weight: 500;
  color: var(--ink);
}

/* Variant: light screen phone (Members mode) */
.phone-anim.v-light {
  --phone-screen-1: oklch(94% 0.025 82);
  --phone-screen-2: oklch(90% 0.04 82);
  --phone-screen-3: oklch(86% 0.05 82);
}
.phone-anim.v-light .pa-screen,
.phone-anim.v-light .pa-screen .pa-top,
.phone-anim.v-light .pa-status,
.phone-anim.v-light .pa-greeting { color: var(--ink); }
.phone-anim.v-light .pa-greeting em { color: var(--purple); }
.phone-anim.v-light .pa-status .battery { border-color: oklch(20% 0.025 295 / .55); }
.phone-anim.v-light .pa-status .battery::before { background: oklch(20% 0.025 295); }
.phone-anim.v-light .pa-status .battery::after { background: oklch(20% 0.025 295 / .55); }
.phone-anim.v-light .pa-card {
  background: oklch(100% 0 0 / .65);
  border-color: oklch(20% 0.025 295 / .08);
}
.phone-anim.v-light .pa-card .nm { color: var(--ink); }
.phone-anim.v-light .pa-card .vl { color: var(--purple); }
.phone-anim.v-light .pa-card .vl::before { background: var(--purple); box-shadow: 0 0 8px var(--purple); }

/* Variant: deep night (Year/Timing mode) */
.phone-anim.v-night {
  --phone-screen-1: oklch(28% 0.10 300);
  --phone-screen-2: oklch(18% 0.07 300);
  --phone-screen-3: oklch(12% 0.05 300);
}

/* Compact phone for gallery */
.phone-anim.v-compact { aspect-ratio: 9 / 17.5; }

/* ============================================================
   Membership flow (App page)
   ============================================================ */

.flow {
  margin-top: clamp(40px, 5vw, 64px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.flow::before {
  content: "";
  position: absolute;
  left: 8%; right: 8%; top: 60px;
  height: 1px;
  background: repeating-linear-gradient(to right, var(--purple) 0 4px, transparent 4px 12px);
  opacity: .4;
}
.flow-step {
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
  padding: 0 12px;
  text-align: center;
  position: relative;
}
.flow-step .marker {
  width: 120px; height: 120px;
  border-radius: 50%;
  background: var(--paper);
  border: 1px solid var(--hairline);
  display: grid; place-items: center;
  position: relative;
  z-index: 1;
}
[data-theme="dark"] .flow-step .marker { background: var(--bg-2); }
.flow-step .marker svg { width: 60%; height: 60%; }
.flow-step .step-n {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--gold-deep);
  text-transform: uppercase;
}
.flow-step h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  margin: 0;
  line-height: 1.15;
}
.flow-step h4 em { color: var(--purple); font-style: italic; }
.flow-step p {
  margin: 0;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 26ch;
}

/* ============================================================
   Roles grid (About — Roles within NUMI, anonymous)
   ============================================================ */

.roles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: clamp(40px, 5vw, 64px);
}
.role-card {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 2.6vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.role-card .r-glyph {
  width: 56px; height: 56px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, oklch(94% 0.06 82 / .9), transparent 55%),
    radial-gradient(circle, oklch(76% 0.14 82 / .5), oklch(38% 0.14 300 / .25));
  box-shadow: inset 0 0 0 1px oklch(76% 0.14 82 / .5);
}
.role-card .r-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.role-card h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  margin: 0;
  line-height: 1.15;
}
.role-card h4 em { color: var(--purple); font-style: italic; }
.role-card p { margin: 0; color: var(--ink-2); font-size: 14.5px; line-height: 1.55; }

/* ============================================================
   Responsive overrides
   ============================================================ */

@media (max-width: 980px) {
  .method-stack { grid-template-columns: 1fr; }
  .method-art { position: static; max-width: 280px; }
  .phone-row { grid-template-columns: 1fr; gap: 40px; }
  .flow { grid-template-columns: 1fr 1fr; gap: 32px 0; }
  .flow::before { display: none; }
  .roles { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .flow { grid-template-columns: 1fr; }
}
