/* ============================================================================
   BEACON — kit.css — all blocks/components on tokens
   ============================================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--ink);
  background-color: var(--bg-base);
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 48px 48px, 48px 48px;
  -webkit-font-smoothing: antialiased;
  transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
  overflow-x: hidden;
}

h1, h2, h3, h4 { font-family: var(--font-display); color: var(--ink-strong); margin: 0; line-height: var(--lh-tight); }
p { margin: 0; }
a { color: var(--accent); text-decoration: none; }
img { display: block; max-width: 100%; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--sp-6); }

/* ---- mono utility ---- */
.mono { font-family: var(--font-mono); }
.data {
  font-family: var(--font-mono);
  font-size: var(--fs-data);
  letter-spacing: var(--tracking-data);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.readout { color: var(--readout-ink); text-shadow: 0 0 12px rgba(var(--accent-glow), 0.45); }

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--sp-4);
}
.eyebrow::before {
  content: ""; width: 22px; height: 2px;
  background: var(--accent); box-shadow: 0 0 8px rgba(var(--accent-glow), 0.7);
}

/* ============================================================================
   TOPBAR
   ============================================================================ */
.topbar {
  position: sticky; top: 0; z-index: 100;
  height: var(--header-h);
  display: flex; align-items: center; gap: var(--sp-5);
  padding: 0 var(--sp-6);
  background: color-mix(in srgb, var(--bg-base) 86%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar__brand { display: flex; align-items: center; gap: var(--sp-3); margin-right: auto; }
.topbar__name { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-lg); color: var(--ink-strong); letter-spacing: 0.02em; }
.topbar__name small { display: block; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: var(--tracking-data); color: var(--ink-mute); text-transform: uppercase; }

.topbar__controls { display: flex; align-items: center; gap: var(--sp-3); }

/* emblem (crisp ring + optically centered triangle + accent core) */
.emblem { width: 34px; height: 34px; flex: 0 0 auto; }
.emblem .ring { fill: none; stroke: var(--ink-soft); stroke-width: 2; }
.emblem .tri  { fill: none; stroke: var(--ink-soft); stroke-width: 2; stroke-linejoin: round; }
.emblem .core { fill: var(--accent); filter: drop-shadow(0 0 4px rgba(var(--accent-glow), 0.8)); }

/* segmented track switcher */
.switcher { display: inline-flex; background: var(--bg-overlay); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 3px; }
.switcher button {
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.08em; text-transform: uppercase;
  border: 0; background: transparent; color: var(--ink-mute);
  padding: 6px 12px; border-radius: var(--r-pill); cursor: pointer;
  transition: color var(--dur-fast), background var(--dur-fast);
  min-width: 0; white-space: nowrap;
}
.switcher button[aria-pressed="true"] {
  color: var(--ink-on-accent); background: var(--accent);
  box-shadow: 0 0 14px rgba(var(--accent-glow), 0.55);
}

.theme-toggle {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--bg-overlay); color: var(--ink-soft);
  border: 1px solid var(--border); border-radius: var(--r-pill);
  padding: 7px 14px; cursor: pointer; white-space: nowrap;
  transition: border-color var(--dur-fast), color var(--dur-fast);
}
.theme-toggle:hover { border-color: var(--accent); color: var(--accent); }
.theme-toggle .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px rgba(var(--accent-glow), 0.8); }

/* ============================================================================
   BUTTONS / CHIPS / TAGS / DIVIDERS
   ============================================================================ */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-mono); font-size: var(--fs-sm); letter-spacing: 0.08em; text-transform: uppercase;
  padding: 12px 22px; border-radius: var(--r-2); border: 1px solid transparent; cursor: pointer;
  transition: transform var(--dur-fast), box-shadow var(--dur), background var(--dur), border-color var(--dur), color var(--dur);
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--accent); color: var(--ink-on-accent); box-shadow: 0 0 0 rgba(var(--accent-glow),0); }
.btn--primary:hover { box-shadow: 0 0 22px rgba(var(--accent-glow), 0.6); }
.btn--ghost {
  background: transparent; color: var(--ink-strong);
  border-color: var(--border-strong);
}
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn--on-image {
  background: rgba(7,11,28,0.45); color: var(--c-white);
  border-color: rgba(255,255,255,0.55); backdrop-filter: blur(4px);
}
.btn--on-image:hover { border-color: var(--accent); color: var(--accent); }
.btn--sm { padding: 8px 14px; font-size: var(--fs-xs); }

.tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.1em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-1);
  border: 1px solid var(--border); color: var(--ink-soft); background: var(--bg-overlay);
}
.tag--accent { border-color: var(--accent); color: var(--accent); }
.tag .led { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 7px rgba(var(--accent-glow),0.9); }

.chip {
  font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.06em;
  padding: 5px 12px; border-radius: var(--r-pill);
  background: var(--bg-overlay); border: 1px solid var(--border); color: var(--ink-soft);
}

.divider { height: 1px; background: var(--border); border: 0; margin: var(--sp-7) 0; }
.divider--glow { background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.7; }

/* ============================================================================
   SECTION / BAND scaffolding
   ============================================================================ */
.section { padding: var(--sp-9) 0; }
.section--tight { padding: var(--sp-7) 0; }

/* filled bands ride theme-aware tokens (dark in dark) and get inner padding */
.band { background: var(--bg-raised); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.band__inner { max-width: var(--maxw); margin: 0 auto; padding: var(--sp-8) var(--sp-6); }
.band--sunken { background: var(--bg-sunken); }
.band--accent {
  background:
    radial-gradient(140% 120% at 0% 0%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 60%),
    var(--bg-overlay);
}

.section-head { max-width: 720px; margin-bottom: var(--sp-7); }
.section-head h2 { font-size: var(--fs-h2); margin-bottom: var(--sp-3); }
.section-head p { color: var(--ink-soft); font-size: var(--fs-lg); }

/* ============================================================================
   HERO  (image-led, bottom-anchored, balanced air, viewport-aware)
   ============================================================================ */
.hero {
  position: relative; overflow: hidden;
  min-height: calc(100svh - var(--header-h));
  display: flex; align-items: flex-end;
  border-bottom: 1px solid var(--border);
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(var(--img-brightness)) saturate(0.65) contrast(1.04);
}
/* colorized instrumentation duotone — gradient overlays only, no multiply */
.hero__media::before {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(125deg, rgba(var(--accent-glow), 0.30), transparent 45%),
    linear-gradient(300deg, rgba(var(--accent-2-glow), 0.22), transparent 50%);
  mix-blend-mode: screen;
}
.hero__media::after {
  content: ""; position: absolute; inset: 0;
  background:
    var(--img-overlay),
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(7,11,28,0.05) 3px 4px);
}
.hero__inner { position: relative; z-index: 2; max-width: 760px; padding: var(--sp-9) var(--sp-6) var(--sp-8); }
/* localized bottom scrim so white hero copy reads in both themes without darkening the whole photo */
.hero::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 70%; z-index: 1;
  background: linear-gradient(0deg, rgba(7,11,28,0.78) 0%, rgba(7,11,28,0.40) 32%, transparent 100%);
  pointer-events: none;
}
.hero h1 { font-size: var(--fs-display); color: var(--c-white); letter-spacing: -0.01em; }
.hero h1 .hl { color: var(--accent); text-shadow: 0 0 28px rgba(var(--accent-glow), 0.55); }
.hero__sub { margin-top: var(--sp-5); font-size: var(--fs-lg); color: var(--c-indigo-100); max-width: 52ch; }
.hero__cta { margin-top: var(--sp-6); display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.hero__eyebrow { color: var(--accent); text-shadow: 0 0 14px rgba(var(--accent-glow), 0.6); }
.hero__readout {
  position: absolute; top: var(--sp-6); right: var(--sp-6); z-index: 3;
  display: flex; flex-direction: column; gap: 4px; text-align: right;
  padding: var(--sp-3) var(--sp-4);
  background: rgba(7,11,28,0.5); border: 1px solid rgba(255,255,255,0.18); border-radius: var(--r-2);
  backdrop-filter: blur(4px);
}
.hero__readout .k { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--c-indigo-200); }
.hero__readout .v { font-family: var(--font-mono); font-size: var(--fs-data); color: var(--accent); }

