/*
 * ═══════════════════════════════════════════════════════════════
 *  OBSERVE THE SYSTEM — GLOBAL DESIGN SYSTEM v3
 *  ONE color scheme. ONE typography system. ZERO opacity hacks.
 *  Background: Midnight Navy (not void black)
 *  Built for hours of comfortable reading.
 *  Build-719 · May 2026
 * ═══════════════════════════════════════════════════════════════
 */

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root {

  /* BACKGROUNDS — layered navy, not void black */
  --bg:          #0F172A;   /* page base — slate-900 equivalent */
  --bg-card:     #1E293B;   /* card surface — slate-800 */
  --bg-elevated: #243347;   /* above card — hover/modal */
  --bg-header:   #0A1220;   /* sticky header — darkest layer */
  --bg-input:    #162033;   /* form inputs */

  /* TEXT — solid colors, no rgba opacity hacks */
  --text-primary:  #F1F5F9;   /* headings, primary content — slate-100 */
  --text-body:     #CBD5E1;   /* body copy — slate-300, readable all day */
  --text-muted:    #94A3B8;   /* secondary labels — slate-400 */
  --text-faint:    #64748B;   /* placeholder, disabled — slate-500 */

  /* ACCENT PALETTE — full saturation always */
  --gold:        #D4A017;
  --gold-bright: #FFD700;
  --gold-pale:   #F5C842;
  --teal:        #00E5FF;
  --violet:      #C77DFF;
  --alarm:       #FF4444;
  --amber:       #FFB300;
  --green:       #22C55E;

  /* BORDERS */
  --border:         1px solid rgba(212,160,23,.18);
  --border-card:    1px solid rgba(255,255,255,.08);
  --border-teal:    1px solid rgba(0,229,255,.22);
  --border-alarm:   1px solid rgba(255,68,68,.28);
  --border-violet:  1px solid rgba(199,125,255,.22);

  /* TYPOGRAPHY — 3 fonts visible to user, 1 for code */
  --font-title:  'Cinzel', 'Georgia', serif;
  --font-deco:   'Cinzel Decorative', 'Georgia', serif;
  --font-body:   'EB Garamond', 'Georgia', serif;
  --font-label:  'Rajdhani', 'Arial', sans-serif;
  --font-mono:   'JetBrains Mono', 'Courier New', monospace;

  /* RADII & SPACING */
  --r:     10px;
  --r-sm:   6px;
  --r-lg:  16px;
  --edge:  clamp(16px, 4vw, 32px);
  --max:   960px;
  --max-wide: 1200px;
}

/* ── GLOBAL RESET ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  overflow-x: clip;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
body {
  background: var(--bg);
  color: var(--text-body);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── AMBIENT BACKGROUND ─────────────────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 80% 50% at 20% 0%, rgba(0,229,255,.04) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 80% 0%, rgba(212,160,23,.05) 0%, transparent 55%),
    radial-gradient(ellipse 100% 60% at 50% 100%, rgba(199,125,255,.03) 0%, transparent 60%);
}

/* ── Z-LAYER UTILITY ────────────────────────────────────────── */
.z1 { position: relative; z-index: 1; }

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container  { max-width: var(--max); margin: 0 auto; padding: 0 var(--edge); }
.container-wide { max-width: var(--max-wide); margin: 0 auto; padding: 0 var(--edge); }

/* ── SITE HEADER ────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 300;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  padding: 0 var(--edge);
  background: rgba(10,18,32,.97);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(212,160,23,.14);
  box-shadow: 0 2px 30px rgba(0,0,0,.5);
}
.brand {
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--text-primary);
  text-decoration: none;
  white-space: nowrap;
}
.brand span { color: var(--teal); }

/* ── TRACK BAR ──────────────────────────────────────────────── */
.track-bar {
  position: sticky;
  top: 56px;
  z-index: 290;
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
  padding: .55rem var(--edge);
  background: rgba(10,18,32,.97);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 2px 20px rgba(0,0,0,.4);
}
.track-label {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-faint);
  flex-shrink: 0;
}
.track-btn {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 5px 13px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--r-sm);
  transition: all .18s;
}
.track-btn:hover {
  color: var(--text-primary);
  border-color: rgba(255,255,255,.38);
  background: rgba(255,255,255,.08);
}
/* Per-track active colors */
.track-btn[data-track="full"].active   { color: var(--teal);   border-color: rgba(0,229,255,.6);   background: rgba(0,229,255,.1);   font-weight:700; }
.track-btn[data-track="dinner"].active { color: var(--amber);  border-color: rgba(255,179,0,.6);   background: rgba(255,179,0,.1);   font-weight:700; }
.track-btn[data-track="street"].active { color: var(--alarm);  border-color: rgba(255,68,68,.6);   background: rgba(255,68,68,.1);   font-weight:700; }
.track-btn[data-track="tech"].active   { color: var(--violet); border-color: rgba(199,125,255,.6); background: rgba(199,125,255,.1); font-weight:700; }
.track-btn[data-track="es"].active     { color: var(--gold-pale); border-color: rgba(212,160,23,.6); background: rgba(212,160,23,.1); font-weight:700; }

