/* ============================================================
   STARFORGED ORACLE — MISSION CONTROL HUD
   Design tokens + layout styles
   ============================================================ */

:root {
  --bg:          #06070b;
  --panel:       rgba(12,12,16,0.35);
  --panel-card:  rgba(12,12,16,0.40);
  --paper:       #f4f1ea;
  --mute:        rgba(244,241,234,0.55);
  --faint:       rgba(244,241,234,0.30);
  --hairline:    rgba(244,241,234,0.18);
  --red:         #e63946;
  --accent-rgb:  230,57,70;   /* RGB triplet of --red, for translucent tints */
  --amber:       #f4a261;
  --ai-amber:    #ffb000;   /* AI output phosphor — old CRT amber */
  --green:       #7bc9a8;
  --ink:         #0c0c10;

  --sans: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono: "IBM Plex Mono", "JetBrains Mono", "SF Mono", ui-monospace, monospace;

  /* CRT tuneable (updated by settings panel) */
  --crt-stripe-opacity: 0.14;
  --crt-scan-opacity:   0.26;
  --crt-vignette:       0.65;
  --crt-sweep-duration: 9s;

  /* Panel tuneable */
  --panel-blur: 3px;

  /* Monitor brightness knob (0.3 – 1.3, applied to HUD elements only) */
  --screen-brightness: 1;
}

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

html, body {
  background: var(--bg);
  color: var(--paper);
  font-family: var(--sans);
  overflow: hidden;
  height: 100vh;
  width: 100vw;
}

/* ── Letterbox stage ───────────────────────────────────────── */
#stage {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: #000;
  overflow: hidden;
}

#scene {
  position: relative;
  width: 1400px;
  height: 900px;
  transform-origin: center center;
  flex-shrink: 0;
  overflow: hidden;
  background: transparent;
  z-index: 1;
}

/* ── Canvas starfield (full-viewport, lives in #stage not #scene) ── */
#starfield {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
  z-index: 0;
}

/* ── Hairline grid (inside windshield frame only) ─────────── */
#grid-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image:
    linear-gradient(var(--hairline) 1px, transparent 1px),
    linear-gradient(90deg, var(--hairline) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: 0.4;
}

/* ── Windshield frame ──────────────────────────────────────── */
#windshield-frame {
  position: absolute;
  top: 32px; bottom: 32px; left: 72px; right: 72px;
  pointer-events: none;
}

#windshield-content {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: auto;
  /* chamfered corners matching inner bezel path */
  clip-path: polygon(
    65px 18px, 1191px 18px,
    1238px 48px, 1238px 801px,
    1221px 818px, 35px 818px,
    18px 801px, 18px 48px
  );
  -webkit-clip-path: polygon(
    65px 18px, 1191px 18px,
    1238px 48px, 1238px 801px,
    1221px 818px, 35px 818px,
    18px 801px, 18px 48px
  );
}

#windshield-svg {
  position: absolute;
  top: -20px; left: -20px;
  width: 1296px; height: 876px;
  overflow: visible;
  z-index: 2;
  pointer-events: none;
}

/* ── HairPanel base ────────────────────────────────────────── */
.hair-panel {
  position: absolute;
  background: var(--panel);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(var(--panel-blur, 3px));
  z-index: 10;
}

/* Monitor brightness: dims the HUD's own light (panels, text, images,
   grid) without dimming the starfield seen through the glass.        */
#windshield-content > .hair-panel,
#grid-overlay {
  filter: brightness(var(--screen-brightness, 1));
}

/* Brightness knob (SVG group in the bezel) is the one interactive
   part of the frame */
#brightness-knob {
  pointer-events: auto;
  cursor: ns-resize;
}

/* ── Region positions (relative to windshield-content interior) */
#top-bar {
  top: 18px; left: 18px; right: 18px;
  height: 56px;
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 28px;
}

#catalog-rail {
  top: 86px; left: 18px;
  width: 96px;
  bottom: 18px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#inquiry-panel {
  top: 86px; left: 126px;
  width: 300px;
  bottom: 18px;
  display: flex;
  flex-direction: column;
  padding: 20px;
}

