/* ============================================================
   DUB NINJA — design system
   Ink on circuit board. Brutalist grotesk + mono. Two colours / composition.
   ============================================================ */

:root{
  /* surfaces — warm, dusty, sophisticated (the house palette) */
  --ink:        #0a0b0a;   /* near-black, faintly cool-warm */
  --ink-2:      #121412;   /* raised panel on dark */
  --ink-line:   rgba(255,255,255,.10);
  --ink-line-2: rgba(255,255,255,.18);
  --on-ink:     #efeee7;   /* warm off-white text on ink */
  --on-ink-dim: #8d8f86;

  --paper:      #f1efe8;   /* warm dusty off-white ground */
  --paper-2:    #e9e7dd;   /* deeper panel */
  --card:       #faf9f4;   /* raised card on paper */
  --text:       #16170f;   /* warm dark ink */
  --text-dim:   #6c6e62;   /* warm gray */
  --paper-line: rgba(22,23,15,.14);
  --paper-line-2: rgba(22,23,15,.28);

  /* primary accent (tweakable) — the live signal */
  --signal:     #19e07c;   /* phosphor signal green */
  --signal-deep:#0c8f50;   /* readable green on light, sparing */

  /* spectrum — sampled straight from the glitch artwork */
  --sig-green:  #19e07c;
  --sig-blue:   #2f5bff;   /* electric cobalt */
  --sig-violet: #6a3cf0;   /* indigo-violet */
  --sig-red:    #ff3a1f;   /* hot red */
  --sig-orange: #ff7a1f;   /* burn orange */
  /* deeper, readable-on-paper variants */
  --sig-blue-d:   #1f3fe0;
  --sig-violet-d: #5a2fd0;
  --sig-red-d:    #d62a12;
  --sig-orange-d: #cf5c08;
  --ink-indigo: #05040e;   /* cover-night ground for the orb */

  /* type */
  --grotesk: "Cabinet Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1480px;
  --gut: clamp(20px, 5vw, 88px);

  --grain-opacity: .055;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--paper);
  color:var(--text);
  font-family:var(--grotesk);
  font-weight:500;
  line-height:1.4;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{ background:var(--signal); color:var(--ink); }

a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
img{ max-width:100%; display:block; }

/* ---- type atoms ---- */
.mono{ font-family:var(--mono); }
.label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
}
.display{
  font-family:var(--grotesk);
  font-weight:900;
  line-height:.92;
  letter-spacing:-.02em;
}
h1,h2,h3{ margin:0; font-weight:900; letter-spacing:-.02em; line-height:.94; }

/* ============================================================
   GRAIN + texture overlays
   ============================================================ */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:var(--grain-opacity);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.no-grain .grain{ display:none; }

.scanlines{
  position:absolute; inset:0; pointer-events:none; z-index:3;
  background:repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,.025) 0 1px,
    transparent 1px 3px);
  mix-blend-mode:overlay;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
section{ position:relative; }

/* index tag that anchors each section, brutalist */
.section-tag{
  display:flex; align-items:baseline; gap:14px;
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--text-dim);
  margin-bottom:34px;
}
.section-tag .num{ color:var(--text); font-weight:700; }
.on-ink .section-tag{ color:var(--on-ink-dim); }
.on-ink .section-tag .num{ color:var(--on-ink); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:8000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .4s ease, color .4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
.nav.on-dark{ color:var(--on-ink); }
.nav.on-light{
  color:var(--text);
  background:color-mix(in srgb, var(--paper) 78%, transparent);
  backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--paper-line);
}
.nav .brand{ display:flex; align-items:center; gap:13px; }
.nav .wordmark{
  font-family:var(--grotesk); font-weight:800; font-size:22px;
  letter-spacing:-.02em; line-height:1; white-space:nowrap;
  display:inline-block; color:currentColor;
}
.nav .wordmark .sl{ font-weight:700; margin:0 .02em; }
.nav .links{ display:flex; align-items:center; gap:34px; }
.nav .links a{
  font-family:var(--mono); font-size:12px; letter-spacing:.04em;
  opacity:.72; transition:opacity .2s;
}
.nav .links a:hover{ opacity:1; }
.nav-right{ display:flex; align-items:center; gap:26px; }

.onair{
  display:flex; align-items:center; gap:9px;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
}
.onair .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--signal);
  box-shadow:0 0 0 0 color-mix(in srgb, var(--signal) 70%, transparent);
  animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 color-mix(in srgb, var(--signal) 60%, transparent); }
  70%{ box-shadow:0 0 0 9px transparent; }
  100%{ box-shadow:0 0 0 0 transparent; }
}
.nav .tune{
  font-family:var(--mono); font-size:12px; letter-spacing:.04em;
  padding:9px 16px; border:1px solid currentColor; border-radius:2px;
  display:flex; align-items:center; gap:8px;
  transition:background .2s,color .2s;
}
.nav.on-dark .tune:hover{ background:var(--signal); color:var(--ink); border-color:var(--signal); }
.nav.on-light .tune:hover{ background:var(--ink); color:var(--on-ink); border-color:var(--ink); }

/* logo mark */
.mark{ display:block; }
.mark .rot{ transform-origin:center; transform:rotate(45deg); }

/* the wordmark — live text in the display grotesk, slash as the anchor */
.nav .brand{ position:relative; }

/* RGB-split chromatic glitch on the wordmark — the artwork's signature, on hover */
.glitch-word{ cursor:pointer; display:inline-block; }
.glitch-word:hover{ animation:wordGlitch .42s steps(2,end) infinite; }
@keyframes wordGlitch{
  0%   { text-shadow:2px 0 var(--sig-red), -2px 0 var(--sig-blue); transform:translate(0,0); clip-path:none; }
  22%  { text-shadow:-3px 0 var(--sig-red), 3px 0 var(--sig-blue); transform:translate(-1px,1px); clip-path:inset(8% 0 56% 0); }
  44%  { text-shadow:3px 0 var(--sig-orange), -3px 0 var(--sig-violet); transform:translate(1px,-1px); clip-path:inset(60% 0 6% 0); }
  66%  { text-shadow:-2px 0 var(--sig-red), 2px 0 var(--sig-blue); transform:translate(1px,0); clip-path:none; }
  88%  { text-shadow:2px 0 var(--sig-orange), -2px 0 var(--sig-blue); transform:translate(-1px,0); clip-path:inset(36% 0 36% 0); }
  100% { text-shadow:2px 0 var(--sig-red), -2px 0 var(--sig-blue); transform:translate(0,0); clip-path:none; }
}
@media (prefers-reduced-motion: reduce){ .glitch-word:hover{ animation:none; } }