.lane-toggle {
  display: flex;
  border: 1px solid rgba(212,160,23,.25);
  border-radius: var(--r-sm);
  overflow: hidden;
  margin-left: auto;
}
.lane-btn {
  font-family: var(--font-label);
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 12px;
  background: none;
  border: none;
  cursor: pointer;
  transition: all .2s;
  color: var(--text-muted);
}
.lane-btn.active {
  background: rgba(212,160,23,.15);
  color: var(--gold-pale);
}

/* ── MODULE BADGE ───────────────────────────────────────────── */
.mod-badge {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--teal);
  border: 1px solid rgba(0,229,255,.35);
  padding: 3px 10px;
  border-radius: 3px;
}

/* ── TYPOGRAPHY SCALE ───────────────────────────────────────── */
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--teal);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  margin-bottom: 1.25rem;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content: '';
  width: 40px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--teal));
}
.hero-eyebrow::after {
  background: linear-gradient(90deg, var(--teal), transparent);
}

.hero-title {
  font-family: var(--font-deco);
  font-size: clamp(2.2rem, 9vw, 5.5rem);
  line-height: .88;
  color: var(--text-primary);
  margin-bottom: .75rem;
  letter-spacing: .02em;
}
.hero-title em { color: var(--gold-bright); font-style: normal; }

.hero-sub {
  font-family: var(--font-body);
  font-style: italic;
  font-size: clamp(1rem, 3.5vw, 1.2rem);
  font-weight: 700;
  color: var(--gold-pale);
  line-height: 1.5;
  max-width: 720px;
  margin: 0 auto 2rem;
}

.sec-num {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: .4rem;
}
.sec-title {
  font-family: var(--font-title);
  font-size: clamp(1.3rem, 5vw, 2rem);
  font-weight: 900;
  color: var(--text-primary);
  line-height: 1.1;
  margin-bottom: .65rem;
  letter-spacing: .02em;
}
.sec-title em { color: var(--gold-bright); font-style: normal; }
.sec-sub {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--gold-pale);
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

/* ── CARDS ──────────────────────────────────────────────────── */
.card {
  background: var(--bg-card);
  border: var(--border-card);
  border-radius: var(--r);
  padding: 1.5rem;
  margin-bottom: 1.2rem;
}
.card:hover { background: var(--bg-elevated); }
.card-alarm  { border: var(--border-alarm);  background: rgba(30,8,8,.9); }
.card-teal   { border: var(--border-teal);   background: rgba(4,16,30,.9); }
.card-gold   { border: 1px solid rgba(212,160,23,.28); background: rgba(24,16,4,.9); }
.card-violet { border: var(--border-violet); background: rgba(12,4,26,.9); }

.card-title {
  font-family: var(--font-title);
  font-size: 1rem;
  font-weight: 700;
  color: var(--gold-pale);
  margin-bottom: .6rem;
}
.card-body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.78;
  color: var(--text-body);
}

/* ── STAT BOXES ─────────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 1rem;
  margin: 2rem 0;
}
.stat-box {
  text-align: center;
  padding: 1.25rem .75rem;
  background: var(--bg-card);
  border: var(--border-card);
  border-radius: var(--r);
  transition: transform .15s, background .15s;
}
.stat-box:hover { transform: translateY(-2px); background: var(--bg-elevated); }
.stat-num {
  font-family: var(--font-deco);
  font-size: clamp(2rem, 8vw, 3rem);
  color: var(--alarm);
  line-height: 1;
  margin-bottom: .25rem;
}
.stat-num.teal   { color: var(--teal); }
.stat-num.gold   { color: var(--gold-bright); }
.stat-num.violet { color: var(--violet); }
.stat-num.amber  { color: var(--amber); }
.stat-label {
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold-pale);
}
.stat-src {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--text-faint);
  margin-top: .3rem;
}

/* ── DIVIDERS ───────────────────────────────────────────────── */
.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin: 2.5rem 0;
  opacity: .2;
}
.divider-teal {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--teal), transparent);
  margin: 2.5rem 0;
  opacity: .2;
}