#output-panel {
  top: 86px; left: 438px; right: 18px;
  bottom: 18px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── CRT overlay layers (opacities driven by CSS vars) ────────── */
#crt-dome {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 999;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(255,255,255,0.05), transparent 60%),
    radial-gradient(ellipse 60% 30% at 20% 95%, rgba(255,255,255,0.03), transparent 60%);
}

#crt-vignette {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 998;
  background: radial-gradient(ellipse at center, transparent 38%, rgba(0,0,0, var(--crt-vignette, 0.65)) 100%);
}

#crt-stripes {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1000;
  background-image: repeating-linear-gradient(
    90deg,
    rgba(255, 0,   80,  var(--crt-stripe-opacity, 0.14)) 0 1px,
    rgba(0,   255, 120, var(--crt-stripe-opacity, 0.14)) 1px 2px,
    rgba(60,  140, 255, var(--crt-stripe-opacity, 0.14)) 2px 3px,
    transparent 3px 4px
  );
  mix-blend-mode: screen;
}

#crt-scanlines {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1001;
  background-image: repeating-linear-gradient(
    180deg,
    rgba(0, 0, 0, var(--crt-scan-opacity, 0.26)) 0 1px,
    transparent 1px 3px
  );
  mix-blend-mode: multiply;
}

#crt-sweep {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1002;
  background: linear-gradient(
    180deg,
    transparent 45%,
    rgba(255,255,255,0.05) 49%,
    rgba(255,255,255,0.08) 50%,
    rgba(255,255,255,0.05) 51%,
    transparent 55%
  );
  background-size: 100% 200%;
  animation: crt-sweep var(--crt-sweep-duration, 9s) linear infinite;
  mix-blend-mode: screen;
}

@keyframes crt-sweep {
  0%   { background-position: 0  100%; }
  100% { background-position: 0 -100%; }
}

/* ── Top bar components ────────────────────────────────────── */
.bar-mark {
  width: 14px; height: 14px;
  background: var(--red);
  flex-shrink: 0;
}

.bar-wordmark {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.bar-wordmark .wm-name {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--paper);
}

.bar-wordmark .wm-build {
  font: 500 9.5px/1 var(--mono);
  color: var(--mute);
  letter-spacing: 0.04em;
}

.bar-divider {
  width: 1px;
  height: 24px;
  background: var(--hairline);
  flex-shrink: 0;
}

.bar-spacer { flex: 1; }

.datum {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.datum .d-label {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.datum .d-value {
  font: 500 14px/1 var(--sans);
  color: var(--paper);
  letter-spacing: -0.01em;
}

.datum .d-value.mono {
  font-family: var(--mono);
  letter-spacing: 0.02em;
}

.datum.right { text-align: right; }

.status-nominal {
  font: 500 10.5px/1 var(--sans);
  color: var(--green);
  letter-spacing: 0.04em;
  white-space: nowrap;
}

/* ── Catalog rail ──────────────────────────────────────────── */
.rail-header {
  padding: 14px 12px 8px;
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  flex-shrink: 0;
}

.rail-list {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex: 1;
}

.rail-list::-webkit-scrollbar { width: 3px; }
.rail-list::-webkit-scrollbar-track { background: transparent; }
.rail-list::-webkit-scrollbar-thumb { background: var(--hairline); }

.rail-item {
  position: relative;
  background: transparent;
  color: var(--mute);
  border: none;
  border-top: 1px solid var(--hairline);
  padding: 11px 12px;
  cursor: pointer;
  text-align: left;
  font: 500 11px/1 var(--sans);
  letter-spacing: -0.005em;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 0.15s, color 0.15s;
}

.rail-item:hover { background: rgba(244,241,234,0.04); color: var(--paper); }

.rail-item.active {
  background: rgba(var(--accent-rgb), 0.12);
  color: var(--paper);
}

.rail-item.active::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--red);
}

.rail-index {
  font: 500 9px/1 var(--mono);
  color: var(--faint);
  width: 18px;
  flex-shrink: 0;
}

/* ── Inquiry panel ─────────────────────────────────────────── */
.inquiry-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 14px;
  flex-shrink: 0;
}