/* hide nav links on small */
@media (max-width:880px){
  .nav .links{ display:none; }
  .nav-right{ gap:16px; }
}
/* on phones the brand + status + CTA crowd: drop the nav status (it's shown
   prominently in the stage below) so the bar breathes — brand + Tune in only */
@media (max-width:768px){
  .nav{ padding:16px var(--gut); }
  .onair{ display:none; }
  .nav .wordmark{ font-size:20px; }
}

/* ============================================================
   HERO  (ink-black, particle field)
   ============================================================ */
.hero{
  background:var(--ink); color:var(--on-ink);
  min-height:100svh; position:relative; overflow:hidden;
}
.hero canvas.field{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero .vignette{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(110% 100% at 68% 42%, transparent 34%, rgba(0,0,0,.62) 100%);
}
.hero .scanlines{ z-index:2; }

/* the breathing signal — gallery object / iMac screensaver */
.hero-disc{
  position:absolute; z-index:2; cursor:pointer;
  width:clamp(340px, 60vmin, 780px); aspect-ratio:1/1;
  right:clamp(-60px, 2vw, 40px); top:50%; transform:translateY(-48%);
}
.hero-disc canvas{ position:absolute; inset:0; width:100%; height:100%; }
.hero-disc .disc-ring{
  position:absolute; inset:7%; border-radius:50%;
  border:1px solid rgba(255,255,255,.10);
}
.hero-disc .disc-ring.r2{ inset:0; border-color:rgba(255,255,255,.05); }
.hero-disc .disc-live{
  position:absolute; left:50%; top:5%; transform:translateX(-50%);
  display:flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--on-ink);
}
.hero-disc .disc-live .d{ width:7px; height:7px; border-radius:50%; background:var(--signal); animation:pulse 2.4s ease-out infinite; }
.hero-disc .disc-cue{
  position:absolute; left:50%; bottom:4%; transform:translateX(-50%);
  font-family:var(--mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--on-ink-dim);
  opacity:0; transition:opacity .3s;
}
.hero-disc:hover .disc-cue{ opacity:1; }

/* foreground type + tag + whisper */
.hero-fg{
  position:absolute; inset:0; z-index:4; pointer-events:none;
  display:flex; flex-direction:column;
  padding:clamp(104px,15vh,160px) var(--gut) clamp(112px,16vh,150px);
}
.hero-tag{
  font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--on-ink-dim); display:flex; gap:14px; flex-wrap:wrap; align-items:center;
}
.hero-tag .gt{ color:var(--signal); }
.hero-bottom{ margin-top:auto; }
.hero-word{
  font-family:var(--grotesk); font-weight:900; text-transform:uppercase;
  font-size:clamp(72px, 16.5vw, 248px); line-height:.8; letter-spacing:-.045em; margin:0;
  mix-blend-mode:exclusion;
}
.hero-word span{ display:block; margin-left:clamp(28px, 9vw, 190px); }
.hero-whisper{
  margin-top:clamp(20px,3.2vh,38px); max-width:48ch; pointer-events:auto;
  display:flex; gap:14px; align-items:baseline;
  font-size:clamp(16px,1.5vw,21px); line-height:1.45; letter-spacing:-.01em;
}
.hero-whisper .who{
  flex:none; font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--signal); padding-top:.35em;
}
.hero-whisper .line{ color:var(--on-ink); font-weight:500; transition:opacity .4s; }

/* bottom transport ticker */
.hero-ticker{
  position:absolute; left:0; right:0; bottom:0; z-index:5;
  display:flex; align-items:center; gap:clamp(16px,3vw,46px);
  padding:14px var(--gut); border-top:1px solid var(--ink-line);
  background:linear-gradient(transparent, rgba(10,11,10,.7));
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:var(--on-ink-dim);
  text-transform:uppercase; flex-wrap:wrap;
}
.hero-ticker .t-live{ display:flex; align-items:center; gap:8px; color:var(--on-ink); }
.hero-ticker .t-live .d{ width:7px; height:7px; border-radius:50%; background:var(--signal); animation:pulse 2.4s ease-out infinite; }
.hero-ticker .tk-now{ color:var(--on-ink); }
.hero-ticker .t-cue{ margin-left:auto; color:var(--on-ink-dim); }

@media (max-width:780px){
  .hero-disc{ width:90vw; right:-18vw; top:42%; opacity:.85; }
  .hero-word{ font-size:clamp(64px,21vw,140px); }
  .hero-whisper{ max-width:90%; }
  .hero-ticker{ font-size:10px; gap:14px; }
  .hero-ticker .t-cue{ display:none; }
}

/* ============================================================
   THE STAGE  (opening — dark, immersive AI-DJ surface)
   ============================================================ */
.stage{ position:relative; min-height:100svh; background:var(--paper); overflow:hidden;
  display:flex; align-items:center; }
.stage-orb{ position:relative; width:clamp(240px, 34vw, 400px); aspect-ratio:1/1; border-radius:50%;
  box-shadow:0 34px 90px -34px rgba(20,18,40,.5),
             0 0 64px -6px color-mix(in srgb, var(--sig-blue) 20%, transparent); }
.stage-orb canvas{ position:absolute; inset:0; width:100%; height:100%; border-radius:50%; }
.stage-fg{ position:relative; z-index:2; width:100%; max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  align-items:center; gap:clamp(36px,6vw,104px);
  padding:clamp(104px,13vh,150px) var(--gut) clamp(96px,12vh,132px); }