/* type-led hero variant */
.hero--type { display: block; min-height: auto; background: var(--bg-base); }
.hero--type .hero__inner { padding-top: var(--sp-9); }
.hero--type h1 { color: var(--ink-strong); }
.hero--type .hero__sub { color: var(--ink-soft); }

/* ============================================================================
   GRID helpers
   ============================================================================ */
.grid { display: grid; gap: var(--sp-5); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid > * { min-width: 0; }

/* ============================================================================
   CARD
   ============================================================================ */
.card {
  background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--r-3);
  padding: var(--sp-6); box-shadow: var(--elev-1);
  transition: border-color var(--dur), box-shadow var(--dur), transform var(--dur);
}
.card:hover { border-color: var(--accent); box-shadow: var(--elev-2); }
.card__index { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); color: var(--accent); }
.card h3 { font-size: var(--fs-h3); margin: var(--sp-3) 0 var(--sp-2); }
.card p { color: var(--ink-soft); }

/* ============================================================================
   FOUR PRINCIPLES
   ============================================================================ */
.principle { position: relative; padding: var(--sp-6); border: 1px solid var(--border); border-radius: var(--r-3); background: var(--bg-raised); overflow: hidden; }
.principle::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--ch); box-shadow: 0 0 14px var(--ch); }
.principle .num { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); color: var(--ch); }
.principle h3 { font-size: var(--fs-h3); margin: var(--sp-2) 0; }
.principle p { color: var(--ink-soft); font-size: var(--fs-sm); }
/* each principle a different channel hue → multi-color */
.principle:nth-child(1) { --ch: var(--sig-cyan); }
.principle:nth-child(2) { --ch: var(--sig-lime); }
.principle:nth-child(3) { --ch: var(--sig-amber); }
.principle:nth-child(4) { --ch: var(--sig-magenta); }

/* ============================================================================
   LINEAGE — evidence split
   ============================================================================ */
.lineage { display: grid; grid-template-columns: 1.05fr 1fr; gap: var(--sp-7); align-items: center; }
.lineage__media { position: relative; border-radius: var(--r-3); overflow: hidden; border: 1px solid var(--border); aspect-ratio: 3/2; background: var(--bg-sunken); }
.lineage__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(var(--img-brightness)) saturate(0.6) contrast(1.05); }
.lineage__media::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(115deg, rgba(var(--accent-glow),0.26), transparent 50%),
    linear-gradient(300deg, rgba(var(--accent-2-glow),0.20), transparent 55%);
  mix-blend-mode: screen;
}
.lineage__media .scan { content:""; position:absolute; inset:0; background: repeating-linear-gradient(0deg, transparent 0 3px, rgba(7,11,28,0.06) 3px 4px); pointer-events:none; }
.chain { list-style: none; padding: 0; margin: var(--sp-5) 0 0; display: grid; gap: var(--sp-2); }
.chain li { display: flex; align-items: center; gap: var(--sp-3); font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--ink-soft); }
.chain li .node { width: 10px; height: 10px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 9px rgba(var(--accent-glow),0.8); flex: 0 0 auto; }
.chain li b { color: var(--ink-strong); }

/* ============================================================================
   TRACK CARDS + feature header
   ============================================================================ */
