/* RetroWeb Archive Cockpit — Sprint 3 visual fidelity pass */
:root {
  --bg: #02070f;
  --bg-2: #04101a;
  --bg-panel: #06131d;
  --bg-panel-2: #081b29;
  --bg-panel-3: #0b2232;
  --bg-well: #00040a;
  --line: rgba(103, 247, 255, 0.42);
  --line-strong: rgba(103, 247, 255, 0.75);
  --cyan: #67f7ff;
  --cyan-2: #1bb9d6;
  --cyan-dim: #1a8da6;
  --text: #d8fbff;
  --text-dim: #8ac7d3;
  --text-muted: #5d93a0;
  --green: #42ff9e;
  --red: #ff4d6d;
  --yellow: #ffd166;
  --violet: #c085ff;
  --blue: #68a4ff;
  --orange: #ff9f43;
  --panel-gap: 10px;
  --shadow: 0 0 22px rgba(27, 185, 214, 0.16);
  --inner-shadow: inset 0 0 18px rgba(27, 185, 214, 0.10);
  --font-mono: "Courier New", Consolas, "Lucida Console", monospace;
  --font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { background: var(--bg); color: var(--text); }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at 16% 0%, rgba(27,185,214,0.13), transparent 28%),
    radial-gradient(circle at 80% 8%, rgba(104,164,255,0.08), transparent 32%),
    repeating-linear-gradient(0deg, rgba(103,247,255,0.025) 0, rgba(103,247,255,0.025) 1px, transparent 1px, transparent 6px),
    linear-gradient(135deg, #01040a 0%, #02070f 52%, #06111a 100%);
  color: var(--text);
  font-family: var(--font-mono);
  letter-spacing: 0.01em;
}

button { font: inherit; }
.skip-link {
  position: absolute;
  left: 8px;
  top: -48px;
  z-index: 20;
  background: var(--cyan);
  color: var(--bg);
  padding: 7px 10px;
}
.skip-link:focus { top: 8px; }