.inquiry-kicker {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.inquiry-heading {
  font: 600 22px/1 var(--sans);
  margin-top: 6px;
  letter-spacing: -0.02em;
  color: var(--paper);
}

.live-dot {
  font: 500 10px/1 var(--mono);
  color: var(--red);
  white-space: nowrap;
}

/* Lock list */
.lock-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.lock-list::-webkit-scrollbar { width: 3px; }
.lock-list::-webkit-scrollbar-track { background: transparent; }
.lock-list::-webkit-scrollbar-thumb { background: var(--hairline); }

.lock-row {
  padding: 10px 0;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  gap: 10px;
}

.lock-row:first-child { border-top: 1px solid var(--hairline); }

.lock-row-inner { flex: 1; min-width: 0; }

.lock-row-label {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.lock-row-value {
  font: 500 14px/1 var(--sans);
  color: var(--paper);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lock-chip {
  font: 600 9px/1 var(--sans);
  color: var(--red);
  letter-spacing: 0.22em;
  padding: 3px 7px;
  border: 1px solid var(--red);
  cursor: pointer;
  flex-shrink: 0;
  background: transparent;
  transition: background 0.15s;
}

.lock-chip:hover { background: rgba(var(--accent-rgb), 0.08); }

.lock-change {
  font: 500 11px/1 var(--sans);
  color: var(--mute);
  cursor: pointer;
  flex-shrink: 0;
  transition: color 0.15s;
  background: none;
  border: none;
}

.lock-change:hover { color: var(--paper); }

/* Lock dropdown */
.lock-dropdown {
  position: absolute;
  background: var(--panel);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(3px);
  z-index: 200;
  max-height: 180px;
  overflow-y: auto;
  min-width: 160px;
}

.lock-dropdown::-webkit-scrollbar { width: 3px; }
.lock-dropdown::-webkit-scrollbar-thumb { background: var(--hairline); }

.lock-dropdown-item {
  padding: 8px 10px;
  font: 500 12px/1 var(--mono);
  color: var(--paper);
  cursor: pointer;
  border-bottom: 1px solid var(--hairline);
}

.lock-dropdown-item:last-child { border-bottom: none; }
.lock-dropdown-item:hover { background: rgba(var(--accent-rgb), 0.08); }

/* Execute roll button */
.roll-area {
  margin-top: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.execute-btn {
  flex: 1;
  padding: 14px 18px;
  background: var(--red);
  color: #fff;
  border: none;
  cursor: pointer;
  font: 600 13px/1 var(--sans);
  letter-spacing: 0.02em;
  transition: opacity 0.15s;
}

.execute-btn:hover { opacity: 0.88; }
.execute-btn:active { opacity: 0.75; }

.roll-hint {
  font: 500 10px/1.3 var(--mono);
  color: var(--mute);
  text-align: right;
  flex-shrink: 0;
}

.roll-hint .hint-sub {
  color: var(--faint);
}

/* ── Core rollers (grouped one-click oracles) ──────────────── */
.core-intro {
  font: 500 11px/1.5 var(--sans);
  color: var(--mute);
  margin-bottom: 12px;
  flex-shrink: 0;
}

.core-roller-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.core-roller-list::-webkit-scrollbar { width: 3px; }
.core-roller-list::-webkit-scrollbar-track { background: transparent; }
.core-roller-list::-webkit-scrollbar-thumb { background: var(--hairline); }

.core-roller-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid var(--hairline);
}
.core-roller-row:first-child { border-top: 1px solid var(--hairline); }

.core-roller-info { flex: 1; min-width: 0; }

.core-roller-name {
  font: 600 14px/1.1 var(--sans);
  color: var(--paper);
  letter-spacing: -0.01em;
}

.core-roller-sub {
  font: 500 8.5px/1 var(--mono);
  color: var(--faint);
  letter-spacing: 0.08em;
  margin-top: 5px;
  text-transform: uppercase;
}

.core-roll-btn {
  flex-shrink: 0;
  font: 600 11px/1 var(--sans);
  letter-spacing: 0.08em;
  color: #fff;
  background: var(--red);
  border: none;
  padding: 9px 20px;
  cursor: pointer;
  transition: opacity 0.15s;
}
.core-roll-btn:hover  { opacity: 0.88; }
.core-roll-btn:active { opacity: 0.75; }

/* Core headline result — centered large text in the output panel */
.core-headline {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 40px 32px;
  text-align: center;
}

.core-hl-kicker {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.core-hl-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.core-hl-line {
  font: 700 52px/1.05 var(--sans);
  color: var(--paper);
  letter-spacing: -0.03em;
}

.core-hl-rolls {
  display: flex;
  gap: 20px;
  justify-content: center;
}

.core-hl-roll {
  font: 500 10px/1 var(--mono);
  color: var(--faint);
  letter-spacing: 0.10em;
}

.core-hl-reroll {
  font: 600 11px/1 var(--sans);
  letter-spacing: 0.08em;
  color: var(--paper);
  background: transparent;
  border: 1px solid var(--hairline);
  padding: 9px 28px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  text-transform: uppercase;
}
.core-hl-reroll:hover  { border-color: var(--red); background: rgba(var(--accent-rgb), 0.06); }

/* MK·II retro overrides for Core headline */
#windshield-content.theme-v2 .core-hl-line {
  text-shadow: 0 0 18px rgba(110,255,160,0.35);
}
#windshield-content.theme-v2 .core-hl-reroll {
  color: var(--green);
  border-color: var(--green);
  text-shadow: 0 0 7px rgba(110,255,170,0.5);
}
#windshield-content.theme-v2 .core-hl-reroll:hover { background: rgba(88,255,157,0.10); }

/* ── Output panel ──────────────────────────────────────────── */
.output-inner {
  padding: 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

/* ── Tab bar ────────────────────────────────────────────────── */
.tab-bar {
  display: flex;
  align-items: flex-end;
  flex-shrink: 0;
  gap: 2px;
  padding: 6px 12px 0;
  border-bottom: 1px solid var(--hairline);
}

.tab-item {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px 5px;
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: 3px 3px 0 0;
  cursor: pointer;
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--faint);
  user-select: none;
  max-width: 130px;
  transition: color 0.12s;
}

.tab-item:hover { color: var(--mute); }

.tab-item.active {
  border-color: var(--hairline);
  border-bottom-color: rgba(12,12,16,0.35);
  color: var(--paper);
  margin-bottom: -1px;
  padding-bottom: 6px;
}

.tab-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tab-close {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--faint);
  font-size: 12px;
  line-height: 1;
  padding: 0 1px;
}

.tab-close:hover { color: var(--red); }

.tab-add {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--faint);
  font-size: 15px;
  line-height: 1;
  padding: 2px 6px 4px;
  margin-left: 2px;
  border-radius: 3px;
  margin-bottom: 1px;
}