.track-card { position: relative; border: 1px solid var(--border); border-radius: var(--r-3); overflow: hidden; background: var(--bg-raised); }
.track-card__media { position: relative; aspect-ratio: 16/9; background: var(--bg-sunken); overflow: hidden; }
.track-card__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(var(--img-brightness)) saturate(0.6) contrast(1.05); }
.track-card__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(160deg, rgba(var(--ch-glow),0.30), transparent 55%), linear-gradient(0deg, rgba(7,11,28,0.55), transparent 50%);
  mix-blend-mode: screen;
}
.track-card__body { padding: var(--sp-5); }
.track-card__body h3 { font-size: var(--fs-h3); margin-bottom: var(--sp-2); }
.track-card__body p { color: var(--ink-soft); font-size: var(--fs-sm); }
.track-card .tag { position: absolute; top: var(--sp-3); left: var(--sp-3); z-index: 2; background: rgba(7,11,28,0.55); border-color: var(--ch); color: var(--ch); }
.track-card .tag .led { background: var(--ch); box-shadow: 0 0 7px var(--ch); }
/* per-card channel coloring so the row reads multi-color */
.track-card[data-ch="cyan"]    { --ch: var(--sig-cyan);    --ch-glow: var(--g-cyan); }
.track-card[data-ch="amber"]   { --ch: var(--sig-amber);   --ch-glow: var(--g-amber); }
.track-card[data-ch="lime"]    { --ch: var(--sig-lime);    --ch-glow: var(--g-lime); }
.track-card[data-ch="magenta"] { --ch: var(--sig-magenta); --ch-glow: var(--g-magenta); }

/* feature header re-skins to the live track accent */
.track-feature { position: relative; border: 1px solid var(--border); border-radius: var(--r-4); overflow: hidden; min-height: 320px; display: flex; align-items: flex-end; }
.track-feature__media { position: absolute; inset: 0; }
.track-feature__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(var(--img-brightness)) saturate(0.6) contrast(1.05); }
.track-feature__media::after {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(115deg, rgba(var(--accent-glow),0.34), transparent 50%),
    linear-gradient(0deg, rgba(7,11,28,0.72), rgba(7,11,28,0.10) 60%);
  mix-blend-mode: screen;
}
.track-feature__inner { position: relative; z-index: 2; padding: var(--sp-7) var(--sp-6); }
.track-feature h3 { color: var(--c-white); font-size: var(--fs-h2); }
.track-feature p { color: var(--c-indigo-100); max-width: 50ch; margin-top: var(--sp-3); }
.track-feature .data { color: var(--accent); }

/* ============================================================================
   STAT / FOOTPRINT STRIP
   ============================================================================ */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-5); }
.stat { padding: var(--sp-5); border: 1px solid var(--border); border-radius: var(--r-3); background: var(--bg-raised); position: relative; }
.stat .v { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); color: var(--ink-strong); line-height: 1; }
.stat .v em { font-style: normal; color: var(--accent); text-shadow: 0 0 16px rgba(var(--accent-glow),0.5); }
.stat .k { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--ink-mute); margin-top: var(--sp-2); }
.stat:nth-child(1) .v em { color: var(--sig-cyan); text-shadow: 0 0 16px rgba(var(--g-cyan),0.5); }
.stat:nth-child(2) .v em { color: var(--sig-lime); text-shadow: 0 0 16px rgba(var(--g-lime),0.5); }
.stat:nth-child(3) .v em { color: var(--sig-amber); text-shadow: 0 0 16px rgba(var(--g-amber),0.5); }
.stat:nth-child(4) .v em { color: var(--sig-magenta); text-shadow: 0 0 16px rgba(var(--g-magenta),0.5); }

/* ============================================================================
   CREDENTIAL / QUOTE
   ============================================================================ */
.quote { border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: var(--r-3); background: var(--bg-raised); padding: var(--sp-7); }
.quote blockquote { margin: 0; font-family: var(--font-display); font-size: var(--fs-h3); color: var(--ink-strong); line-height: var(--lh-snug); }
.quote .by { margin-top: var(--sp-5); display: flex; align-items: center; gap: var(--sp-3); }
.quote .by .name { color: var(--ink-strong); font-weight: 600; }
.quote .by .role { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.08em; color: var(--ink-mute); text-transform: uppercase; }
.quote .avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--bg-inset); border: 1px solid var(--accent); display: grid; place-items: center; font-family: var(--font-mono); color: var(--accent); }

/* ============================================================================
   CTA BAND
   ============================================================================ */
.cta {
  position: relative; overflow: hidden;
  background:
    radial-gradient(120% 140% at 100% 0%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 55%),
    radial-gradient(120% 140% at 0% 100%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 55%),
    var(--bg-raised);
  border: 1px solid var(--border); border-radius: var(--r-4);
}
.cta__inner { padding: var(--sp-8) var(--sp-7); display: flex; align-items: center; justify-content: space-between; gap: var(--sp-6); flex-wrap: wrap; }
.cta h2 { font-size: var(--fs-h2); max-width: 18ch; }
.cta p { color: var(--ink-soft); margin-top: var(--sp-2); }
.cta__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }

/* ============================================================================
   PHOTO + CAPTION (documentary, treated)
   ============================================================================ */
.photo { border: 1px solid var(--border); border-radius: var(--r-3); overflow: hidden; background: var(--bg-sunken); }
.photo__frame { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.photo__frame img { width: 100%; height: 100%; object-fit: cover; filter: brightness(var(--img-brightness)) saturate(0.6) contrast(1.06); }
.photo__frame::after { content:""; position:absolute; inset:0; background: linear-gradient(120deg, rgba(var(--accent-glow),0.24), transparent 55%); mix-blend-mode: screen; }
.photo__cap { padding: var(--sp-4) var(--sp-5); display: flex; gap: var(--sp-3); align-items: baseline; }
.photo__cap .idx { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--accent); letter-spacing: var(--tracking-data); }
.photo__cap p { font-size: var(--fs-sm); color: var(--ink-soft); }

/* ============================================================================
   FAQ / ACCORDION
   ============================================================================ */
.faq { border: 1px solid var(--border); border-radius: var(--r-3); overflow: hidden; background: var(--bg-raised); }
.faq details { border-bottom: 1px solid var(--border); }
.faq details:last-child { border-bottom: 0; }
.faq summary { list-style: none; cursor: pointer; padding: var(--sp-5) var(--sp-6); display: flex; align-items: center; gap: var(--sp-4); font-family: var(--font-display); color: var(--ink-strong); font-size: var(--fs-lg); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .q { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--accent); letter-spacing: var(--tracking-data); }
.faq summary::after { content: "+"; margin-left: auto; font-family: var(--font-mono); color: var(--accent); font-size: 1.4rem; transition: transform var(--dur); }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details > div { padding: 0 var(--sp-6) var(--sp-5) calc(var(--sp-6) + 3.2rem); color: var(--ink-soft); }

/* ============================================================================
   CONTENT + MEDIA SPLIT
   ============================================================================ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-7); align-items: center; }
.split--rev .split__media { order: -1; }
.split__media { position: relative; border-radius: var(--r-3); overflow: hidden; border: 1px solid var(--border); aspect-ratio: 4/3; background: var(--bg-sunken); }
.split__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(var(--img-brightness)) saturate(0.6) contrast(1.05); }
.split__media::after { content:""; position:absolute; inset:0; background: linear-gradient(125deg, rgba(var(--accent-glow),0.26), transparent 52%); mix-blend-mode: screen; }
.split h2 { font-size: var(--fs-h2); margin-bottom: var(--sp-4); }
.split p { color: var(--ink-soft); }
.split ul { margin: var(--sp-4) 0 0; padding: 0; list-style: none; display: grid; gap: var(--sp-3); }
.split ul li { display: flex; gap: var(--sp-3); align-items: baseline; }
.split ul li::before { content: "›"; color: var(--accent); font-family: var(--font-mono); }

/* ============================================================================
   PROGRESSION — TELEMETRY LADDER (signature mechanic, interactive)
   each rank a different lit channel hue; LEDs glow in-hue; gauges fill in hue.
   ============================================================================ */