.hud-bar {
  position: sticky;
  top: 0;
  z-index: 10;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto minmax(350px, 1.1fr);
  gap: 10px;
  align-items: center;
  min-height: 66px;
  padding: 8px 12px;
  background: linear-gradient(180deg, rgba(2,7,15,.98), rgba(3,14,23,.94));
  border-bottom: 1px solid var(--line-strong);
  box-shadow: 0 0 26px rgba(27, 185, 214, .18), inset 0 -1px 0 rgba(103,247,255,.18);
  backdrop-filter: blur(5px);
}
.hud-bar:after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -3px;
  height: 3px;
  background: linear-gradient(90deg, transparent, rgba(103,247,255,.55), transparent);
  pointer-events: none;
}
.hud-brand { display: flex; align-items: center; gap: 10px; min-width: 0; }
.brand-stack { min-width: 0; }
.hud-brand strong {
  display: block;
  color: var(--cyan);
  font-size: 1.02rem;
  line-height: 1;
  text-shadow: 0 0 10px rgba(103,247,255,.45);
  letter-spacing: .12em;
}
.hud-brand small { display: block; color: var(--text-dim); font-size: .66rem; margin-top: 5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hud-nav { display: flex; gap: 5px; flex-wrap: wrap; justify-content: center; }
.hud-button,
.control-grid button,
.filter-bank button,
.quick-mark-strip button {
  border: 1px solid rgba(103,247,255,.46);
  background: linear-gradient(180deg, rgba(9,35,51,.95), rgba(3,16,25,.95));
  color: var(--text);
  padding: 5px 8px;
  min-height: 28px;
  cursor: pointer;
  text-transform: uppercase;
  font-size: .68rem;
  line-height: 1;
  box-shadow: var(--inner-shadow);
}
button:hover,
button:focus-visible { border-color: var(--cyan); color: #fff; outline: 1px solid rgba(103,247,255,.55); }
.hud-button.active,
.filter-bank .chip.active,
.quick-mark-strip button.active { color: #001014; background: linear-gradient(180deg, var(--cyan), var(--cyan-2)); border-color: var(--cyan); }
.hud-right { justify-self: end; display: grid; grid-template-columns: auto 1fr; gap: 4px 8px; align-items: center; max-width: 100%; }
.session-chip,
.hud-clock {
  border: 1px solid rgba(103,247,255,.28);
  background: rgba(0,8,13,.45);
  padding: 4px 7px;
  font-size: .64rem;
  color: var(--text-dim);
  white-space: nowrap;
}
.hud-clock { grid-column: 1 / -1; text-align: right; color: var(--text-muted); }
.hud-status { display: flex; justify-content: flex-end; gap: 4px; flex-wrap: wrap; }
.status-light,
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1px solid rgba(103,247,255,.35);
  padding: 3px 6px;
  font-size: .60rem;
  line-height: 1;
  text-transform: uppercase;
  color: var(--text-dim);
  background: rgba(3,16,25,.76);
}
.status-light:before,
.led,
.diag-dot {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 8px currentColor;
}
.status-light.ok:before,
.diag-dot.ok { background: var(--green); color: var(--green); }
.status-light.warn:before { background: var(--yellow); color: var(--yellow); }
.led-cyan { color: var(--cyan); background: var(--cyan); margin-right: 6px; }

.pixel-avatar {
  width: 24px;
  height: 24px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 2px;
  padding: 2px;
  border: 1px solid var(--line);
  background: #010810;
  box-shadow: 0 0 10px rgba(103,247,255,.18);
  flex: 0 0 auto;
}
.pixel-avatar span { display: block; background: var(--cyan); opacity: .86; }
.avatar-green span { background: var(--green); }
.avatar-yellow span { background: var(--yellow); }
.avatar-violet span { background: var(--violet); }
.avatar-blue span { background: var(--blue); }
.pixel-avatar span:nth-child(2), .pixel-avatar span:nth-child(3) { opacity: .45; }

.cockpit-shell {
  display: grid;
  grid-template-columns: minmax(270px, 310px) minmax(460px, 1fr) minmax(300px, 360px);
  gap: var(--panel-gap);
  padding: var(--panel-gap);
  align-items: stretch;
  min-height: calc(100vh - 240px);
}
.panel,
.console-card,
.disclaimer {
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(8,27,41,.86), rgba(3,13,22,.94)),
    repeating-linear-gradient(90deg, rgba(103,247,255,.025) 0, rgba(103,247,255,.025) 1px, transparent 1px, transparent 9px);
  box-shadow: var(--shadow), var(--inner-shadow);
  position: relative;
}
.panel:before,
.console-card:before {
  content: "";
  position: absolute;
  top: -1px; left: 10px; right: 10px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(103,247,255,.65), transparent);
}
.panel { padding: 10px; min-width: 0; overflow: hidden; }
.queue-panel,
.radar-panel { display: flex; flex-direction: column; gap: 8px; max-height: calc(100vh - 98px); }
.media-stage { display: flex; flex-direction: column; gap: 8px; min-height: 610px; }
.panel-header,
.stage-title-row,
.console-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  border-bottom: 1px solid rgba(103,247,255,.24);
  padding-bottom: 7px;
}
h1, h2, h3, p { margin: 0; }
.panel h1,
.panel h2,
.console-card h2 { color: var(--cyan); font-size: .88rem; letter-spacing: .09em; text-transform: uppercase; }
.subpanel h3 { color: var(--cyan); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 6px; }
.eyebrow { color: var(--text-muted); font-size: .60rem; text-transform: uppercase; letter-spacing: .14em; margin-bottom: 3px; }
.counter {
  border: 1px solid rgba(103,247,255,.32);
  color: var(--text-dim);
  background: rgba(0,8,13,.55);
  padding: 4px 6px;
  font-size: .62rem;
  white-space: nowrap;
}
.source-rail,
.viewer-toolbar,
.transport-strip,
.queue-table-head {
  display: grid;
  gap: 5px;
  border: 1px solid rgba(103,247,255,.20);
  background: rgba(0,8,13,.42);
  padding: 6px;
  color: var(--text-dim);
  font-size: .62rem;
}
.source-rail { grid-template-columns: auto 1fr; }
.source-rail span { color: var(--text-muted); text-transform: uppercase; }
.source-rail strong { color: var(--text); font-weight: 400; }
.control-grid { display: grid; gap: 5px; }
.jump-grid { grid-template-columns: repeat(7, 1fr); }
.filter-bank { display: flex; gap: 5px; flex-wrap: wrap; }
.filter-bank .chip { flex: 1 1 auto; min-width: fit-content; }
.queue-table-head { grid-template-columns: 28px minmax(0, 1fr) 44px 64px; text-transform: uppercase; color: var(--text-muted); }
.queue-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  overflow: auto;
  padding-right: 2px;
}
.queue-entry {
  width: 100%;
  display: grid;
  grid-template-columns: 28px 5px minmax(0, 1fr) 44px 64px;
  gap: 6px;
  align-items: center;
  min-height: 39px;
  border: 1px solid rgba(103,247,255,.18);
  background: rgba(0,8,13,.44);
  color: var(--text);
  padding: 4px 5px;
  text-align: left;
  cursor: pointer;
}
.queue-entry:hover { border-color: var(--line-strong); background: rgba(8,34,50,.75); }
.queue-entry.active { border-color: var(--cyan); background: linear-gradient(90deg, rgba(27,185,214,.30), rgba(0,8,13,.65)); }
.row-num { color: var(--text-muted); font-size: .62rem; text-align: right; }
.status-edge { width: 5px; height: 29px; background: var(--cyan); box-shadow: 0 0 8px currentColor; }
.queue-entry[data-status="tested"] .status-edge { color: var(--green); background: var(--green); }
.queue-entry[data-status="favorite"] .status-edge { color: var(--violet); background: var(--violet); }
.queue-entry[data-status="broken"] .status-edge { color: var(--red); background: var(--red); }
.queue-entry[data-status="untested"] .status-edge { color: var(--yellow); background: var(--yellow); }
.entry-main { min-width: 0; }
.entry-main strong { display: block; font-size: .70rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.entry-main small { display: block; color: var(--text-muted); font-size: .58rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 3px; }
.type-pill,
.state-pill,
.ext-pill {
  justify-self: end;
  border: 1px solid rgba(103,247,255,.25);
  background: rgba(0,8,13,.62);
  color: var(--text-dim);
  padding: 3px 4px;
  font-size: .55rem;
  text-transform: uppercase;
  white-space: nowrap;
}
.state-pill { max-width: 64px; overflow: hidden; text-overflow: ellipsis; }

.stage-title-row { align-items: center; }
.stage-title-block { min-width: 0; }
.media-stage h2 { color: var(--cyan); font-size: 1.05rem; letter-spacing: .05em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.filename-line { color: var(--text-muted); font-size: .65rem; margin-top: 3px; }
.badge-row { display: flex; gap: 5px; flex-wrap: wrap; justify-content: flex-end; }
.status-badge.untested { border-color: rgba(255,209,102,.6); color: var(--yellow); }
.status-badge.broken { border-color: rgba(255,77,109,.7); color: var(--red); }
.status-badge.tested, .status-badge.tested_ok { border-color: rgba(66,255,158,.65); color: var(--green); }
.status-badge.favorite { border-color: rgba(192,133,255,.7); color: var(--violet); }
.status-badge.format { color: var(--cyan); }
.viewer-toolbar,
.transport-strip { grid-template-columns: repeat(3, 1fr); align-items: center; }
.viewer-toolbar span:nth-child(2), .transport-strip span:nth-child(2) { text-align: center; }
.viewer-toolbar span:nth-child(3), .transport-strip span:nth-child(3), .transport-strip span:nth-child(4) { text-align: right; }
.transport-strip { grid-template-columns: repeat(4, 1fr); }
.safety-chip { color: var(--yellow); }
.viewer-frame {
  position: relative;
  flex: 1 1 auto;
  min-height: 340px;
  border: 1px solid var(--line-strong);
  background: radial-gradient(circle at center, rgba(27,185,214,.07), transparent 45%), #00040a;
  overflow: hidden;
  box-shadow: inset 0 0 28px rgba(103,247,255,.10), 0 0 18px rgba(27,185,214,.14);
}
.screen-grid {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(103,247,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(103,247,255,.045) 1px, transparent 1px);
  background-size: 32px 32px;
  opacity: .55;
  pointer-events: none;
}
.scanline {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(0deg, transparent 0 3px, rgba(103,247,255,.035) 3px 4px);
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 4;
}
.preview-composition { position: absolute; inset: 28px; overflow: hidden; border: 1px solid rgba(103,247,255,.16); background: rgba(0,8,13,.28); }
.preview-label {
  position: absolute;
  left: 10px; bottom: 10px;
  border: 1px solid rgba(103,247,255,.30);
  background: rgba(0,8,13,.74);
  color: var(--text-dim);
  padding: 5px 7px;
  font-size: .64rem;
  z-index: 5;
}
.preview-object, .preview-path, .preview-core { position: absolute; }
.preview-core { left: 50%; top: 50%; width: 54px; height: 54px; margin: -27px 0 0 -27px; border: 2px solid var(--cyan); background: rgba(103,247,255,.08); box-shadow: 0 0 20px rgba(103,247,255,.26); }
.object-a, .object-b, .object-c { border: 1px solid var(--line-strong); background: rgba(103,247,255,.13); box-shadow: 0 0 14px rgba(103,247,255,.18); }
.object-a { left: 13%; top: 18%; width: 42px; height: 42px; }
.object-b { right: 18%; top: 26%; width: 34px; height: 34px; }
.object-c { left: 32%; bottom: 19%; width: 30px; height: 30px; }
.path-a, .path-b { height: 2px; background: linear-gradient(90deg, transparent, var(--cyan), transparent); transform-origin: left center; opacity: .70; }
.path-a { left: 12%; top: 66%; width: 72%; transform: rotate(-16deg); }
.path-b { left: 18%; top: 32%; width: 62%; transform: rotate(20deg); }
.preview-pinball .preview-core { border-radius: 50%; }
.preview-pinball .object-a, .preview-pinball .object-b, .preview-pinball .object-c { border-radius: 50%; }
.preview-maze .preview-core { width: 46px; height: 30px; border-radius: 0 18px 18px 0; transform: rotate(-25deg); }
.preview-maze .preview-composition, .preview-maze { background-image: linear-gradient(90deg, rgba(103,247,255,.13) 2px, transparent 2px), linear-gradient(rgba(103,247,255,.13) 2px, transparent 2px); background-size: 52px 52px; }
.preview-orbit .preview-core { border-radius: 50%; }
.preview-orbit .preview-path { height: 120px; border: 1px solid rgba(103,247,255,.38); border-radius: 50%; background: transparent; }
.preview-orbit .path-a { width: 58%; left: 21%; top: 32%; transform: rotate(12deg); }
.preview-orbit .path-b { width: 44%; left: 28%; top: 26%; transform: rotate(-35deg); }
.preview-animation .object-a { width: 120px; height: 36px; transform: rotate(18deg); border-radius: 50%; }
.preview-animation .object-b { width: 160px; height: 28px; transform: rotate(-12deg); border-radius: 50%; }
.preview-video:before {
  content: ""; position: absolute; left: 8%; right: 8%; bottom: 18%; height: 24px;
  border: 1px solid rgba(103,247,255,.32);
  background: repeating-linear-gradient(90deg, rgba(103,247,255,.22) 0 4px, transparent 4px 22px);
}
.preview-video .preview-core { width: 150px; height: 84px; margin: -42px 0 0 -75px; }
.preview-site .preview-core { width: 220px; height: 140px; margin: -70px 0 0 -110px; border-radius: 0; }
.preview-site .preview-core:before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 20px; background: rgba(103,247,255,.22); border-bottom: 1px solid var(--line); }
.preview-broken { background: repeating-linear-gradient(45deg, rgba(255,77,109,.16) 0 12px, rgba(0,8,13,.42) 12px 24px); }
.preview-broken .preview-core { border-color: var(--red); box-shadow: 0 0 22px rgba(255,77,109,.25); transform: rotate(45deg); }
.preview-broken .object-a, .preview-broken .object-b, .preview-broken .object-c { border-color: var(--red); background: rgba(255,77,109,.13); }
.quick-mark-strip { display: flex; gap: 5px; flex-wrap: wrap; }
.stage-lower-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 8px; min-height: 138px; }
.subpanel {
  border: 1px solid rgba(103,247,255,.22);
  background: rgba(0,8,13,.36);
  padding: 8px;
  min-width: 0;
  overflow: auto;
}
.stage-notes p { color: var(--text-dim); font-size: .68rem; line-height: 1.45; margin-bottom: 7px; }
.metadata-mini,
.readonly-grid { display: grid; grid-template-columns: auto 1fr; gap: 4px 8px; margin: 0; font-size: .62rem; }
.metadata-mini dt,
.readonly-grid span:nth-child(odd) { color: var(--text-muted); text-transform: uppercase; }
.metadata-mini dd { margin: 0; color: var(--text); min-width: 0; overflow-wrap: anywhere; }
.comment-stack,
.thread-stack,
.playlist-stack,
.reaction-stack { display: grid; gap: 6px; }
.comment,
.thread,
.playlist-row,
.reaction-row {
  border-left: 3px solid var(--cyan-dim);
  background: rgba(0,8,13,.42);
  padding: 6px;
  color: var(--text-dim);
  font-size: .62rem;
  line-height: 1.35;
}
.comment strong,
.thread strong,
.playlist-row strong,
.reaction-row strong { display: block; color: var(--text); font-size: .64rem; margin-bottom: 2px; }