.tab-add:hover { color: var(--paper); }

.output-inner::-webkit-scrollbar { width: 4px; }
.output-inner::-webkit-scrollbar-track { background: transparent; }
.output-inner::-webkit-scrollbar-thumb { background: var(--hairline); }

.output-header {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 16px;
  flex-shrink: 0;
}

.output-kicker {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.output-heading {
  font: 600 22px/1 var(--sans);
  margin-top: 6px;
  letter-spacing: -0.02em;
  color: var(--paper);
}

.output-count {
  font: 500 14px/1 var(--mono);
  color: var(--mute);
  margin-left: 6px;
}

.header-spacer { flex: 1; }

/* View toggle */
.view-toggle {
  display: flex;
  gap: 0;
  padding: 3px;
  border: 1px solid var(--hairline);
}

.view-pip {
  padding: 5px 11px;
  background: transparent;
  color: var(--mute);
  font: 500 11px/1 var(--sans);
  cursor: pointer;
  border: none;
  transition: background 0.15s, color 0.15s;
}

.view-pip.active {
  background: rgba(244,241,234,0.10);
  color: var(--paper);
}

.describe-btn {
  padding: 6px 12px;
  background: transparent;
  color: var(--paper);
  border: 1px solid var(--hairline);
  cursor: pointer;
  font: 500 11px/1 var(--sans);
  white-space: nowrap;
  transition: border-color 0.15s, background 0.15s;
}

.describe-btn:hover { border-color: var(--red); background: rgba(var(--accent-rgb), 0.06); }
.describe-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Card grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  flex-shrink: 0;
}