.stage-left{ display:flex; flex-direction:column; align-items:center; gap:clamp(20px,3vh,34px); }
.stage-right{ display:flex; flex-direction:column; align-items:flex-start; text-align:left;
  gap:clamp(20px,3vh,30px); }

.stage-status{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); display:flex; gap:10px; align-items:center; white-space:nowrap; }
.stage-status .dot{ width:8px; height:8px; border-radius:50%; background:var(--signal);
  box-shadow:0 0 0 0 color-mix(in srgb,var(--signal) 70%,transparent); animation:pulse 2.4s ease-out infinite; }
.stage-status .sep{ opacity:.4; }
.stage-status .on{ color:var(--text); }
/* the Ninja's scale — an always-honest, always-large stat (records, 24/7) */
.stage-scale{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); text-align:center; max-width:46ch; line-height:1.7; margin-top:-6px; }

.stage-now{ display:flex; flex-direction:column; align-items:flex-start; gap:9px; }
.stage-now .lab{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }
.stage-now h1{ font-family:var(--grotesk); font-weight:900; letter-spacing:-.035em; line-height:.9;
  font-size:clamp(52px,6vw,96px); text-wrap:balance; }
.stage-now .by{ font-family:var(--mono); font-size:clamp(13px,1.2vw,15px); color:var(--text-dim); }
.stage-now .by em{ font-style:normal; color:var(--text); }

/* reasoning — fixed-height panel so streaming text never reflows the page */
.stage-reason{ width:100%; height:6.2em; overflow:hidden;
  border-left:2px solid var(--paper-line-2); padding-left:18px;
  display:flex; flex-direction:column; gap:7px; }
.stage-reason .who{ flex:none; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--signal-deep); }
.stage-reason .line{ margin:0; color:var(--text); font-size:clamp(15px,1.35vw,19px); line-height:1.45; letter-spacing:-.01em; }
.stage-reason .cursor{ display:inline-block; width:.5ch; height:1em; background:var(--signal-deep);
  transform:translateY(.12em); margin-left:.06em; animation:blink 1s steps(2) infinite; }

/* the command surface — steer the intelligence */
.stage-cmd{ width:100%; display:flex; flex-direction:column; gap:14px; }
.cmd-bar{ display:flex; align-items:center; gap:12px; width:100%;
  border:1px solid var(--paper-line-2); border-radius:999px; padding:14px 20px;
  background:color-mix(in srgb, var(--card) 55%, transparent); backdrop-filter:blur(10px);
  transition:border-color .2s; }
.cmd-bar:focus-within{ border-color:var(--signal-deep); }
.cmd-bar .ic{ font-family:var(--mono); font-size:13px; color:var(--signal-deep); }
.cmd-bar input{ flex:1; background:transparent; border:0; outline:none; color:var(--text);
  font-family:var(--grotesk); font-weight:500; font-size:16px; letter-spacing:-.01em; text-align:left; }
.cmd-bar input::placeholder{ color:var(--text-dim); }
.cmd-bar .send{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.cmd-chips{ display:flex; flex-wrap:wrap; gap:9px; justify-content:flex-start; }
.cmd-chips button{ font-family:var(--mono); font-size:12px; letter-spacing:.02em; cursor:pointer;
  color:var(--text); background:transparent; border:1px solid var(--paper-line-2); border-radius:999px;
  padding:9px 16px; transition:border-color .18s, background .18s, color .18s; }
.cmd-chips button:hover{ background:var(--card); }
.cmd-chips button.on{ border-color:var(--signal-deep); color:var(--signal-deep); }

.stage-scroll{ position:absolute; bottom:26px; right:var(--gut); z-index:2;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim);
  display:flex; flex-direction:column; align-items:center; gap:7px; transition:color .2s; }
.stage-scroll:hover{ color:var(--text); }
.stage-scroll .ln{ width:1px; height:30px; background:linear-gradient(var(--paper-line-2), transparent); }

@media (max-width:880px){
  .stage-fg{ grid-template-columns:1fr; gap:clamp(28px,5vh,44px); justify-items:center; text-align:center;
    padding-top:clamp(96px,12vh,130px); padding-bottom:clamp(80px,10vh,110px); }
  .stage-right{ align-items:center; text-align:center; max-width:560px; }
  .stage-now{ align-items:center; }
  .stage-status{ white-space:normal; flex-wrap:wrap; justify-content:center; }
  .stage-reason{ border-left:0; border-top:1px solid var(--paper-line-2); padding-left:0; padding-top:14px;
    height:8.5em; min-height:0; align-items:center; }
  .cmd-chips{ justify-content:center; }
  .stage-scroll{ display:none; }
}
@media (max-width:640px){
  .stage-orb{ width:clamp(190px,58vw,300px); }
}

/* ---- the memory drawer trigger ---- */
.trail-open{ position:absolute; top:clamp(82px,11vh,120px); right:var(--gut); z-index:6;
  display:flex; align-items:center; gap:9px; cursor:pointer;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text);
  background:color-mix(in srgb, var(--card) 60%, transparent); backdrop-filter:blur(8px);
  border:1px solid var(--paper-line-2); border-radius:999px; padding:9px 14px; transition:border-color .2s, background .2s; }
.trail-open:hover{ border-color:var(--signal-deep); background:var(--card); }
.trail-open .g{ color:var(--signal-deep); font-size:13px; }
.trail-open .ct{ font-size:10px; color:var(--text-dim); border-left:1px solid var(--paper-line-2); padding-left:9px; }

/* scrim + drawer */
.trail-scrim{ position:fixed; inset:0; z-index:8500; background:rgba(18,16,30,.34); backdrop-filter:blur(2px);
  opacity:0; pointer-events:none; transition:opacity .32s ease; }
.trail-scrim.open{ opacity:1; pointer-events:auto; }
.trail{ position:fixed; top:0; right:0; z-index:8600; height:100svh; width:min(440px, 92vw);
  background:var(--paper-2); border-left:1px solid var(--paper-line-2);
  box-shadow:-30px 0 80px -30px rgba(18,16,30,.5);
  display:flex; flex-direction:column; transform:translateX(100%); transition:transform .42s cubic-bezier(.6,.04,.2,1); }