/* ── QOP GATES ──────────────────────────────────────────────── */
.qop {
  background: rgba(4,14,28,.92);
  border-left: 3px solid var(--teal);
  padding: 1rem 1.25rem;
  margin: 1rem 0;
  border-radius: 0 var(--r) var(--r) 0;
}
.qop.alarm  { border-left-color: var(--alarm); }
.qop.gold   { border-left-color: var(--gold-bright); }
.qop.violet { border-left-color: var(--violet); }
.qop-label {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: .4rem;
}
.qop.alarm  .qop-label { color: var(--alarm); }
.qop.gold   .qop-label { color: var(--gold-bright); }
.qop.violet .qop-label { color: var(--violet); }
.qop-body {
  font-family: var(--font-body);
  font-size: .92rem;
  line-height: 1.65;
  color: var(--text-body);
}
.qop-v {
  font-family: var(--font-label);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  margin-top: .5rem;
  color: var(--teal);
}
.qop.alarm  .qop-v { color: var(--alarm); }
.qop.gold   .qop-v { color: var(--gold-bright); }
.qop.violet .qop-v { color: var(--violet); }

/* ── PULL QUOTES ────────────────────────────────────────────── */
.pull-quote {
  background: rgba(24,4,4,.92);
  border-left: 4px solid var(--alarm);
  border-radius: 0 var(--r) var(--r) 0;
  padding: 1.5rem;
  margin: 1.5rem 0;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--text-primary);
}
.pull-quote.gold   { border-left-color: var(--gold-bright); background: rgba(20,14,4,.92); }
.pull-quote.violet { border-left-color: var(--violet);      background: rgba(12,4,26,.92); }
.pull-quote.teal   { border-left-color: var(--teal);        background: rgba(4,16,28,.92); }
.pull-quote cite {
  display: block;
  font-family: var(--font-mono);
  font-size: .75rem;
  color: var(--gold-pale);
  margin-top: .5rem;
  font-style: normal;
  letter-spacing: 1px;
}

/* ── TIMELINE ───────────────────────────────────────────────── */
.timeline { position: relative; padding-left: 2rem; margin: 1.5rem 0; }
.timeline::before {
  content: '';
  position: absolute;
  left: .35rem; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--teal), var(--violet), var(--alarm), var(--gold));
}
.tl-item { position: relative; margin-bottom: 2.25rem; padding-left: 1.5rem; }
.tl-item::before {
  content: '';
  position: absolute;
  left: -1.65rem; top: .4rem;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--gold-bright);
  border: 2px solid var(--bg);
}
.tl-item.alarm  ::before { background: var(--alarm); }
.tl-item.teal   ::before { background: var(--teal); }
.tl-item.violet ::before { background: var(--violet); }
.tl-date {
  font-family: var(--font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--gold-bright);
  margin-bottom: .2rem;
}
.tl-title {
  font-family: var(--font-title);
  font-size: 1rem;
  font-weight: 700;
  color: var(--gold-pale);
  margin-bottom: .3rem;
}
.tl-body {
  font-family: var(--font-body);
  font-size: .97rem;
  line-height: 1.7;
  color: var(--text-body);
}

/* ── INLINE CITATIONS ───────────────────────────────────────── */
sup.cite {
  font-family: var(--font-mono);
  font-size: .62rem;
  color: var(--teal);
  cursor: pointer;
  margin-left: 1px;
  vertical-align: super;
}
sup.cite:hover { color: var(--gold-bright); }

/* ── LANDMINE ITEMS ─────────────────────────────────────────── */
.lm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}
.lm-item {
  background: rgba(22,8,8,.9);
  border: var(--border-alarm);
  border-radius: var(--r);
  padding: 1rem;
  transition: transform .15s, border-color .15s;
}
.lm-item:hover { transform: translateY(-1px); border-color: rgba(255,68,68,.45); }
.lm-head { display: flex; align-items: center; gap: .5rem; margin-bottom: .35rem; }
.lm-name {
  font-family: var(--font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--alarm);
}
.lm-score {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  color: var(--gold-bright);
  margin-left: auto;
}
.lm-desc {
  font-family: var(--font-body);
  font-size: .88rem;
  color: var(--text-muted);
  line-height: 1.5;
}