.card-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex-shrink: 0;
}

.card-map {
  flex: 1;
  border: 1px solid var(--hairline);
  display: grid;
  place-items: center;
  color: var(--faint);
  font: 500 12px/1 var(--sans);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* Placeholder text */
.output-placeholder {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font: 500 12px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ── Result card (grid mode) ───────────────────────────────── */
.result-card {
  position: relative;
  min-height: 472px;
  display: flex;
  flex-direction: column;
  background: var(--panel-card);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(3px);
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
  animation: card-in 0.2s ease-out both;
}

.result-card:nth-child(2) { animation-delay: 0.08s; }
.result-card:nth-child(3) { animation-delay: 0.16s; }

@keyframes card-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.result-card.selected {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12);
}

/* Card hero */
.card-hero {
  height: 160px;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--hairline);
  flex-shrink: 0;
}

.card-hero img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.7) brightness(0.55) contrast(1.1);
  display: block;
}

.card-hero-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(12,12,16,0.30) 0%, rgba(12,12,16,0.85) 100%);
  pointer-events: none;
}

.card-crosshair-v {
  position: absolute;
  left: 50%; top: 0; bottom: 0;
  width: 1px;
  background: var(--hairline);
  pointer-events: none;
}

.card-crosshair-h {
  position: absolute;
  top: 50%; left: 0; right: 0;
  height: 1px;
  background: var(--hairline);
  pointer-events: none;
}

.card-hero-strip {
  position: absolute;
  top: 0; left: 0; right: 0;
  display: flex;
  justify-content: space-between;
  padding: 10px 14px;
  font: 500 10px/1 var(--mono);
  color: var(--mute);
  background: linear-gradient(180deg, rgba(12,12,16,0.7), transparent);
  pointer-events: none;
}

.card-hero-name {
  position: absolute;
  left: 14px; right: 14px; bottom: 12px;
  pointer-events: none;
}

.card-name {
  font: 600 26px/1.05 var(--sans);
  color: var(--paper);
  letter-spacing: -0.02em;
}

.card-designation {
  font: 500 10px/1 var(--mono);
  color: var(--mute);
  margin-top: 6px;
  letter-spacing: 0.02em;
}

/* Card rows */
.card-rows {
  padding: 0 14px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.card-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 0;
  border-bottom: 1px solid var(--hairline);
}

.card-row:last-child { border-bottom: none; }

.card-row-label {
  font: 500 10px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  width: 90px;
  flex-shrink: 0;
}

.card-row-value {
  flex: 1;
  font: 500 13.5px/1.2 var(--sans);
  color: var(--paper);
  letter-spacing: -0.005em;
  min-width: 0;
}

.card-row-badge {
  flex-shrink: 0;
}

.card-lock-chip {
  font: 600 9px/1 var(--sans);
  color: var(--red);
  letter-spacing: 0.22em;
  padding: 2px 6px;
  border: 1px solid var(--red);
}

.card-roll-num {
  font: 500 10.5px/1 var(--mono);
  color: var(--mute);
  cursor: pointer;
  transition: color 0.15s;
}

.card-roll-num:hover { color: var(--red); }

/* Card footer */
.card-footer {
  padding: 10px 14px;
  border-top: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font: 500 11px/1 var(--sans);
  flex-shrink: 0;
}

.card-seed {
  color: var(--mute);
}

.card-reroll {
  font: 500 11px/1 var(--sans);
  color: var(--red);
  background: transparent;
  border: 1px solid var(--red);
  padding: 5px 12px;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 0.15s;
}

.card-reroll:hover { background: rgba(var(--accent-rgb), 0.08); }

/* Card list mode */
.card-list-item {
  background: var(--panel-card);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(3px);
  display: flex;
  align-items: stretch;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
  animation: card-in 0.2s ease-out both;
}

.card-list-item:nth-child(2) { animation-delay: 0.08s; }
.card-list-item:nth-child(3) { animation-delay: 0.16s; }