.radar-shell { position: relative; aspect-ratio: 1 / 1; min-height: 260px; border: 1px solid rgba(103,247,255,.24); background: radial-gradient(circle, rgba(27,185,214,.11), rgba(0,8,13,.68) 62%, rgba(0,4,10,.95)); overflow: hidden; }
.radar-rings { position: absolute; inset: 10px; border-radius: 50%; background: repeating-radial-gradient(circle, transparent 0 29px, rgba(103,247,255,.12) 30px 31px); opacity: .9; }
.radar-grid { position: absolute; inset: 18px; display: grid; grid-template-columns: repeat(11, 1fr); grid-template-rows: repeat(11, 1fr); gap: 4px; }
.radar-cell {
  min-width: 0;
  min-height: 0;
  border: 1px solid rgba(103,247,255,.10);
  background: rgba(103,247,255,.05);
  padding: 0;
  cursor: default;
}
.radar-cell.cluster { cursor: pointer; border-color: rgba(103,247,255,.45); box-shadow: 0 0 10px currentColor; }
.radar-cell.cluster:after { content: ""; display: block; width: 60%; height: 60%; margin: 20%; border-radius: 50%; background: currentColor; }
.radar-cell.active { outline: 2px solid var(--cyan); outline-offset: 1px; }
.radar-cell.game { color: var(--green); }
.radar-cell.video { color: var(--blue); }
.radar-cell.animation { color: var(--yellow); }
.radar-cell.interactive { color: var(--cyan); }
.radar-cell.site { color: var(--orange); }
.radar-cell.broken { color: var(--red); }
.radar-cell.favorite { color: var(--violet); }
.radar-readout { border: 1px solid rgba(103,247,255,.22); background: rgba(0,8,13,.46); color: var(--text-dim); padding: 7px; font-size: .64rem; min-height: 48px; line-height: 1.35; }
.legend-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 5px; font-size: .60rem; color: var(--text-dim); }
.legend-grid span { border: 1px solid rgba(103,247,255,.18); padding: 5px; background: rgba(0,8,13,.35); }
.legend { display: inline-block; width: 8px; height: 8px; margin-right: 6px; box-shadow: 0 0 7px currentColor; }
.legend.game { color: var(--green); background: var(--green); }
.legend.video { color: var(--blue); background: var(--blue); }
.legend.animation { color: var(--yellow); background: var(--yellow); }
.legend.interactive { color: var(--cyan); background: var(--cyan); }
.legend.site { color: var(--orange); background: var(--orange); }
.legend.broken { color: var(--red); background: var(--red); }
.legend.favorite { color: var(--violet); background: var(--violet); }
.readonly-grid { grid-template-columns: minmax(90px, auto) minmax(0, 1fr); }
.readonly-grid span { padding: 4px 0; border-bottom: 1px solid rgba(103,247,255,.10); overflow-wrap: anywhere; }