/* ── VERDICT BLOCK ──────────────────────────────────────────── */
.verdict-block {
  text-align: center;
  padding: 3rem var(--edge);
  background: rgba(22,4,4,.95);
  border: var(--border-alarm);
  border-radius: var(--r);
  margin: 2rem 0;
  box-shadow: 0 0 40px rgba(255,68,68,.07) inset, 0 4px 40px rgba(0,0,0,.4);
}
.verdict-grade {
  font-family: var(--font-deco);
  font-size: clamp(1.8rem, 8vw, 3.5rem);
  color: var(--alarm);
  line-height: 1;
  margin-bottom: .75rem;
}
.verdict-rationale {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--text-primary);
  line-height: 1.68;
  max-width: 640px;
  margin: 0 auto;
}

/* ── OBSERVER NOTICE ────────────────────────────────────────── */
.observer-notice {
  display: block;
  max-width: 680px;
  margin: 0 auto 1.5rem;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  padding: 10px 18px;
  border: 1px solid rgba(212,160,23,.3);
  color: var(--gold-pale);
  background: rgba(212,160,23,.05);
  border-radius: var(--r-sm);
  line-height: 1.7;
  text-align: left;
}

/* ── VERDICT PILL ───────────────────────────────────────────── */
.verdict-pill {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 6px 20px;
  border: 1px solid var(--alarm);
  color: var(--alarm);
  background: rgba(255,68,68,.07);
  border-radius: 3px;
}

/* ── NETWORK MAP ────────────────────────────────────────────── */
.net-box {
  background: rgba(5,10,22,.97);
  border: var(--border-card);
  border-radius: var(--r);
  padding: 1.5rem;
  overflow-x: auto;
}
.net-box pre {
  font-family: var(--font-mono);
  font-size: .74rem;
  line-height: 1.9;
  color: var(--text-primary);
  white-space: pre;
}

/* ── DATA TABLES ────────────────────────────────────────────── */
.data-table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
.data-table th {
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: .6rem .85rem;
  border-bottom: 1px solid rgba(0,229,255,.2);
  text-align: left;
  color: var(--teal);
}
.data-table td {
  font-family: var(--font-mono);
  font-size: .82rem;
  padding: .55rem .85rem;
  border-bottom: 1px solid rgba(255,255,255,.05);
  color: var(--text-body);
}
.data-table tr:hover td { background: rgba(255,255,255,.025); }

/* ── SPLIT COMPARE ──────────────────────────────────────────── */
.split-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1.25rem 0; }
.split-side { border-radius: var(--r); padding: 1.25rem; }
.split-blue { background: rgba(4,14,28,.95); border: var(--border-teal); }
.split-red  { background: rgba(22,4,4,.95);  border: var(--border-alarm); }
.split-label {
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: .5rem;
}
.split-label.blue { color: var(--teal); }
.split-label.red  { color: var(--alarm); }
.split-body { font-family: var(--font-body); font-size: .93rem; line-height: 1.65; color: var(--text-body); }

/* ── LOOSH METERS ───────────────────────────────────────────── */
.loosh-meter { margin: .65rem 0; }
.loosh-label {
  font-family: var(--font-label);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold-pale);
  display: flex;
  justify-content: space-between;
  margin-bottom: .3rem;
}
.loosh-track { height: 8px; background: rgba(255,255,255,.07); border-radius: 4px; overflow: hidden; }
.loosh-fill  { height: 100%; background: linear-gradient(90deg, var(--teal), var(--alarm)); border-radius: 4px; }