.card-list-item.selected {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12);
}

.card-list-left {
  width: 140px;
  flex-shrink: 0;
  padding: 14px;
  border-right: 1px solid var(--hairline);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.card-list-name {
  font: 600 15px/1.1 var(--sans);
  color: var(--paper);
  letter-spacing: -0.01em;
}

.card-list-desig {
  font: 500 9px/1 var(--mono);
  color: var(--mute);
  margin-top: 5px;
  letter-spacing: 0.02em;
}

.card-list-rows {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  padding: 8px 14px;
  gap: 0;
}

.card-list-row {
  width: 50%;
  display: flex;
  gap: 6px;
  padding: 5px 0;
  border-bottom: 1px solid var(--hairline);
  align-items: baseline;
}

.card-list-row:nth-child(odd) { border-right: 1px solid var(--hairline); padding-right: 10px; }
.card-list-row:nth-child(even) { padding-left: 10px; }

.card-list-label {
  font: 500 9px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  width: 60px;
  flex-shrink: 0;
}

.card-list-value {
  font: 500 11px/1.2 var(--sans);
  color: var(--paper);
  flex: 1;
}

.card-list-footer {
  width: 80px;
  flex-shrink: 0;
  border-left: 1px solid var(--hairline);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px;
}

/* ── Description section ───────────────────────────────────── */
.description-section {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--hairline);
  flex-shrink: 0;
}

.description-kicker {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

/* AI output: bright amber phosphor, like an old CRT terminal */
.description-text {
  font: 400 13.5px/1.75 var(--mono);
  color: var(--ai-amber);
  text-shadow: 0 0 6px rgba(255,176,0,0.30);
}

.description-text p { margin-bottom: 1em; }
.description-text p:last-child { margin-bottom: 0; }

.description-text h2 {
  font: 600 16px/1.3 var(--mono);
  color: #ffc94d;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 1.4em 0 0.2em;
}
.description-text h2:first-child { margin-top: 0; }

.description-text h3 {
  font: 500 11.5px/1.4 var(--mono);
  color: rgba(255,176,0,0.75);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 1em;
}

.description-text strong { color: #ffd166; font-weight: 600; }
.description-text em     { color: rgba(255,205,100,0.85); }

.description-text ul { margin: 0.6em 0 1em; padding-left: 1.4em; }
.description-text li { margin: 0.35em 0; }
.description-text li::marker { color: rgba(255,176,0,0.55); }

.description-text hr {
  border: none;
  border-top: 1px dashed rgba(255,176,0,0.35);
  margin: 1.6em 0;
}

/* ── Animations ────────────────────────────────────────────── */
@keyframes flash-red {
  0%   { color: var(--red); }
  100% { color: var(--paper); }
}

.flash { animation: flash-red 0.6s ease-out; }

/* ── Scrollbar defaults ────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--hairline); }
::-webkit-scrollbar-thumb:hover { background: var(--mute); }

/* ── Settings button (top bar) ─────────────────────────────── */
.settings-btn {
  background: none;
  border: 1px solid var(--hairline);
  color: var(--faint);
  width: 26px; height: 26px;
  cursor: pointer;
  font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color 0.15s, border-color 0.15s;
  padding: 0;
}
.settings-btn:hover,
.settings-btn.active { color: var(--paper); border-color: var(--mute); }

/* ── Settings panel ────────────────────────────────────────── */
#settings-panel {
  position: absolute;
  right: 92px; top: 90px;
  width: 288px;
  max-height: 720px;
  overflow-y: auto;
  z-index: 2000;
  background: rgba(8,8,12,0.94);
  border: 1px solid var(--hairline);
  backdrop-filter: blur(14px);
}

#settings-panel::-webkit-scrollbar { width: 3px; }
#settings-panel::-webkit-scrollbar-thumb { background: var(--hairline); }

.sp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--hairline);
  flex-shrink: 0;
}
.sp-title {
  font: 500 9px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.sp-close {
  background: none; border: none;
  color: var(--faint); cursor: pointer;
  font-size: 12px; line-height: 1; padding: 2px;
}
.sp-close:hover { color: var(--red); }

.sp-tabs {
  display: flex;
  border-bottom: 1px solid var(--hairline);
  flex-shrink: 0;
}
.sp-tab {
  flex: 1;
  padding: 7px 4px;
  background: none; border: none;
  border-right: 1px solid var(--hairline);
  color: var(--faint);
  font: 500 8.5px/1 var(--sans);
  letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer;
}
.sp-tab:last-child { border-right: none; }
.sp-tab.active { color: var(--paper); background: rgba(244,241,234,0.06); }
.sp-tab:hover:not(.active) { color: var(--mute); }

.sp-row {
  padding: 9px 14px;
  border-bottom: 1px solid var(--hairline);
  display: flex; align-items: center; gap: 8px;
  min-height: 36px;
}
.sp-row:last-child { border-bottom: none; }
.sp-row-label {
  font: 500 9.5px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.12em; text-transform: uppercase;
  flex: 1;
}

.sp-toggle {
  font: 600 8px/1 var(--sans);
  letter-spacing: 0.20em;
  padding: 3px 8px;
  border: 1px solid;
  background: transparent; cursor: pointer;
  flex-shrink: 0;
  transition: background 0.12s;
}
.sp-toggle.on  { color: var(--red);   border-color: var(--red); }
.sp-toggle.off { color: var(--faint); border-color: var(--hairline); }
.sp-toggle.on:hover  { background: rgba(var(--accent-rgb), 0.10); }
.sp-toggle.off:hover { background: rgba(244,241,234,0.04); }

.sp-slider-row {
  padding: 8px 14px 10px;
  border-bottom: 1px solid var(--hairline);
}
.sp-slider-row:last-of-type { border-bottom: none; }
.sp-slider-hd {
  display: flex; justify-content: space-between;
  margin-bottom: 7px;
}
.sp-slider-label {
  font: 500 9px/1 var(--sans);
  color: var(--faint);
  letter-spacing: 0.12em; text-transform: uppercase;
}
.sp-slider-val {
  font: 500 10px/1 var(--mono);
  color: var(--mute);
}

.sp-slider {
  width: 100%;
  -webkit-appearance: none; appearance: none;
  height: 2px;
  background: var(--hairline);
  outline: none; cursor: pointer;
}
.sp-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 10px; height: 10px;
  background: var(--paper); cursor: pointer;
}
.sp-slider::-moz-range-thumb {
  width: 10px; height: 10px;
  background: var(--paper); border: none; cursor: pointer;
}