.ladder { display: grid; grid-template-columns: 260px 1fr; gap: var(--sp-6); }
.ladder__rail { display: flex; flex-direction: column; gap: var(--sp-2); }
.rung {
  position: relative; text-align: left; cursor: pointer;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--sp-3);
  padding: var(--sp-4); border: 1px solid var(--border); border-radius: var(--r-2);
  background: var(--bg-raised); color: var(--ink-soft);
  font-family: var(--font-mono); transition: border-color var(--dur), background var(--dur), transform var(--dur-fast);
}
.rung:hover { transform: translateX(3px); }
.rung .led { width: 12px; height: 12px; border-radius: 50%; background: var(--bg-inset); border: 1px solid var(--rc); transition: box-shadow var(--dur), background var(--dur); }
.rung .lvl { font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; }
.rung .lvl b { color: var(--ink-strong); display: block; font-family: var(--font-display); letter-spacing: 0; }
.rung .stat-led { font-size: 0.6rem; letter-spacing: 0.12em; color: var(--ink-mute); text-transform: uppercase; }
.rung[aria-selected="true"] { border-color: var(--rc); background: color-mix(in srgb, var(--rc) 10%, var(--bg-raised)); }
.rung[aria-selected="true"] .led { background: var(--rc); box-shadow: 0 0 12px var(--rc); }
.rung[aria-selected="true"] .stat-led { color: var(--rc); }
/* channel per rank */
.rung[data-rank="1"] { --rc: var(--sig-cyan); }
.rung[data-rank="2"] { --rc: var(--sig-lime); }
.rung[data-rank="3"] { --rc: var(--sig-amber); }
.rung[data-rank="4"] { --rc: var(--sig-magenta); }
.rung[data-rank="5"] { --rc: var(--c-white); }

.ladder__panel { border: 1px solid var(--border); border-radius: var(--r-3); background: var(--bg-sunken); padding: var(--sp-6); position: relative; overflow: hidden; }
.ladder__panel::before { content:""; position:absolute; inset:0; background: radial-gradient(120% 100% at 0% 0%, color-mix(in srgb, var(--pc) 12%, transparent), transparent 55%); pointer-events:none; }
.panel-head { display: flex; align-items: center; gap: var(--sp-3); }
.panel-head .badge { width: 14px; height: 14px; border-radius: 50%; background: var(--pc); box-shadow: 0 0 14px var(--pc); }
.panel-head .lvlno { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); color: var(--pc); text-transform: uppercase; }
.ladder__panel h3 { font-size: var(--fs-h2); margin: var(--sp-2) 0 var(--sp-2); position: relative; }
.ladder__panel .desc { color: var(--ink-soft); position: relative; }
.gauge { margin-top: var(--sp-5); position: relative; }
.gauge .glabel { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; }
.gauge .track-bar { height: 8px; border-radius: var(--r-pill); background: var(--bg-inset); overflow: hidden; border: 1px solid var(--border); }
.gauge .fill { height: 100%; width: 0; background: var(--pc); box-shadow: 0 0 14px var(--pc); border-radius: var(--r-pill); transition: width var(--dur-slow) var(--ease); }
.unlocks { margin-top: var(--sp-5); list-style: none; padding: 0; display: grid; gap: var(--sp-3); position: relative; }
.unlocks li { display: flex; gap: var(--sp-3); align-items: flex-start; font-size: var(--fs-sm); color: var(--ink); }
.unlocks li .u-led { margin-top: 6px; width: 8px; height: 8px; border-radius: 50%; background: var(--pc); box-shadow: 0 0 8px var(--pc); flex: 0 0 auto; }
.unlocks li b { color: var(--ink-strong); }
/* panel channel by selected rank, set via JS data-rank on panel */
.ladder__panel[data-rank="1"] { --pc: var(--sig-cyan); }
.ladder__panel[data-rank="2"] { --pc: var(--sig-lime); }
.ladder__panel[data-rank="3"] { --pc: var(--sig-amber); }
.ladder__panel[data-rank="4"] { --pc: var(--sig-magenta); }
.ladder__panel[data-rank="5"] { --pc: var(--c-white); }

/* ============================================================================
   TOKEN / SPEC BOARD (index only)
   ============================================================================ */
.specboard { display: grid; gap: var(--sp-6); }
.swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: var(--sp-3); }
.sw { border: 1px solid var(--border); border-radius: var(--r-2); overflow: hidden; background: var(--bg-raised); }
.sw .chip-color { height: 56px; }
.sw .meta { padding: var(--sp-2) var(--sp-3); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--ink-mute); }
.sw .meta b { color: var(--ink-strong); display: block; }

.ramp { display: flex; border-radius: var(--r-2); overflow: hidden; border: 1px solid var(--border); }
.ramp span { flex: 1; height: 42px; }