.trail.open{ transform:translateX(0); }

.trail-head{ flex:none; display:flex; align-items:flex-start; justify-content:space-between;
  padding:clamp(22px,3vh,30px) clamp(22px,3vw,30px) 18px; border-bottom:1px solid var(--paper-line); }
.th-kick{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--signal-deep); margin-bottom:8px; }
.th-title{ font-family:var(--grotesk); font-weight:800; font-size:clamp(22px,2.4vw,28px); letter-spacing:-.02em; }
.th-close{ flex:none; width:34px; height:34px; border-radius:50%; cursor:pointer;
  border:1px solid var(--paper-line-2); background:transparent; color:var(--text-dim); font-size:13px;
  display:flex; align-items:center; justify-content:center; transition:border-color .2s, color .2s; }
.th-close:hover{ border-color:var(--text); color:var(--text); }

/* on air — pinned at the top of memory */
.trail-now{ flex:none; padding:clamp(18px,2.4vh,24px) clamp(22px,3vw,30px); border-bottom:1px solid var(--paper-line);
  background:linear-gradient(color-mix(in srgb,var(--signal) 7%,transparent), transparent); }
.tn-live{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); margin-bottom:11px; }
.tn-live .d{ width:7px; height:7px; border-radius:50%; background:var(--signal); animation:pulse 2.4s ease-out infinite; }
.tn-track{ font-family:var(--grotesk); font-weight:800; font-size:clamp(24px,2.8vw,32px); letter-spacing:-.025em; line-height:1.04; }
.tn-by{ font-family:var(--mono); font-size:12px; color:var(--text-dim); margin-top:7px; }
.tn-by em{ font-style:normal; color:var(--text); }
.tn-time{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--signal-deep); margin-top:10px; }

/* the thread of memory */
.trail-list{ flex:1; overflow-y:auto; padding:clamp(14px,2vh,20px) clamp(22px,3vw,30px) 40px; position:relative; }
.trail-list::before{ content:""; position:absolute; left:calc(clamp(22px,3vw,30px) + 3px); top:24px; bottom:54px; width:1px;
  background:linear-gradient(var(--paper-line-2), color-mix(in srgb,var(--paper-line) 40%,transparent)); }
.trail-item{ position:relative; padding:14px 0 14px 26px; }
.ti-node{ position:absolute; left:0; top:20px; width:7px; height:7px; border-radius:50%;
  background:var(--text-dim); box-shadow:0 0 0 4px var(--paper-2); }
.trail-item:first-child .ti-node{ background:var(--signal-deep); }
.ti-line{ display:grid; grid-template-columns:minmax(0,1fr) auto; align-items:start; column-gap:14px; }
.ti-t{ font-family:var(--grotesk); font-weight:700; font-size:16px; letter-spacing:-.01em; line-height:1.2; min-width:0; }
.ti-ago{ font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--text-dim); white-space:nowrap; padding-top:3px; }
.ti-a{ font-family:var(--mono); font-size:11.5px; color:var(--text-dim); margin-top:4px; }
.ti-note{ margin-top:9px; padding-left:11px; border-left:2px solid color-mix(in srgb,var(--signal) 40%,var(--paper-line));
  font-size:13.5px; line-height:1.5; color:var(--text-dim); }
.ti-note::before{ content:"the Ninja  "; font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--signal-deep); }
.trail-floor{ text-align:center; font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); opacity:.6; margin-top:18px; }

@media (max-width:880px){
  .trail-open{ top:auto; bottom:24px; right:var(--gut); }
}

/* THE QUEUE — the Ninja's next moves (reasoning, not a schedule) */
.queue-sec{ background:var(--paper); padding:clamp(50px,8vh,110px) 0 clamp(60px,9vh,120px); }
.queue{ display:flex; flex-direction:column; border-top:1px solid var(--paper-line); margin-top:34px; }
.qrow{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.5fr) auto; gap:clamp(16px,3vw,46px);
  align-items:baseline; padding:clamp(20px,2.6vh,30px) 0; border-bottom:1px solid var(--paper-line); transition:padding-left .2s; }
.qrow:hover{ padding-left:10px; }
.qrow .tk .t{ font-family:var(--grotesk); font-weight:800; font-size:clamp(20px,2vw,27px); letter-spacing:-.02em; }
.qrow .tk .a{ font-family:var(--mono); font-size:12px; color:var(--text-dim); margin-top:5px; }
.qrow .why{ font-size:clamp(14px,1.2vw,16px); line-height:1.5; color:var(--text-dim); }
.qrow .why b{ font-family:var(--mono); font-weight:500; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--signal-deep); margin-right:9px; }
.qrow .pos{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); text-align:right; white-space:nowrap; }
.qrow:first-child .pos{ color:var(--signal-deep); }
@media (max-width:760px){ .qrow{ grid-template-columns:1fr; gap:10px; } .qrow .pos{ text-align:left; } }

/* ============================================================
   THE SIGNAL  (legacy — unused) */
.signal{ background:var(--paper); padding:0 0 clamp(60px,9vh,120px); }
.sig-hero{ min-height:100svh; display:grid; grid-template-columns:1.08fr .92fr;
  gap:clamp(40px,6vw,110px); align-items:center; padding-top:clamp(96px,12vh,128px); }
@media (max-width:980px){ .sig-hero{ grid-template-columns:1fr; gap:clamp(36px,6vw,56px); min-height:0; padding-top:120px; } }

.sig-kicker{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim); display:flex; gap:11px; flex-wrap:wrap; align-items:center; margin-bottom:clamp(30px,5vh,58px); }
.sig-kicker .gt{ color:var(--signal-deep); }
.sig-kicker .sep{ opacity:.4; }
.sig-kicker .clk{ color:var(--text); }