.sp-swatches {
  display: flex; gap: 8px; flex-wrap: wrap;
  padding: 10px 14px 12px;
  border-bottom: 1px solid var(--hairline);
}
.sp-swatch {
  width: 26px; height: 26px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform 0.12s;
}
.sp-swatch:hover  { transform: scale(1.12); }
.sp-swatch.active { border-color: var(--paper); }

.sp-reset {
  width: 100%; padding: 10px;
  background: transparent; border: none;
  border-top: 1px solid var(--hairline);
  color: var(--faint);
  font: 500 8.5px/1 var(--sans);
  letter-spacing: 0.16em; text-transform: uppercase;
  cursor: pointer; text-align: center; display: block;
}
.sp-reset:hover { color: var(--red); }

/* Segmented control (firmware switcher) */
.sp-seg-wrap {
  padding: 10px 14px;
  border-bottom: 1px solid var(--hairline);
}
.sp-seg {
  display: flex;
  border: 1px solid var(--hairline);
}
.sp-seg-btn {
  flex: 1;
  padding: 7px 4px;
  background: transparent;
  border: none;
  color: var(--faint);
  font: 600 8.5px/1 var(--sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.sp-seg-btn + .sp-seg-btn { border-left: 1px solid var(--hairline); }
.sp-seg-btn.active { color: var(--paper); background: rgba(244,241,234,0.08); }
.sp-seg-btn:hover:not(.active) { color: var(--mute); }

/* ============================================================
   SCREEN FIRMWARE MK·II — 80s retrofuture display
   A software update for the monitor: green phosphor, mono type,
   heavy scanlines, glow and flicker. Scoped to the screen interior
   only — the frame and the stars outside are untouched.
   ============================================================ */
#windshield-content.theme-v2 {
  --paper:      #9dffbe;
  --mute:       rgba(130,255,170,0.62);
  --faint:      rgba(130,255,170,0.36);
  --hairline:   rgba(90,255,150,0.26);
  --panel:      rgba(2,18,8,0.50);
  --panel-card: rgba(2,20,10,0.55);
  --green:      #58ff9d;
  text-shadow: 0 0 5px rgba(110,255,160,0.28);
}

/* Everything speaks terminal */
#windshield-content.theme-v2 * {
  font-family: var(--mono) !important;
}