/* ── TRACK PANELS ───────────────────────────────────────────── */
.track-content { display: none; }
.track-content.active { display: block; }
.track-panel {
  background: rgba(12,8,28,.97);
  border: var(--border-violet);
  border-left: 3px solid var(--violet);
  border-radius: 0 var(--r-lg) var(--r-lg) 0;
  padding: 2rem;
  margin-top: 1.5rem;
}
.track-panel-title {
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--violet);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid rgba(199,125,255,.18);
}
.track-panel p  { font-family: var(--font-body); font-size: 1rem; line-height: 1.8; color: var(--text-body); margin-bottom: 1rem; }
.track-panel h4 { font-family: var(--font-title); font-size: 1.05rem; font-weight: 700; color: var(--gold-pale); margin: 1.2rem 0 .4rem; }
.track-panel .analogy {
  font-style: italic;
  border-left: 2px solid var(--violet);
  padding: .75rem 1rem;
  margin: 1rem 0;
  border-radius: 0 8px 8px 0;
  background: rgba(199,125,255,.05);
  color: var(--text-body);
}
/* Dinner track overrides */
#track-dinner .track-panel { border-color: rgba(255,179,0,.2); border-left-color: var(--amber); }
#track-dinner .track-panel-title { color: var(--amber); border-bottom-color: rgba(255,179,0,.18); }
/* Street track overrides */
#track-street .track-panel { border-color: var(--border-alarm); border-left-color: var(--alarm); }
#track-street .track-panel-title { color: var(--alarm); border-bottom-color: rgba(255,68,68,.18); }
/* Tech track overrides */
#track-tech .track-panel { border-color: var(--border-teal); border-left-color: var(--teal); }
#track-tech .track-panel-title { color: var(--teal); border-bottom-color: rgba(0,229,255,.18); }
#track-tech .track-panel h4 { font-family: var(--font-mono); color: var(--teal); font-size: .95rem; }
/* Español track overrides */
#track-es .track-panel { border-color: rgba(212,160,23,.2); border-left-color: var(--gold); }
#track-es .track-panel-title { color: var(--gold); border-bottom-color: rgba(212,160,23,.18); }

/* ── SOURCES LIST ───────────────────────────────────────────── */
.sources-list { counter-reset: src; }
.src-item {
  counter-increment: src;
  display: flex;
  gap: .75rem;
  margin-bottom: .7rem;
  padding-bottom: .7rem;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.src-item::before {
  content: counter(src);
  font-family: var(--font-mono);
  font-size: .8rem;
  color: var(--teal);
  flex-shrink: 0;
  min-width: 22px;
  margin-top: .1rem;
}
.src-text { font-family: var(--font-body); font-size: .9rem; line-height: 1.55; color: var(--text-muted); }
.src-type {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: .4rem;
}
.src-primary  { background: rgba(0,229,255,.1);   color: var(--teal); }
.src-official { background: rgba(212,160,23,.1);  color: var(--gold-pale); }
.src-academic { background: rgba(199,125,255,.1); color: var(--violet); }
.src-personal { background: rgba(255,68,68,.1);   color: var(--alarm); }
.src-scripture{ background: rgba(148,0,211,.12);  color: #CC88FF; }

/* ── MODULE FOOTER ──────────────────────────────────────────── */
.mod-footer {
  text-align: center;
  padding: 2rem var(--edge);
  border-top: 1px solid rgba(212,160,23,.1);
}
.mod-footer p {
  font-family: var(--font-label);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--text-faint);
}

/* ── ESOTERIC LANE ──────────────────────────────────────────── */
.esoteric-only { display: none; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 600px) {
  .stats-grid       { grid-template-columns: repeat(2, 1fr); }
  .split-compare    { grid-template-columns: 1fr; }
  .lm-grid          { grid-template-columns: 1fr; }
  .lane-toggle      { display: none; }
  .timeline         { padding-left: 1.5rem; }
  .data-table       { display: block; overflow-x: auto; }
  .track-btn        { font-size: 8px; padding: 5px 10px; letter-spacing: .1em; }
  .track-bar        { gap: .4rem; padding: .5rem .85rem; }
}
@media (max-width: 390px) {
  .container        { padding: 0 1rem; }
  .site-header      { padding: 0 1rem; }
  .hero-title       { font-size: 2rem; }
}

/* ── SCROLLBAR ──────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: rgba(212,160,23,.3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(212,160,23,.5); }

/* ── UTILITY ────────────────────────────────────────────────── */
.section { padding: 3.5rem 0; }
.text-gold    { color: var(--gold-bright) !important; }
.text-teal    { color: var(--teal)        !important; }
.text-alarm   { color: var(--alarm)       !important; }
.text-violet  { color: var(--violet)      !important; }
.text-primary { color: var(--text-primary)!important; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
strong { color: var(--text-primary); }
a { color: var(--teal); text-decoration: none; }
a:hover { color: var(--gold-bright); }