.np-live{ display:flex; align-items:center; gap:9px; margin-bottom:14px; }
.np-live .dot{ width:9px; height:9px; border-radius:50%; background:var(--signal);
  box-shadow:0 0 0 0 color-mix(in srgb,var(--signal) 70%,transparent); animation:pulse 2.4s ease-out infinite; }
.np-live .label{ color:var(--text-dim); }

.sig-title{ font-family:var(--grotesk); font-weight:900; font-size:clamp(62px,9.4vw,164px);
  line-height:.84; letter-spacing:-.045em; margin:4px 0 10px; }
.sig-artist{ font-family:var(--mono); font-size:clamp(14px,1.4vw,18px); color:var(--text-dim); letter-spacing:.01em; }
.sig-artist em{ font-style:normal; color:var(--text); }

/* reactive waveform */
.wave{ width:100%; height:118px; margin:clamp(28px,4vh,44px) 0 16px; display:block; }

.np-transport{ display:flex; align-items:center; justify-content:space-between;
  font-family:var(--mono); font-size:13px; color:var(--text-dim); }
.np-transport .cur{ color:var(--text); }
.np-bar{ height:2px; background:var(--paper-line); position:relative; margin:13px 0 24px; }
.np-bar .fill{ position:absolute; left:0; top:0; bottom:0; background:var(--ink); }
.np-bar .fill::after{ content:""; position:absolute; right:-1px; top:-3px; width:2px; height:8px; background:var(--signal); }

.sig-meta{ display:flex; align-items:flex-end; gap:clamp(22px,3.2vw,52px); flex-wrap:wrap; }
.np-meta .v{ font-family:var(--mono); font-weight:700; font-size:22px; letter-spacing:-.01em; white-space:nowrap; }
.np-meta .k{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); margin-top:5px; }
.sig-links{ margin-left:auto; display:flex; gap:20px; align-self:flex-end; }
.sig-links a{ font-family:var(--mono); font-size:13px; color:var(--text-dim); display:flex; align-items:center; gap:6px; transition:color .2s; }
.sig-links a::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--paper-line-2); transition:background .2s; }
.sig-links a:hover{ color:var(--text); }
.sig-links a:hover::before{ background:var(--signal); }

/* the signal, as a calm object */
.sig-disc-wrap{ display:flex; flex-direction:column; gap:16px; align-items:center; }
.sig-disc{ position:relative; width:min(100%, clamp(280px,33vw,440px)); aspect-ratio:1/1; border-radius:50%; overflow:hidden; }
.sig-disc canvas{ position:absolute; inset:0; width:100%; height:100%; }
.sig-disc .disc-ring{ position:absolute; inset:0; border-radius:50%; border:1px solid var(--paper-line-2); }
.disc-cap{ display:flex; justify-content:space-between; width:min(100%, clamp(280px,33vw,440px));
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.disc-cap .d{ display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--signal);
  margin-right:7px; animation:pulse 2.4s ease-out infinite; }

/* lists, below the fold */
.sig-lists{ margin-top:clamp(64px,10vh,140px); }
.lists-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,90px); }
@media (max-width:760px){ .lists-grid{ grid-template-columns:1fr; gap:36px; } }
.np-side{ display:none; }
.tracklist h4{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--text-dim); font-weight:500; margin:0 0 18px; padding-bottom:12px; border-bottom:1px solid var(--paper-line); }
.trk{ display:grid; grid-template-columns:1fr auto; gap:6px 14px; padding:13px 0; border-bottom:1px solid var(--paper-line);
  align-items:baseline; transition:padding-left .2s; }
.trk:hover{ padding-left:8px; }
.trk .t{ font-weight:700; font-size:17px; letter-spacing:-.01em; }
.trk .a{ font-family:var(--mono); font-size:12px; color:var(--text-dim); grid-column:1; }
.trk .time{ font-family:var(--mono); font-size:11px; color:var(--text-dim); grid-column:2; grid-row:1; text-align:right; }
.trk .tags{ grid-column:2; grid-row:2; font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--paper-line-2); text-align:right; }
.trk.next .t::before{ content:"→ "; color:var(--signal); }
.trk .reason{ grid-column:1 / -1; grid-row:3; margin-top:8px;
  font-family:var(--mono); font-size:11.5px; line-height:1.5; letter-spacing:.01em;
  color:var(--signal-deep); border-left:2px solid var(--signal); padding-left:11px; }

/* ============================================================
   NINJA VOICE  (centerpiece, dark band)
   ============================================================ */
.ninja{ background:var(--paper); color:var(--text); padding:clamp(80px,13vh,170px) 0; position:relative; overflow:hidden; }
.ninja .halo{ position:absolute; z-index:0; width:60vw; height:60vw; left:-12vw; top:-12vw;
  background:radial-gradient(circle, color-mix(in srgb,var(--signal) 9%,transparent), transparent 62%); filter:blur(46px); pointer-events:none; }
.ninja .inner{ position:relative; z-index:2; }
.ninja-grid{ display:grid; grid-template-columns:auto minmax(0,1fr); gap:clamp(28px,5vw,80px); align-items:start; }
@media (max-width:880px){ .ninja-grid{ grid-template-columns:1fr; gap:34px; } }

.ninja-id{ display:flex; flex-direction:column; gap:18px; }
.ninja-sig{ width:128px; height:128px; position:relative; border-radius:50%; overflow:hidden; }
.ninja-sig canvas{ position:absolute; inset:0; width:100%; height:100%; }
.ninja-sig .sig-ring{ position:absolute; inset:0; border-radius:50%; border:1px solid var(--paper-line-2); }
.ninja-status{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); display:flex; align-items:center; gap:9px; }
.ninja-status .d{ width:7px; height:7px; border-radius:50%; background:var(--signal); }

.ninja-speak{ max-width:none; }
.ninja-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); margin-bottom:26px; display:flex; gap:18px; flex-wrap:wrap; }
.ninja-meta .ctx{ color:var(--signal-deep); }
.ninja-quote{ font-family:var(--grotesk); font-weight:700; font-size:clamp(24px,2.8vw,40px);
  line-height:1.18; letter-spacing:-.02em; max-width:38ch; min-height:4.8em; text-wrap:balance; }