.bottom-console {
  display: grid;
  grid-template-columns: 1.1fr 1.2fr 1.1fr 1.1fr 1.2fr;
  gap: var(--panel-gap);
  padding: 0 var(--panel-gap) var(--panel-gap);
}
.console-card { padding: 8px; min-width: 0; min-height: 150px; overflow: hidden; }
.console-head { align-items: center; padding-bottom: 6px; margin-bottom: 6px; }
.console-head h2 { font-size: .72rem; }
.console-head span { color: var(--text-muted); font-size: .58rem; text-transform: uppercase; border: 1px solid rgba(103,247,255,.18); padding: 3px 5px; }
.user-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
.user-card { display: flex; align-items: center; gap: 6px; border: 1px solid rgba(103,247,255,.18); background: rgba(0,8,13,.40); padding: 5px; min-width: 0; }
.user-card span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: .62rem; color: var(--text-dim); }
.diagnostic-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 5px; }
.diagnostic-list li { display: flex; align-items: center; gap: 6px; border: 1px solid rgba(103,247,255,.16); background: rgba(0,8,13,.38); padding: 5px; color: var(--text-dim); font-size: .61rem; }
.disclaimer { margin: 0 var(--panel-gap) var(--panel-gap); padding: 10px 12px; color: var(--text-dim); font-size: .70rem; line-height: 1.5; }
.disclaimer strong { color: var(--yellow); }