#windshield-content.theme-v2 .inquiry-heading,
#windshield-content.theme-v2 .output-heading,
#windshield-content.theme-v2 .card-name,
#windshield-content.theme-v2 .wm-name {
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Chunkier scanlines — visible raster, like a zoomed-in movie monitor */
#windshield-content.theme-v2 #crt-scanlines {
  background-image: repeating-linear-gradient(
    180deg,
    rgba(0, 0, 0, calc(var(--crt-scan-opacity, 0.26) * 1.5)) 0 2px,
    transparent 2px 5px
  );
}

/* Phosphor stripes lean green/cyan */
#windshield-content.theme-v2 #crt-stripes {
  background-image: repeating-linear-gradient(
    90deg,
    rgba(0,   255, 120, calc(var(--crt-stripe-opacity, 0.14) * 1.7)) 0 1px,
    rgba(0,   200, 255, calc(var(--crt-stripe-opacity, 0.14) * 1.1)) 1px 2px,
    rgba(120, 255, 160, calc(var(--crt-stripe-opacity, 0.14) * 0.8)) 2px 3px,
    transparent 3px 4px
  );
}

/* Tube curvature: darker corners + glass highlight up top */
#windshield-content.theme-v2::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 997;
  background:
    radial-gradient(ellipse 120% 90% at 50% 50%, transparent 58%, rgba(0,26,10,0.55) 100%),
    radial-gradient(ellipse 45% 22% at 50% 6%, rgba(160,255,200,0.07), transparent 70%);
}

/* Phosphor bloom + irregular flicker */
#windshield-content.theme-v2::after {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1003;
  background: radial-gradient(ellipse at 50% 45%, rgba(110,255,170,0.06), rgba(110,255,170,0.02) 70%);
  mix-blend-mode: screen;
  animation: v2-flicker 7s linear infinite;
}

@keyframes v2-flicker {
  0%, 100% { opacity: 1; }
  87%      { opacity: 1; }
  88%      { opacity: 0.45; }
  89%      { opacity: 1; }
  93%      { opacity: 0.75; }
  94%      { opacity: 1; }
}

/* Hero images re-phosphored through the green tube */
#windshield-content.theme-v2 .card-hero img {
  filter: brightness(0.55) contrast(1.15) sepia(1) hue-rotate(75deg) saturate(1.7);
}

/* Execute button: outline terminal style instead of solid Swiss red */
#windshield-content.theme-v2 .execute-btn {
  background: transparent;
  border: 1px solid var(--green);
  color: var(--green);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  text-shadow: 0 0 7px rgba(110,255,170,0.5);
}
#windshield-content.theme-v2 .execute-btn:hover  { background: rgba(88,255,157,0.12); opacity: 1; }
#windshield-content.theme-v2 .execute-btn:active { background: rgba(88,255,157,0.22); opacity: 1; }

#windshield-content.theme-v2 .core-roll-btn {
  background: transparent;
  border: 1px solid var(--green);
  color: var(--green);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  text-shadow: 0 0 7px rgba(110,255,170,0.5);
}
#windshield-content.theme-v2 .core-roll-btn:hover  { background: rgba(88,255,157,0.12); opacity: 1; }
#windshield-content.theme-v2 .core-roll-btn:active { background: rgba(88,255,157,0.22); opacity: 1; }

/* AI text keeps its amber phosphor — a second tube color, very 80s */
#windshield-content.theme-v2 .description-text {
  text-shadow: 0 0 6px rgba(255,176,0,0.30);
}