.ninja-quote .cursor{ display:inline-block; width:.5ch; height:1em; background:var(--signal-deep); margin-left:.08em;
  transform:translateY(.12em); animation:blink 1s steps(2) infinite; }
@keyframes blink{ 50%{ opacity:0; } }
.ninja-sign{ margin-top:30px; display:flex; align-items:center; gap:14px;
  font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--text-dim); }
.ninja-sign b{ color:var(--text); font-weight:500; }
.ninja-dots{ display:flex; gap:7px; margin-top:38px; }
.ninja-dots span{ width:24px; height:2px; background:var(--paper-line-2); transition:background .3s; }
.ninja-dots span.on{ background:var(--signal-deep); }

/* ============================================================
   MYTHOLOGY  (character reveal, paper)
   ============================================================ */
.myth{ background:var(--paper); padding:clamp(80px,13vh,170px) 0; }
.myth-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,100px); align-items:center; }
@media (max-width:880px){ .myth-grid{ grid-template-columns:1fr; gap:44px; } }
.myth h2{ font-size:clamp(40px,6.4vw,108px); line-height:.9; letter-spacing:-.03em; }
.myth h2 em{ font-style:normal; color:var(--text-dim); }
.myth-body{ max-width:42ch; }
.myth-body p{ font-size:clamp(16px,1.4vw,19px); line-height:1.6; color:var(--text); margin:0 0 18px; }
.myth-body p.lead{ font-size:clamp(19px,1.7vw,24px); color:var(--text); font-weight:700; line-height:1.4; letter-spacing:-.01em; }
.myth-facts{ margin-top:30px; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); }
.myth-facts .f{ background:var(--paper); padding:18px 20px; }
.myth-facts .f .k{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }
.myth-facts .f .v{ font-family:var(--mono); font-weight:700; font-size:16px; margin-top:6px; letter-spacing:-.01em; }

/* halftone portrait placeholder = "the face of the signal" */
.signal-portrait{ position:relative; aspect-ratio:4/5; background:var(--ink-indigo); overflow:hidden; border-radius:4px; }
.signal-portrait canvas{ position:absolute; inset:0; width:100%; height:100%; }
.signal-portrait .cap{ position:absolute; left:18px; bottom:16px; right:18px; z-index:3;
  font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--on-ink-dim);
  display:flex; justify-content:space-between; }
.signal-portrait .tag{ position:absolute; left:18px; top:16px; z-index:3;
  font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--signal); }

/* ============================================================
   THE SELECTION  (live AI editorial)
   ============================================================ */
.rotation{ background:var(--paper); color:var(--text); padding:clamp(80px,12vh,160px) 0; }
.rot-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:clamp(56px,8vh,96px); flex-wrap:wrap; }
.rot-head h2{ font-size:clamp(40px,6vw,96px); line-height:.88; letter-spacing:-.03em; }
.rot-head h2 em{ font-style:normal; color:var(--signal-deep); }
.rot-head .sub{ font-family:var(--mono); font-size:13px; color:var(--text-dim); max-width:38ch; line-height:1.6; }

.sel-grid{ display:grid; grid-template-columns:minmax(0,1.15fr) minmax(0,0.85fr); gap:clamp(28px,3.5vw,56px); align-items:start; }
@media (max-width:920px){ .sel-grid{ grid-template-columns:1fr; gap:40px; } }

/* featured pick */
.sel-feature{ display:grid; grid-template-columns:minmax(0,0.78fr) minmax(0,1.22fr); gap:clamp(20px,2.5vw,34px); align-items:start; }
@media (max-width:560px){ .sel-feature{ grid-template-columns:1fr; } }
.sf-art{ position:relative; aspect-ratio:1/1; border-radius:6px; overflow:hidden; background:var(--ink-indigo);
  box-shadow:0 24px 60px -28px rgba(20,18,40,.5); }
.sf-art canvas{ position:absolute; inset:0; width:100%; height:100%; }
.sf-badge{ position:absolute; left:14px; top:14px; z-index:3; display:flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--on-ink);
  background:rgba(8,7,16,.5); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.16); border-radius:999px; padding:6px 11px; }
.sf-badge .d{ width:6px; height:6px; border-radius:50%; background:var(--signal); animation:pulse 2.4s ease-out infinite; }

.sf-body{ display:flex; flex-direction:column; }
.sf-fresh{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--signal-deep); }
.sf-title{ font-family:var(--grotesk); font-weight:900; font-size:clamp(32px,4.2vw,58px); letter-spacing:-.035em; line-height:.95; margin:10px 0 8px; }
.sf-by{ font-family:var(--mono); font-size:13px; color:var(--text-dim); }
.sf-by .sep{ opacity:.4; margin:0 2px; }

/* snippet player */
.sf-player{ display:flex; align-items:center; gap:14px; margin:22px 0; }
.sf-play{ flex:none; width:46px; height:46px; border-radius:50%; cursor:pointer;
  border:1px solid var(--text); background:transparent; color:var(--text);
  display:grid; place-items:center; transition:background .2s, color .2s, transform .15s; }
.sf-play:hover{ background:var(--text); color:var(--paper); }
.sf-play.on{ background:var(--signal); border-color:var(--signal); color:var(--ink); }
.sf-play svg{ margin-left:1px; }
.sf-play.on svg{ margin-left:0; }
.sf-wave{ position:relative; flex:1; height:42px; overflow:hidden; }
.sf-bars{ display:flex; align-items:center; gap:2px; height:100%; width:100%; }
.sf-bars span{ flex:1; min-width:0; background:color-mix(in srgb,var(--text) 32%,transparent); border-radius:1px;
  transform-origin:center; transition:background .2s; }
.sf-wave.playing .sf-bars span{ background:var(--text); animation:waveBar .85s ease-in-out infinite alternate; }
@keyframes waveBar{ from{ transform:scaleY(.34); } to{ transform:scaleY(1); } }
.sf-prog{ position:absolute; left:0; top:0; bottom:0; width:0; background:color-mix(in srgb,var(--signal) 16%,transparent);
  border-right:1px solid var(--signal-deep); pointer-events:none; transition:width .1s linear; }