.type-specimen > * { margin-bottom: var(--sp-3); }
.scale-row { display: flex; align-items: baseline; gap: var(--sp-4); border-bottom: 1px solid var(--border-faint); padding-bottom: var(--sp-2); }
.scale-row .label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--ink-mute); width: 70px; flex: 0 0 auto; letter-spacing: 0.08em; }

.spec-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--sp-4); }
.spec-cell { border: 1px solid var(--border); border-radius: var(--r-2); padding: var(--sp-4); background: var(--bg-raised); }
.spec-cell .v { font-family: var(--font-mono); color: var(--accent); font-size: var(--fs-sm); }
.spec-cell .k { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }
.elev-demo { height: 60px; border-radius: var(--r-2); background: var(--bg-raised); margin-bottom: var(--sp-3); }
.elev-demo.e1 { box-shadow: var(--elev-1); }
.elev-demo.e2 { box-shadow: var(--elev-2); }

/* paired light/dark frames in the showcase */
.pair { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
.frame { border: 1px solid var(--border); border-radius: var(--r-3); overflow: hidden; }
.frame__label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--ink-mute); padding: var(--sp-2) var(--sp-4); border-bottom: 1px solid var(--border); background: var(--bg-overlay); }
.frame__body { padding: var(--sp-5); background: var(--bg-base); background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 32px 32px, 32px 32px; }
/* forced-theme frames for showcase pairing */
.frame[data-theme] .frame__body { color: var(--ink); }

/* ============================================================================
   FOOTER
   ============================================================================ */
.footer { background: var(--bg-sunken); border-top: 1px solid var(--border); margin-top: var(--sp-8); }
.footer__inner { max-width: var(--maxw); margin: 0 auto; padding: var(--sp-8) var(--sp-6) var(--sp-7); display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--sp-6); }
.footer__brand { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.footer h4 { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--ink-mute); margin-bottom: var(--sp-3); }
.footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-2); }
.footer ul a { color: var(--ink-soft); font-size: var(--fs-sm); }
.footer ul a:hover { color: var(--accent); }
.footer__bar { border-top: 1px solid var(--border); }
.footer__bar .wrap { display: flex; justify-content: space-between; align-items: center; padding-top: var(--sp-4); padding-bottom: var(--sp-4); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--ink-mute); letter-spacing: 0.06em; flex-wrap: wrap; gap: var(--sp-2); }

/* page intro block on showcase */
.kicker { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--accent); }
.lede { font-size: var(--fs-lg); color: var(--ink-soft); max-width: 70ch; margin-top: var(--sp-4); }
.showcase-title { font-size: var(--fs-h1); margin-top: var(--sp-3); }

.block-label { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-data); text-transform: uppercase; color: var(--ink-mute); margin-bottom: var(--sp-4); display: flex; align-items: center; gap: var(--sp-3); }
.block-label::after { content:""; flex:1; height:1px; background: var(--border); }

/* ============================================================================
   RESPONSIVE — no horizontal overflow at 390px
   ============================================================================ */
@media (max-width: 900px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .lineage, .split, .split--rev { grid-template-columns: 1fr; }
  .split--rev .split__media { order: 0; }
  .ladder { grid-template-columns: 1fr; }
  .ladder__rail { flex-direction: row; flex-wrap: wrap; }
  .rung { flex: 1 1 160px; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .pair { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .wrap { padding: 0 var(--sp-4); }
  .topbar { flex-wrap: wrap; height: auto; padding: var(--sp-3) var(--sp-4); gap: var(--sp-2); }
  .topbar__brand { margin-right: 0; width: 100%; }
  .topbar__controls { width: 100%; justify-content: space-between; gap: var(--sp-2); }
  .switcher button { padding: 6px 9px; }
  .grid-2, .grid-3, .grid-4, .stats { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; }
  .hero__readout { display: none; }
  .hero__inner { padding: var(--sp-8) var(--sp-4) var(--sp-7); }
  .cta__inner { padding: var(--sp-6) var(--sp-5); }
  .band__inner { padding: var(--sp-6) var(--sp-4); }
  .ladder__rail { flex-direction: column; }
}

/* showcase needs a taller header allowance when wrapped — handled by sticky+auto */