.panel.flash-focus,
.console-card.flash-focus { outline: 2px solid var(--cyan); outline-offset: 2px; }

@media (max-width: 1180px) {
  .hud-bar { grid-template-columns: 1fr; }
  .hud-right { justify-self: stretch; grid-template-columns: auto 1fr; }
  .cockpit-shell { grid-template-columns: 280px 1fr; }
  .radar-panel { grid-column: 1 / -1; max-height: none; display: grid; grid-template-columns: minmax(260px, 360px) 1fr; }
  .radar-panel .panel-header, .radar-panel .legend-grid, .radar-panel .readonly-panel { grid-column: auto; }
  .bottom-console { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .cockpit-shell { grid-template-columns: 1fr; }
  .queue-panel, .radar-panel { max-height: none; display: flex; }
  .stage-lower-grid { grid-template-columns: 1fr; }
  .viewer-toolbar, .transport-strip { grid-template-columns: 1fr; }
  .viewer-toolbar span, .transport-strip span { text-align: left !important; }
  .bottom-console { grid-template-columns: 1fr; }
  .hud-nav { justify-content: flex-start; }
}


/* Sprint 6 — media modules, radar routing, and separate pixel icon generator */
.viewer-frame {
  min-height: 360px;
  position: relative;
  overflow: hidden;
}
.media-module-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  background: #01050a;
  z-index: 3;
  display: none;
}
.viewer-frame.module-loaded .media-module-frame { display: block; }
.viewer-frame.module-loaded .preview-composition { display: none; }
.viewer-frame.module-loaded .scanline,
.viewer-frame.module-loaded .screen-grid { pointer-events: none; z-index: 4; opacity: .18; }
.radar-note {
  color: var(--text-dim);
  border: 1px solid rgba(103,247,255,.18);
  background: rgba(103,247,255,.045);
  padding: 7px 8px;
  margin-bottom: 10px;
  font: 11px/1.35 var(--mono);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.radar-cell.linked::after {
  content: "";
  position: absolute;
  inset: 25%;
  border: 1px solid rgba(255,255,255,.65);
  transform: rotate(45deg);
}
.radar-cell.active {
  outline: 2px solid var(--cyan-primary);
  box-shadow: 0 0 12px rgba(103,247,255,.55), inset 0 0 8px rgba(103,247,255,.25);
}
.bottom-console {
  grid-template-columns: minmax(180px, 1fr) minmax(220px, 1.35fr) minmax(220px, 1.2fr) minmax(210px, 1.2fr) minmax(220px, 1.1fr);
}
.icon-generator-card { min-width: 220px; }
.icon-tool-layout {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
}
.icon-grid {
  width: 96px;
  height: 96px;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-template-rows: repeat(8, 1fr);
  border: 1px solid rgba(103,247,255,.48);
  background: #02070f;
  box-shadow: inset 0 0 14px rgba(103,247,255,.08);
}
.icon-pixel {
  border: 1px solid rgba(103,247,255,.08);
  background: rgba(103,247,255,.03);
  cursor: pointer;
}
.icon-pixel.on-1 { background: #67f7ff; box-shadow: 0 0 6px rgba(103,247,255,.65); }
.icon-pixel.on-2 { background: #42ff9e; box-shadow: 0 0 6px rgba(66,255,158,.6); }
.icon-pixel.on-3 { background: #ffd166; box-shadow: 0 0 6px rgba(255,209,102,.6); }
.icon-tool-controls { display: grid; gap: 6px; }
.icon-tool-controls button {
  border: 1px solid rgba(103,247,255,.38);
  background: rgba(6,19,29,.82);
  color: var(--cyan-primary);
  font: 10px var(--mono);
  text-transform: uppercase;
  padding: 6px 8px;
  cursor: pointer;
}
.icon-tool-controls button:hover { background: rgba(103,247,255,.12); }
.icon-caption {
  color: var(--text-dim);
  font: 10px/1.35 var(--mono);
  letter-spacing: .03em;
  text-transform: uppercase;
}
.queue-entry.has-module .entry-main strong::after {
  content: "  ▶";
  color: var(--status-ok);
  font-size: 10px;
}
.status-badge.tested_demo { border-color: rgba(66,255,158,.65); color: #42ff9e; }
.status-badge.html { border-color: rgba(103,247,255,.65); color: #67f7ff; }
@media (max-width: 1200px) {
  .bottom-console { grid-template-columns: repeat(2, minmax(220px, 1fr)); }
}
@media (max-width: 720px) {
  .icon-tool-layout { grid-template-columns: 1fr; }
  .icon-grid { width: 128px; height: 128px; }
}


/* Sprint 7 — radar cell repair, larger aligned icon generator, and audio module */
.radar-shell {
  min-height: 232px;
  aspect-ratio: 1 / 1;
  padding: 10px;
  overflow: hidden;
}
.radar-rings {
  inset: 9px;
  border-radius: 0;
  background:
    linear-gradient(rgba(103,247,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(103,247,255,.05) 1px, transparent 1px),
    radial-gradient(circle at 50% 50%, transparent 0 31%, rgba(103,247,255,.12) 32% 32.5%, transparent 33% 48%, rgba(103,247,255,.09) 49% 49.5%, transparent 50%);
  background-size: 18px 18px, 18px 18px, 100% 100%;
  opacity: .9;
}
.radar-grid {
  inset: 16px;
  gap: 3px;
  place-items: stretch;
}
.radar-cell {
  position: relative;
  width: auto;
  height: auto;
  aspect-ratio: 1 / 1;
  border-radius: 2px;
  border: 1px solid rgba(103,247,255,.16);
  background: rgba(103,247,255,.035);
  padding: 0;
  overflow: hidden;
}
.radar-cell.cluster {
  border-color: color-mix(in srgb, currentColor 72%, #67f7ff 28%);
  background: rgba(0, 8, 13, .7);
  box-shadow: 0 0 5px currentColor, inset 0 0 7px rgba(255,255,255,.08);
}
.radar-cell.cluster::after,
.radar-cell.linked::after {
  content: "";
  position: absolute;
  inset: 28%;
  display: block;
  width: auto;
  height: auto;
  margin: 0;
  border: 0;
  border-radius: 2px;
  background: currentColor;
  box-shadow: 0 0 8px currentColor;
  transform: none;
}
.radar-cell.linked::before {
  content: "";
  position: absolute;
  inset: 12%;
  border: 1px solid rgba(255,255,255,.32);
  opacity: .75;
}
.radar-cell.active {
  outline: 1px solid var(--cyan);
  outline-offset: 1px;
  box-shadow: 0 0 12px rgba(103,247,255,.55), inset 0 0 8px rgba(103,247,255,.25);
}
.radar-cell.audio { color: #f472ff; }
.radar-cell.image { color: #9ddcff; }
.legend.audio { color: #f472ff; background: #f472ff; }
.legend.image { color: #9ddcff; background: #9ddcff; }

.audio-stage {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  padding: 26px;
  background:
    radial-gradient(circle at 50% 38%, rgba(244,114,255,.16), transparent 34%),
    linear-gradient(180deg, rgba(0,10,18,.98), rgba(0,4,10,.98));
  color: var(--text);
}
.audio-stage[hidden] { display: none; }
.audio-panel-title {
  color: #f472ff;
  border: 1px solid rgba(244,114,255,.45);
  background: rgba(244,114,255,.06);
  padding: 6px 10px;
  font: 11px var(--mono);
  letter-spacing: .12em;
}
.audio-stage h3 { margin: 0; font: 700 1.35rem var(--mono); color: var(--cyan); text-align: center; }
.audio-stage p { margin: 0; color: var(--text-dim); font: 12px var(--mono); }
.audio-stage audio { width: min(620px, 94%); filter: hue-rotate(145deg) saturate(1.2); }
.audio-readout { color: var(--text-dim); font: 11px var(--mono); text-transform: uppercase; letter-spacing: .08em; }
.audio-bars { width: min(620px, 92%); height: 92px; display: grid; grid-template-columns: repeat(12, 1fr); align-items: end; gap: 7px; padding: 12px; border: 1px solid rgba(244,114,255,.28); background: rgba(0,8,13,.54); }
.audio-bars i { display: block; background: linear-gradient(180deg, #f472ff, #67f7ff); box-shadow: 0 0 10px rgba(244,114,255,.55); min-height: 16px; animation: audioBar 1.4s ease-in-out infinite alternate; }
.audio-bars i:nth-child(1) { height: 28%; animation-delay: -.2s; }
.audio-bars i:nth-child(2) { height: 68%; animation-delay: -.4s; }
.audio-bars i:nth-child(3) { height: 42%; animation-delay: -.6s; }
.audio-bars i:nth-child(4) { height: 88%; animation-delay: -.8s; }
.audio-bars i:nth-child(5) { height: 52%; animation-delay: -1.0s; }
.audio-bars i:nth-child(6) { height: 75%; animation-delay: -1.2s; }
.audio-bars i:nth-child(7) { height: 36%; animation-delay: -.3s; }
.audio-bars i:nth-child(8) { height: 92%; animation-delay: -.7s; }
.audio-bars i:nth-child(9) { height: 58%; animation-delay: -.5s; }
.audio-bars i:nth-child(10) { height: 80%; animation-delay: -.9s; }
.audio-bars i:nth-child(11) { height: 46%; animation-delay: -1.1s; }
.audio-bars i:nth-child(12) { height: 64%; animation-delay: -.1s; }
@keyframes audioBar { to { transform: scaleY(.54); opacity: .75; } }
.viewer-frame.audio-loaded .media-module-frame,
.viewer-frame.audio-loaded .preview-composition { display: none; }
.viewer-frame.audio-loaded .audio-stage { display: grid; }

.bottom-console {
  grid-template-columns: minmax(170px, .8fr) minmax(360px, 1.75fr) minmax(220px, 1.05fr) minmax(220px, 1.05fr) minmax(230px, 1.05fr);
  align-items: stretch;
}
.console-card { min-height: 196px; }
.icon-generator-card { min-width: 360px; }
.icon-tool-layout {
  grid-template-columns: 184px minmax(130px, 1fr);
  align-items: start;
  gap: 12px;
}
.icon-grid-wrap { display: grid; gap: 6px; justify-items: center; }
.icon-grid-label {
  justify-self: stretch;
  text-align: center;
  color: var(--text-dim);
  font: 10px var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  border: 1px solid rgba(103,247,255,.18);
  padding: 4px;
  background: rgba(0,8,13,.36);
}
.icon-grid {
  width: 168px;
  height: 168px;
  aspect-ratio: 1 / 1;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(12, 1fr);
  border: 1px solid rgba(103,247,255,.64);
  background:
    linear-gradient(rgba(103,247,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(103,247,255,.06) 1px, transparent 1px), #02070f;
  background-size: calc(100% / 12) calc(100% / 12), calc(100% / 12) calc(100% / 12), auto;
}
.icon-pixel { border: 1px solid rgba(103,247,255,.055); }
.icon-pixel.on-4 { background: #f472ff; box-shadow: 0 0 6px rgba(244,114,255,.62); }
.icon-tool-controls { align-content: start; }
.icon-tool-controls button { min-height: 30px; }
.icon-tool-controls button.active { background: rgba(103,247,255,.18); border-color: rgba(103,247,255,.75); }
.icon-palette { display: grid; grid-template-columns: repeat(4, 1fr); gap: 5px; }
.icon-palette i { height: 16px; border: 1px solid rgba(255,255,255,.25); box-shadow: 0 0 7px currentColor; }
.icon-palette .p1 { color: #67f7ff; background: #67f7ff; }
.icon-palette .p2 { color: #42ff9e; background: #42ff9e; }
.icon-palette .p3 { color: #ffd166; background: #ffd166; }
.icon-palette .p4 { color: #f472ff; background: #f472ff; }
.queue-entry[data-type="audio"] .status-edge { background: #f472ff; box-shadow: 0 0 8px #f472ff; }
.status-badge.audio, .status-badge.mp3 { border-color: rgba(244,114,255,.7); color: #f472ff; }
@media (max-width: 1200px) {
  .bottom-console { grid-template-columns: repeat(2, minmax(260px, 1fr)); }
  .icon-generator-card { min-width: 0; }
}
@media (max-width: 720px) {
  .icon-tool-layout { grid-template-columns: 1fr; }
  .icon-grid { width: 180px; height: 180px; }
}


/* Sprint 8 — icon paint tool, filled forum preview, and audio spectrum visual */
.bottom-console {
  grid-template-columns: minmax(160px, .75fr) minmax(420px, 2fr) minmax(360px, 1.7fr) minmax(220px, .95fr) minmax(220px, .95fr);
}
.icon-generator-card { min-width: 420px; min-height: 250px; }
.icon-tool-layout { grid-template-columns: minmax(220px, 230px) minmax(150px, 1fr); gap: 14px; align-items: start; }
.icon-grid { width: 216px; height: 216px; border-color: rgba(103,247,255,.72); }
.icon-pixel { min-width: 0; min-height: 0; }
.icon-pixel.on-5 { background: #ff9f1c; box-shadow: 0 0 6px rgba(255,159,28,.62); }
.icon-pixel.on-6 { background: #5aa9ff; box-shadow: 0 0 6px rgba(90,169,255,.62); }
.icon-pixel.on-7 { background: #e6fbff; box-shadow: 0 0 6px rgba(230,251,255,.62); }
.active-color-readout {
  display: grid; grid-template-columns: 1fr auto; gap: 6px; align-items: center;
  border: 1px solid rgba(103,247,255,.22); background: rgba(0,8,13,.38); padding: 5px 6px;
  color: var(--text-dim); font: 10px var(--mono); text-transform: uppercase; letter-spacing: .06em;
}
.active-color-readout strong { color: var(--cyan); font-weight: 700; }
.icon-palette { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }
.icon-palette .swatch {
  height: 24px; min-height: 24px; padding: 0; border: 1px solid rgba(230,251,255,.25);
  background: var(--swatch); box-shadow: 0 0 8px color-mix(in srgb, var(--swatch) 70%, transparent);
  cursor: pointer;
}
.icon-palette .swatch.erase { background: repeating-linear-gradient(45deg, #02070f 0 6px, rgba(103,247,255,.12) 6px 12px); }
.icon-palette .swatch.active { outline: 2px solid var(--cyan); outline-offset: 2px; }
.icon-command-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; }
.icon-tool-controls .icon-command-row button {
  min-height: 24px; padding: 4px 5px; font-size: 9px; letter-spacing: .08em;
}
.icon-caption { border-top: 1px solid rgba(103,247,255,.14); padding-top: 6px; }

.forum-card { min-width: 360px; min-height: 250px; }
.forum-filter-rail { display: flex; gap: 4px; overflow-x: auto; padding-bottom: 5px; margin-bottom: 5px; }
.forum-chip {
  flex: 0 0 auto; border: 1px solid rgba(103,247,255,.25); background: rgba(0,8,13,.45); color: var(--text-dim);
  font: 9px var(--mono); text-transform: uppercase; padding: 4px 6px; cursor: pointer;
}
.forum-chip.active, .forum-chip:hover { color: var(--cyan); border-color: rgba(103,247,255,.70); background: rgba(103,247,255,.10); }
.thread-stack { max-height: 145px; overflow: auto; padding-right: 2px; }
.thread.forum-row {
  width: 100%; display: grid; grid-template-columns: 88px minmax(0, 1fr); gap: 3px 8px; text-align: left; cursor: pointer;
  border-left-color: rgba(103,247,255,.38); margin: 0; color: var(--text-dim);
}
.thread.forum-row strong { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.thread.forum-row span:last-child { grid-column: 2; font-size: .57rem; color: var(--text-muted); }
.thread.forum-row.active { border-color: rgba(103,247,255,.55); border-left-color: var(--cyan); background: rgba(103,247,255,.08); }
.forum-category { color: var(--yellow); font-size: .55rem; text-transform: uppercase; }
.thread-detail {
  margin-top: 6px; border: 1px solid rgba(103,247,255,.20); background: rgba(0,8,13,.45); padding: 6px;
  color: var(--text-dim); font: 10px/1.35 var(--mono); min-height: 46px;
}
.thread-stage-link {
  margin-top: 5px; border: 1px solid rgba(103,247,255,.32); background: rgba(6,19,29,.72); color: var(--cyan);
  font: 9px var(--mono); text-transform: uppercase; padding: 4px 6px; cursor: pointer;
}
.thread-stage-link:hover { background: rgba(103,247,255,.12); }

.audio-stage { gap: 9px; padding: 18px; }
.spectrum-monitor {
  width: min(680px, 96%); border: 1px solid rgba(244,114,255,.32); background: rgba(0,8,13,.62); padding: 10px 10px 7px;
  box-shadow: inset 0 0 18px rgba(103,247,255,.06), 0 0 18px rgba(244,114,255,.09);
}
#spectrum-canvas { display: block; width: 100%; height: clamp(105px, 21vh, 180px); background: #01050a; }
.band-labels { display: grid; grid-template-columns: repeat(10, 1fr); gap: 4px; margin-top: 5px; color: var(--text-muted); font: 9px var(--mono); text-align: center; }
.spectrum-status { margin-top: 6px; color: var(--text-dim); font: 10px var(--mono); text-transform: uppercase; letter-spacing: .06em; text-align: center; }
.mini-command {
  border: 1px solid rgba(244,114,255,.42); background: rgba(244,114,255,.08); color: #f472ff;
  font: 10px var(--mono); letter-spacing: .08em; text-transform: uppercase; padding: 5px 8px; cursor: pointer;
}
.mini-command:hover { background: rgba(244,114,255,.16); }
.audio-bars { display: none; }

@media (max-width: 1300px) {
  .bottom-console { grid-template-columns: repeat(2, minmax(300px, 1fr)); }
  .icon-generator-card, .forum-card { min-width: 0; }
}
@media (max-width: 760px) {
  .icon-tool-layout { grid-template-columns: 1fr; }
  .icon-grid { width: min(216px, 80vw); height: min(216px, 80vw); }
  .thread.forum-row { grid-template-columns: 1fr; }
  .thread.forum-row span:last-child { grid-column: auto; }
}