.sf-time{ flex:none; font-family:var(--mono); font-size:12px; color:var(--text); white-space:nowrap; }
.sf-time span{ color:var(--text-dim); }

/* live "Tune in" CTA (replaces the static snippet player) */
.sf-cta{ display:inline-flex; align-items:center; gap:9px; margin:22px 0; cursor:pointer;
  padding:11px 20px 11px 17px; border-radius:999px; border:1px solid var(--text);
  background:var(--text); color:var(--paper);
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  transition:background .2s ease, color .2s ease, transform .15s ease; }
.sf-cta:hover{ transform:translateY(-1px); }
.sf-cta svg{ margin-left:1px; }
.sf-cta.on{ background:var(--signal); border-color:var(--signal); color:var(--ink); }
.sf-cta.on svg{ margin-left:0; }

/* streamed reasoning */
.sf-reason{ border-left:2px solid var(--paper-line-2); padding-left:16px; min-height:5.4em; }
.sf-reason .who{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--signal-deep); }
.sf-reason .line{ margin:7px 0 0; font-size:clamp(15px,1.25vw,17px); line-height:1.5; letter-spacing:-.01em; color:var(--text); }
.sf-reason .cursor{ display:inline-block; width:.5ch; height:1em; background:var(--signal-deep); transform:translateY(.12em); margin-left:.06em; animation:blink 1s steps(2) infinite; }

/* the rest it's pushing */
.sel-list{ display:flex; flex-direction:column; border-top:1px solid var(--paper-line); }
.sl-head{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); padding:18px 0 6px; }
.sl-row{ display:grid; grid-template-columns:auto minmax(0,1fr) auto; align-items:center; gap:14px; cursor:pointer;
  text-align:left; background:transparent; border:0; border-bottom:1px solid var(--paper-line); padding:15px 4px; transition:padding-left .2s, background .2s; }
.sl-row:hover{ padding-left:12px; background:color-mix(in srgb,var(--card) 60%,transparent); }
.sl-row.on{ padding-left:12px; }
.sl-glyph{ flex:none; width:22px; height:22px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--paper-line-2); color:var(--text-dim); transition:color .2s, border-color .2s; }
.sl-row.on .sl-glyph{ color:var(--signal-deep); border-color:var(--signal-deep); }
.sl-tk{ min-width:0; display:flex; flex-direction:column; gap:3px; }
.sl-tk .t{ font-family:var(--grotesk); font-weight:700; font-size:16px; letter-spacing:-.01em; line-height:1.15; }
.sl-row.on .sl-tk .t{ color:var(--signal-deep); }
.sl-tk .a{ font-family:var(--mono); font-size:11.5px; color:var(--text-dim); }
.sl-fresh{ flex:none; font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; }
@media (max-width:440px){ .sl-fresh{ display:none; } }

/* ============================================================
   MANIFESTO  (bilingual quotes, big type, paper)
   ============================================================ */
.manifesto{ background:var(--paper); padding:clamp(90px,15vh,200px) 0; }
.man-list{ display:flex; flex-direction:column; }
.man-q{ display:flex; align-items:baseline; gap:clamp(16px,3vw,48px); padding:clamp(20px,3.4vh,40px) 0;
  border-top:1px solid var(--paper-line); }
.man-q:last-child{ border-bottom:1px solid var(--paper-line); }
.man-q .n{ font-family:var(--mono); font-size:13px; color:var(--text-dim); width:3ch; flex:none; padding-top:.6em; }
.man-q .txt{ font-size:clamp(28px,5.2vw,76px); line-height:.98; letter-spacing:-.03em; font-weight:900; text-wrap:balance; }
.man-q .txt em{ font-style:normal; color:var(--sig-blue-d); }
.man-q:nth-child(3) .txt em{ color:var(--sig-red-d); }
.man-q .reg{ margin-left:auto; flex:none; align-self:flex-start; padding-top:.9em;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
@media (max-width:680px){ .man-q .reg{ display:none; } }

/* ============================================================
   FOOTER / CTA
   ============================================================ */
.foot{ background:var(--paper-2); color:var(--text); padding:clamp(56px,8vh,96px) 0 40px; position:relative; overflow:hidden; }
.foot .cta{ display:flex; align-items:flex-start; justify-content:space-between; gap:40px; flex-wrap:wrap; margin-bottom:clamp(50px,8vh,100px); }
.foot .cta h2{ font-size:clamp(56px,12vw,200px); line-height:.82; letter-spacing:-.04em; text-transform:uppercase; }
.foot .cta h2 em{ font-style:normal; color:var(--signal-deep); }
.foot-sub{ max-width:36ch; }
.foot-sub p{ font-family:var(--mono); font-size:13px; line-height:1.6; color:var(--text-dim); }
.signup{ display:flex; gap:0; margin-top:22px; border:1px solid var(--paper-line-2); border-radius:2px; overflow:hidden; max-width:340px; }
.signup input{ flex:1; background:transparent; border:0; color:var(--text); font-family:var(--mono); font-size:13px; padding:13px 14px; outline:none; }
.signup input::placeholder{ color:var(--text-dim); }
.signup button{ background:var(--signal); color:var(--ink); border:0; padding:0 18px; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; }
.foot-grid{ display:flex; justify-content:space-between; gap:30px; flex-wrap:wrap; border-top:1px solid var(--paper-line); padding-top:30px; }
.foot-col h5{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); font-weight:500; margin:0 0 14px; }
.foot-col a{ display:block; font-family:var(--mono); font-size:13px; color:var(--text); opacity:.82; padding:5px 0; line-height:1.35; white-space:nowrap; transition:opacity .2s,color .2s; }
.foot-col a:hover{ opacity:1; color:var(--signal-deep); }
.foot-bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:50px;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--text-dim); }

/* the wordmark — small header above the closing line */
.foot-mark{ margin-bottom:20px; }
.foot-word{ font-family:var(--grotesk); font-weight:800; font-size:clamp(26px,3vw,40px);
  line-height:.95; letter-spacing:-.03em; color:var(--text); display:inline-block; white-space:nowrap; }
.foot-word .sl{ font-weight:700; color:var(--signal-deep); }

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001s !important; animation-iteration-count:1 !important; }
}

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ---- live additions (play affordance on the orb) ---- */
.stage-orb { position: relative; }
.orb-play {
  position: absolute; inset: 0; margin: auto; width: 132px; height: 132px;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 9px;
  background: rgba(8, 9, 8, .5); color: #efeee7; border: 1px solid rgba(239, 238, 231, .35);
  border-radius: 50%; cursor: pointer; backdrop-filter: blur(3px); transition: .2s; padding-left: 4px;
}
.orb-play span { font: 11px/1 "JetBrains Mono", monospace; text-transform: uppercase; letter-spacing: .16em; }
.orb-play:hover { border-color: var(--signal); color: var(--signal); transform: scale(1.04); }

/* ---- next-transition indicator (AI-native, not a radio waveform) ---- */
.next-mix { margin-top: 18px; max-width: 460px; }
.nm-bar {
  position: relative; height: 3px; border-radius: 3px;
  background: rgba(239, 238, 231, .12); overflow: visible;
}
.nm-fill {
  position: absolute; left: 0; top: 0; bottom: 0; border-radius: 3px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--signal) 55%, transparent), var(--signal));
  transition: width .9s linear; box-shadow: 0 0 8px color-mix(in srgb, var(--signal) 60%, transparent);
}
/* the mark where the crossfade begins — a subtle tick on the bar (no floating dot) */
.nm-mark {
  position: absolute; top: -2px; width: 2px; height: 7px; border-radius: 1px;
  background: rgba(239, 238, 231, .4);
}
.nm-label {
  margin-top: 9px; font-family: "JetBrains Mono", monospace; font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase; color: var(--text-dim, #8a8c84);
}
.nm-label b { color: var(--signal); font-weight: 700; }

/* now-playing vitals — mood / bpm / key / energy, visible on landing */
.stage-vitals { display: flex; flex-wrap: wrap; align-items: center; gap: 9px 10px; margin-top: 14px; }
.stage-vitals .vital { display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px; border: 1px solid var(--paper-line-2, rgba(20,20,18,.14)); border-radius: 999px;
  font-family: "JetBrains Mono", monospace; font-size: 11px; line-height: 1; white-space: nowrap; }
.stage-vitals .vk { letter-spacing: .14em; text-transform: uppercase; color: var(--text-dim, #8a8c84); font-size: 9.5px; }
.stage-vitals .vv { color: var(--text); font-weight: 500; text-transform: capitalize; }
.stage-vitals .vbar { display: inline-block; width: 46px; height: 5px; border-radius: 3px;
  background: color-mix(in srgb, var(--text) 12%, transparent); overflow: hidden; }
.stage-vitals .vbar-fill { display: block; height: 100%; border-radius: 3px;
  background: linear-gradient(90deg, var(--signal-deep, #12b466), var(--signal, #19e07c)); }

/* teleprompter reasoning: fixed field, newest text always in view (no clipping) */
.stage-reason { display: flex; flex-direction: column; }
.stage-reason .line { flex: 1 1 auto; min-height: 0; overflow: hidden; }

/* memory drawer: per-track chips (time / key / bpm / energy / mood) */
.ti-line { align-items: baseline; }
.ti-time { font-family: var(--mono); font-size: 10.5px; letter-spacing: .04em; color: var(--text-dim); white-space: nowrap; padding-top: 2px; }
.ti-chips { display: flex; flex-wrap: wrap; gap: 5px 6px; margin-top: 9px; }
.ti-chip { font-family: var(--mono); font-size: 9.5px; letter-spacing: .05em; text-transform: uppercase;
  color: var(--text-dim); border: 1px solid var(--paper-line-2); border-radius: 999px; padding: 3px 8px; white-space: nowrap; }
.ti-chip.key { color: var(--signal-deep); border-color: color-mix(in srgb, var(--signal) 38%, transparent); }
.ti-chip.mood { text-transform: capitalize; }

/* email-capture success modal + form states */
.sub-modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 24px;
  background: color-mix(in srgb, var(--ink, #0a0b0a) 62%, transparent); backdrop-filter: blur(6px);
  animation: subIn .2s ease; }
.sub-card { position: relative; max-width: 420px; width: 100%; text-align: center;
  background: var(--paper); color: var(--text); border: 1px solid var(--paper-line-2);
  border-radius: 8px; padding: 34px 30px; box-shadow: 0 30px 80px rgba(0,0,0,.35); animation: subUp .25s ease; }
.sub-card .sub-glyph { color: var(--signal-deep); font-size: 20px; }
.sub-card h3 { font-family: var(--grotesk); font-weight: 800; font-size: clamp(22px,2.4vw,26px); margin: 12px 0 8px; letter-spacing: -.02em; }
.sub-card p { font-size: 14px; line-height: 1.6; color: var(--text-dim); margin: 0 0 22px; }
.sub-card button { background: var(--text); color: var(--paper); border: 0; border-radius: 999px; cursor: pointer;
  font-family: var(--mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; padding: 11px 26px; }
.sub-card button:hover { background: var(--signal); color: var(--ink); }
@keyframes subIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes subUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.signup.err { border-color: #ff5a3c; }
.signup-msg { margin-top: 10px; font-family: var(--mono); font-size: 11px; letter-spacing: .02em; }
.signup-msg.err { color: #ff5a3c; }

/* mobile polish: the stage centres on phones, so centre the live components too */
@media (max-width: 880px) {
  .stage-vitals { justify-content: center; }
  .next-mix { margin-left: auto; margin-right: auto; }
  .nm-label { text-align: center; }
}
@media (max-width: 420px) {
  .stage-vitals { gap: 7px; }
  .stage-vitals .vital { padding: 5px 9px; }
  .stage-vitals .vbar { width: 38px; }
  .sub-card { padding: 28px 22px; }
}
