/* EMBER — style.css */
/* Stolencow */
/* Widget chrome: cold Stellar Ascent cyan. MOTE/game data: warm amber.
   Two-temperature design: cold machine interface, warm droid presence. */

@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&display=swap');

/* ── Tokens ── */
:root {
  /* Ember amber — MOTE warmth, game data, title */
  --color-primary:       #f0a030;
  --color-primary-mid:   #c07820;
  --color-primary-dark:  #7a4c10;
  --color-alert:         #cc2222;
  --color-alert-dim:     #881818;
  --color-success:       #60c848;
  --color-success-dim:   #3a7830;

  /* Stellar Ascent cyan — widget chrome, structural UI */
  --color-cyan:          #00d4ff;
  --color-cyan-mid:      #0099cc;
  --color-cyan-dark:     #006688;
  --color-secondary:     #2a8a78;   /* teal for sensor/timer dots */

  /* Structural grays — deep cold navy (Stellar Ascent base) */
  --color-bg:            #030810;
  --color-bg-secondary:  #07111e;
  --color-panel:         #0b1a2c;
  --color-panel-deep:    #0e2038;
  --color-border:        #1a3050;
  --color-border-dim:    #102030;

  /* Text */
  --color-text:          #c8e8f5;
  --color-text-dim:      #7aabcc;
  --color-text-dark:     #3d6688;
  --color-text-bright:   #eef8ff;
  --color-bright:        #eef8ff;

  /* Danger dim — tokenized (used by reset/erase buttons) */
  --color-danger-dim:    #664444;
  --color-danger-border: #4a1a1a;

  /* Grid / canvas */
  --color-grid-bg:       #030810;
  --color-grid-line:     #1a3050;
  --color-wall-fill:     #1c2028;
  --color-wall-stroke:   #2e3444;
  --color-obstacle:      #2a2e38;
  --color-goal:          #c07820;

  /* Glow — amber for MOTE, cyan for structure */
  --glow-primary:        0 0 18px rgba(240,160,48,0.55);
  --glow-primary-soft:   0 0 8px  rgba(240,160,48,0.25);
  --glow-cyan:           0 0 14px rgba(0,212,255,0.4);
  --glow-cyan-soft:      0 0 6px  rgba(0,212,255,0.25);
  --glow-alert:          0 0 14px rgba(204,34,34,0.55);

  /* Gradient anchors */
  --gd-amber-dk:         #7a3800;
  --gd-red-dk:           #6a0010;
  --gd-green-dk:         #1e5c10;
  --gd-teal-dk:          #0e4038;
  --gd-cyan-dk:          #003848;

  /* Type — Share Tech Mono: CRT/terminal sci-fi character, purpose-built for screens */
  --font-primary:        'Share Tech Mono', 'Courier New', monospace;

  /* Spacing scale — 4px base grid */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;

  /* Letter-spacing scale — 3 stops only */
  --ls-tight:  1.5px;
  --ls-normal: 2.5px;
  --ls-wide:   4px;

  /* Animation */
  --anim-fast:   80ms;
  --anim-normal: 200ms;
}

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

/* ── Base — dot-grid bg cyan tint (Stellar Ascent) + scanlines ── */
html, body {
  width: 100%;
  height: 100%;
  background-color: var(--color-bg);
  background-image: radial-gradient(rgba(0,200,255,0.038) 1px, transparent 1px);
  background-size: 24px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-primary);
  color: var(--color-text);
  overflow: hidden;
  user-select: none;
  -webkit-user-select: none;
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent, transparent 3px,
    rgba(0,0,0,0.04) 3px, rgba(0,0,0,0.04) 4px
  );
  pointer-events: none;
  z-index: 9999;
}

/* ── Game root ── */
#game-root {
  width: 1200px;
  height: 675px;
  background: var(--color-bg);
  position: relative;
  display: flex;
  flex-direction: column;
}

/* ── Header ── */
#top-bar {
  height: 44px;
  background: linear-gradient(180deg, var(--color-panel-deep), var(--color-panel));
  border: 1px solid var(--color-border);
  border-bottom: none;
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 14px;
  flex-shrink: 0;
  overflow: hidden;
}

#top-bar-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex-shrink: 0;
}

/* EMBER title stays warm amber */
#top-bar-title {
  font-size: 19px;
  letter-spacing: 5px;
  color: var(--color-primary);
  text-shadow: var(--glow-primary-soft);
  text-transform: uppercase;
  white-space: nowrap;
}

#top-bar-sub {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.top-hdiv {
  width: 1px;
  height: 24px;
  background: var(--color-border);
  flex-shrink: 0;
}

.top-hstat {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex-shrink: 0;
}

.top-hstat-lbl {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.top-hstat-val {
  font-size: 17px;
  font-weight: bold;
  color: var(--color-bright);
  line-height: 1;
  text-transform: uppercase;
}

/* Amber = MOTE/game values; cyan = system status; green = ready */
.hv-amber { color: var(--color-primary);  text-shadow: var(--glow-primary-soft); }
.hv-green { color: var(--color-success); }
.hv-red   { color: var(--color-alert); }
.hv-cyan  { color: var(--color-cyan);    text-shadow: var(--glow-cyan-soft); }
.hv-dim   { color: var(--color-text-dim); }

#top-bar-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 14px;
}

.btn-sound {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-dim);
  font-family: var(--font-primary);
  font-size: 10px;
  letter-spacing: var(--ls-normal);
  padding: 4px 10px;
  cursor: pointer;
  text-transform: uppercase;
  transition: border-color var(--anim-fast), color var(--anim-fast);
}

.btn-sound:hover {
  border-color: var(--color-cyan);
  color: var(--color-cyan);
}

.btn-sound.muted {
  color: var(--color-text-dark);
  border-color: var(--color-border-dim);
  opacity: 0.5;
}

/* ── Middle row ── */
#middle-row {
  flex: 1;
  display: flex;
  overflow: hidden;
}

/* ── Side panels ── */
.side-panel {
  width: 200px;
  flex-shrink: 0;
  background: var(--color-panel);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow-y: auto;
  overflow-x: hidden;
  align-self: stretch;
}

#panel-left {
  border: 1px solid var(--color-border);
  border-right: none;
}

#panel-right {
  border: 1px solid var(--color-border);
  border-left: none;
}

/* ── Widget — cold cyan chrome (Stellar Ascent anatomy) ── */
.widget {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-dim);
  padding: 8px 10px;
  position: relative;
  flex-shrink: 0;
}

/* Top highlight — cold cyan (matches Armada/Stellar Ascent exactly) */
.widget::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,212,255,0.2), transparent);
}

.wlbl {
  font-size: 10px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  text-transform: uppercase;
  margin-bottom: var(--space-1);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* Status dot — default cyan (cold structure); amber class for MOTE data */
.dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--color-cyan);
  box-shadow: 0 0 5px var(--color-cyan);
  animation: dot-blink 1.5s infinite;
}

/* Amber dot for MOTE-related widgets */
.dot.amber { background: var(--color-primary); box-shadow: 0 0 5px var(--color-primary); }
.dot.r     { background: var(--color-alert);   box-shadow: 0 0 5px var(--color-alert); }
.dot.g     { background: var(--color-success); box-shadow: 0 0 5px var(--color-success); }
.dot.t     { background: var(--color-secondary); box-shadow: 0 0 5px var(--color-secondary); }
.dot.off   { background: var(--color-text-dark); box-shadow: none; animation: none; }

@keyframes dot-blink { 0%,100%{opacity:1} 50%{opacity:.1} }

/* Big value — default cyan for system data */
.wval {
  font-size: 24px;
  font-weight: bold;
  color: var(--color-cyan);
  line-height: 1;
}

.wval.sm  { font-size: 18px; }
.wval.lg  { font-size: 31px; }

/* Amber value class for MOTE/game data */
.wval.amber-val,
.amber-val { color: var(--color-primary); }

/* Color overrides */
.wval.r   { color: var(--color-alert); }
.wval.g   { color: var(--color-success); }
.wval.t   { color: var(--color-secondary); }
.wval.dim { color: var(--color-text-dim); }

/* Subtext */
.wsub {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
  margin-top: var(--space-1);
}

/* Progress bar — 5px, bordered track, gradient+glow fill */
.prog {
  height: 5px;
  background: var(--color-panel-deep);
  border: 1px solid var(--color-border-dim);
  margin-top: 6px;
  overflow: hidden;
}

.pf {
  height: 100%;
  transition: width 0.3s ease, background 0.5s ease;
}

/* Cyan (structural/system bars) */
.pf.c {
  background: linear-gradient(90deg, var(--gd-cyan-dk), var(--color-cyan));
  box-shadow: 0 0 6px rgba(0,212,255,0.35);
}

/* Amber (MOTE/game bars) */
.pf.a {
  background: linear-gradient(90deg, var(--gd-amber-dk), var(--color-primary));
  box-shadow: 0 0 6px rgba(240,160,48,0.4);
}

/* Red */
.pf.r {
  background: linear-gradient(90deg, var(--gd-red-dk), var(--color-alert));
  box-shadow: 0 0 6px rgba(204,34,34,0.4);
}

/* Green */
.pf.g {
  background: linear-gradient(90deg, var(--gd-green-dk), var(--color-success));
  box-shadow: 0 0 5px rgba(96,200,72,0.3);
}

/* Teal */
.pf.t {
  background: linear-gradient(90deg, var(--gd-teal-dk), var(--color-secondary));
  box-shadow: 0 0 5px rgba(42,138,120,0.3);
}

@keyframes crit-pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.pf.crit { animation: crit-pulse 0.6s infinite; }

/* ── CRT Error Log Widget ── */
.widget-log {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

#dash-log-widget {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
  position: relative;
}

.log-crt-wrap {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 4px;
  min-height: 0;
  /* CRT phosphor fade mask — older lines fade toward top */
  mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.4) 20%, black 60%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.4) 20%, black 60%);
}

.log-crt-line {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.7;
  /* typewriter-style — new lines flash bright */
  transition: color 0.1s;
}

.log-crt-line.fresh {
  color: var(--color-cyan);
  text-shadow: 0 0 8px rgba(0,212,255,0.5);
}

/* CRT scanline texture layered over the log */
#dash-log-widget::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.12) 2px, rgba(0,0,0,0.12) 3px
  );
  pointer-events: none;
  z-index: 1;
}

/* ── Inventory ── */
#inventory-list {
  display: flex;
  flex-direction: column;
}

.inv-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 10px;
  cursor: pointer;
  border-left: 2px solid transparent;
  border-bottom: 1px solid var(--color-border-dim);
  transition: border-color var(--anim-fast), background var(--anim-fast);
  user-select: none;
}

.inv-row:hover {
  background: rgba(0,212,255,0.04);
  border-left-color: var(--color-cyan-dark);
}

.inv-row.selected {
  border-left-color: var(--color-primary);
  background: rgba(240,160,48,0.08);
}

.inv-row.empty {
  opacity: 0.22;
  cursor: default;
  pointer-events: none;
}

.inv-icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}

.inv-label {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text);
  text-transform: uppercase;
  flex: 1;
}

.inv-count {
  font-size: 12px;
  color: var(--color-primary);
  min-width: 14px;
  text-align: right;
  font-weight: bold;
}

/* ── Canvas wrapper ── */
#canvas-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #020308;
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}

#bg-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  display: block;
}

#game-canvas {
  position: relative;
  z-index: 1;
}

/* Canvas corner brackets — 4 corners, amber warm glow */
#canvas-wrap::before,
#canvas-wrap::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  z-index: 5;
  pointer-events: none;
}

#canvas-wrap::before {
  top: 0; left: 0;
  border-top: 2px solid var(--color-primary);
  border-left: 2px solid var(--color-primary);
  box-shadow: -1px -1px 10px rgba(240,160,48,0.3);
}

#canvas-wrap::after {
  top: 0; right: 0;
  border-top: 2px solid var(--color-primary);
  border-right: 2px solid var(--color-primary);
  box-shadow: 1px -1px 10px rgba(240,160,48,0.3);
}

.canvas-corner-bl {
  position: absolute;
  width: 16px; height: 16px;
  bottom: 0; left: 0;
  border-bottom: 2px solid var(--color-primary);
  border-left: 2px solid var(--color-primary);
  box-shadow: -1px 1px 10px rgba(240,160,48,0.3);
  z-index: 5;
  pointer-events: none;
}

.canvas-corner-br {
  position: absolute;
  width: 16px; height: 16px;
  bottom: 0; right: 0;
  border-bottom: 2px solid var(--color-primary);
  border-right: 2px solid var(--color-primary);
  box-shadow: 1px 1px 10px rgba(240,160,48,0.3);
  z-index: 5;
  pointer-events: none;
}

.canvas-scanlines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.07) 2px, rgba(0,0,0,0.07) 4px
  );
}

#game-canvas {
  display: block;
  image-rendering: pixelated;
  align-self: center;
  position: relative;
  z-index: 0;
}

/* ── Ending Screen ── */
@keyframes ending-fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}

#ending-screen {
  display: none;
  position: absolute;
  inset: 0;
  z-index: 35;
  background: #020508;
}

#ending-screen.active {
  display: flex;
  animation: ending-fadein 2s ease both;
}

/* Left half — portrait image, clipped to fill */
#ending-left {
  width: 50%;
  height: 100%;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
  border-right: 1px solid var(--color-border-dim);
}

#ending-portrait {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  opacity: 0;
  animation: ending-fadein 2.5s ease 0.5s both;
}

/* Right half — text content */
#ending-right {
  width: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: 40px 44px;
}

#ending-title {
  font-size: 14px;
  letter-spacing: var(--ls-wide);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

#ending-charge {
  font-size: 10px;
  letter-spacing: var(--ls-normal);
  color: var(--color-primary);
  text-transform: uppercase;
  opacity: 0.7;
}

#ending-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 120px;
}

.ending-line {
  font-size: 12px;
  letter-spacing: 2.5px;
  color: var(--color-text);
  text-transform: uppercase;
  line-height: 1.6;
}

.ending-dot {
  height: 10px;
}

/* #btn-ending-close — fully defined in consolidated .btn section above */

/* ── Title Screen ── */
@keyframes title-fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}

#title-screen {
  display: none;
  position: absolute;
  inset: 0;
  z-index: 30;
  background:
    repeating-linear-gradient(
      0deg,
      transparent, transparent 2px,
      rgba(0,0,0,0.07) 2px, rgba(0,0,0,0.07) 4px
    ),
    rgba(2,6,14,0.91);
  align-items: center;
  justify-content: center;
}

#title-screen.active {
  display: flex;
  animation: title-fadein 600ms ease both;
}

#title-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 36px 52px 40px;
  background: var(--color-panel-deep);
  border: 1px solid var(--color-border);
  position: relative;
  text-align: center;
  width: 560px;
}

#title-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-primary) 30%, var(--color-primary) 70%, transparent);
  box-shadow: 0 0 14px rgba(240,160,48,0.5);
}

#title-eyebrow {
  font-size: 10px;
  letter-spacing: var(--ls-wide);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

#title-logo {
  font-size: 64px;
  letter-spacing: 18px;
  color: var(--color-primary);
  text-shadow: 0 0 30px rgba(240,160,48,0.5), 0 0 60px rgba(240,160,48,0.2);
  line-height: 1;
  text-transform: uppercase;
  padding-right: 18px; /* compensate letter-spacing on last char */
}

.title-divider {
  width: 100%;
  height: 1px;
  background: var(--color-border-dim);
}

#title-demo-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

#title-demo-canvas {
  display: block;
  /* sized by JS — 5 × 64px = 320px */
  image-rendering: pixelated;
}

#title-demo-labels {
  display: flex;
  width: 320px; /* matches canvas width exactly */
  margin-top: 5px;
}

#title-demo-labels span {
  font-size: 9px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
  flex: 1;
  text-align: center;
}

#title-instructions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 2px 0;
}

.title-line {
  font-size: 10px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dim);
  text-transform: uppercase;
}

.title-line.title-line-sub {
  font-size: 10px;
  color: var(--color-text-dark);
  margin-top: 2px;
}

#title-entry {
  font-size: 11px;
  letter-spacing: var(--ls-wide);
  color: var(--color-cyan);
  text-transform: uppercase;
  text-shadow: var(--glow-cyan-soft);
}

/* #btn-title-start sizing only — color/hover defined in consolidated .btn section */
#btn-title-start {
  margin-top: 4px;
  font-size: 12px;
  padding: 10px 32px;
}

/* ── Overlay ── */
#overlay {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  pointer-events: none;
  z-index: 10;
}

#overlay.active {
  display: flex;
  pointer-events: all;
}

#overlay.fail-overlay {
  background: rgba(204,34,34,0.14);
  animation: fail-flash 0.3s ease-out;
}

#overlay.win-overlay  { background: rgba(3,8,16,0.86); }
#overlay.init-overlay { background: rgba(3,8,16,0.84); }

@keyframes fail-flash {
  0%   { background: rgba(204,34,34,0.55); }
  100% { background: rgba(204,34,34,0.14); }
}

.overlay-card {
  background: var(--color-panel-deep);
  border: 1px solid var(--color-border);
  padding: 20px 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  min-width: 300px;
  position: relative;
}

.overlay-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,212,255,0.25), transparent);
}

.overlay-eyebrow {
  font-size: 10px;
  letter-spacing: var(--ls-wide);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.overlay-title {
  font-size: 22px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--color-alert);
  text-shadow: var(--glow-alert);
  line-height: 1;
  font-weight: bold;
}

.overlay-title.win {
  color: var(--color-primary);
  text-shadow: var(--glow-primary);
}

.overlay-title.init {
  color: var(--color-text-bright);
  text-shadow: none;
  font-size: 16px;
  letter-spacing: 4px;
}

#overlay-countdown {
  font-size: 64px;
  font-weight: bold;
  letter-spacing: 6px;
  color: var(--color-primary);
  text-shadow: var(--glow-primary);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

#overlay-countdown:empty {
  display: none;
}

#overlay-countdown.go {
  color: var(--color-text-bright);
  text-shadow: 0 0 24px rgba(255,255,255,0.6);
  font-size: 52px;
  letter-spacing: 12px;
}

@keyframes countdown-pop {
  0%   { transform: scale(1.45); opacity: 0.6; }
  40%  { transform: scale(1.0);  opacity: 1;   }
  100% { transform: scale(0.92); opacity: 0.7; }
}

#overlay-countdown.pop {
  animation: countdown-pop 0.85s ease-out forwards;
}

.overlay-divider {
  width: 100%;
  height: 1px;
  background: var(--color-border);
  margin: 3px 0;
}

.overlay-sub {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text);
  text-transform: uppercase;
}

/* overlay-detail: rating stars etc — amber, not teal */
.overlay-detail {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-primary);
  text-transform: uppercase;
}

.overlay-detail:empty {
  display: none;
}

/* Overlay buttons — sizing only; color defined in consolidated .btn section above */
#btn-next-level,
#btn-repeat-mission {
  margin-top: 6px;
  font-size: 11px;
  padding: 8px 22px;
}

/* ── Init scanline sweep ── */
@keyframes scanline-sweep {
  0%   { background-position: 0 -100%; }
  100% { background-position: 0 200%; }
}

.init-scanline {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px, transparent 3px,
    rgba(200,232,245,0.022) 3px, rgba(200,232,245,0.022) 4px
  );
  animation: scanline-sweep 1.4s linear infinite;
  pointer-events: none;
}

/* ── Footer — GO + CLEAR centered ── */
#bottom-bar {
  height: 36px;
  background: linear-gradient(0deg, var(--color-bg-secondary), var(--color-panel));
  border: 1px solid var(--color-border);
  border-top: 1px solid var(--color-border-dim);
  border-bottom: none;
  display: flex;
  align-items: center;
  padding: 0 14px;
  flex-shrink: 0;
}

#footer-left {
  flex: 1;
  display: flex;
  align-items: center;
}

#footer-center {
  display: flex;
  align-items: center;
  gap: 10px;
}

#footer-right {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  align-items: center;
}

/* ── Buttons — base pattern ── */
.btn {
  background: transparent;
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  font-family: var(--font-primary);
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  padding: 5px 16px;
  cursor: pointer;
  text-transform: uppercase;
  transition: background var(--anim-fast), box-shadow var(--anim-fast), border-color var(--anim-fast), color var(--anim-fast);
  flex-shrink: 0;
}

.btn:hover {
  background: rgba(240,160,48,0.08);
  box-shadow: 0 0 10px rgba(240,160,48,0.2);
}

.btn:disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}

/* Modifier: dim/neutral */
.btn-clear {
  border-color: var(--color-border);
  color: var(--color-text-dim);
}

.btn-clear:hover {
  border-color: var(--color-text);
  color: var(--color-text);
  box-shadow: none;
}

/* Modifier: cold cyan */
.btn-cyan {
  border-color: var(--color-cyan);
  color: var(--color-cyan);
}

.btn-cyan:hover {
  background: rgba(0,212,255,0.08);
  box-shadow: 0 0 10px rgba(0,212,255,0.2);
}

/* Modifier: danger dim (erase/reset actions) */
.btn-danger {
  border-color: var(--color-danger-border);
  color: var(--color-danger-dim);
}

.btn-danger:hover {
  border-color: var(--color-alert);
  color: var(--color-alert);
}

/* Modifier: test/dev (purple, low emphasis) */
.btn-dev {
  border-color: #2a1a4a;
  color: #6644aa;
}

.btn-dev:hover {
  border-color: #8844ee;
  color: #aa66ff;
}

/* ── Overlay action buttons — extend .btn ── */
#btn-next-level,
#btn-repeat-mission,
#btn-title-start,
#btn-ending-close,
#btn-ship-map-close {
  background: transparent;
  font-family: var(--font-primary);
  cursor: pointer;
  text-transform: uppercase;
  transition: background var(--anim-fast), box-shadow var(--anim-fast), border-color var(--anim-fast), color var(--anim-fast);
}

#btn-next-level,
#btn-title-start {
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  letter-spacing: var(--ls-wide);
}

#btn-next-level:hover,
#btn-title-start:hover {
  background: rgba(240,160,48,0.1);
  box-shadow: var(--glow-primary-soft);
}

#btn-repeat-mission {
  border: 1px solid var(--color-alert);
  color: var(--color-alert);
  letter-spacing: var(--ls-normal);
}

#btn-repeat-mission:hover {
  background: rgba(204,34,34,0.1);
  box-shadow: 0 0 10px rgba(204,34,34,0.2);
}

#btn-ending-close {
  border: 1px solid var(--color-border);
  color: var(--color-text-dim);
  letter-spacing: var(--ls-wide);
  padding: 8px 24px;
  font-size: 10px;
  align-self: flex-start;
  margin-top: 8px;
  opacity: 0;
  animation: ending-fadein 1s ease 8s both;
}

#btn-ending-close:hover {
  border-color: var(--color-text);
  color: var(--color-text);
}

#btn-ship-map-close {
  border: 1px solid var(--color-border);
  color: var(--color-text-dim);
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  padding: 5px 14px;
}

#btn-ship-map-close:hover {
  border-color: var(--color-cyan);
  color: var(--color-cyan);
  box-shadow: var(--glow-cyan-soft);
}

/* ── Footer credit ── */
.bottom-credit {
  font-size: 10px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  opacity: 0.5;
}

/* ── Ship Map overlay ── */
/* ── Ship Map overlay ── */
@keyframes sm-fadein {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

#ship-map {
  display: none;
  position: absolute;
  inset: 0;
  z-index: 20;
  /* Heavy scrim — mutes game content behind */
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 2px,
      rgba(0,0,0,0.06) 2px,
      rgba(0,0,0,0.06) 4px
    ),
    rgba(2,6,14,0.93);
  backdrop-filter: blur(3px);
  align-items: center;
  justify-content: center;
}

#ship-map.active {
  display: flex;
  animation: sm-fadein 140ms ease both;
}

#ship-map-card {
  /* Fill the canvas field with a small inset margin */
  width: calc(100% - 28px);
  height: calc(100% - 28px);
  display: flex;
  flex-direction: column;
  background: var(--color-panel-deep);
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}

/* Cyan top accent line */
#ship-map-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--color-cyan) 30%, var(--color-cyan) 70%, transparent 100%);
  box-shadow: 0 0 12px rgba(0,212,255,0.5);
  z-index: 1;
}

/* Inner dot-grid texture — matches body bg */
#ship-map-card::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(0,200,255,0.025) 1px, transparent 1px);
  background-size: 20px 20px;
  z-index: 0;
}

#ship-map-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px 12px;
  border-bottom: 1px solid var(--color-border-dim);
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

#ship-map-eyebrow {
  display: flex;
  align-items: center;
  gap: 16px;
}

#ship-map-title {
  font-size: 17px;
  letter-spacing: var(--ls-wide);
  color: var(--color-cyan);
  text-shadow: var(--glow-cyan-soft);
  text-transform: uppercase;
}

#ship-map-sub {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  text-transform: uppercase;
  padding-top: 1px;
}

/* #btn-ship-map-close — defined in consolidated .btn section above */

/* #btn-reset-save — uses .btn-danger tokens */
#btn-reset-save {
  background: transparent;
  border: 1px solid var(--color-danger-border);
  color: var(--color-danger-dim);
  font-family: var(--font-primary);
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  padding: 5px 14px;
  cursor: pointer;
  text-transform: uppercase;
  transition: border-color var(--anim-fast), color var(--anim-fast);
}

#btn-reset-save:hover {
  border-color: var(--color-alert);
  color: var(--color-alert);
}

#ship-map-body {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  padding: 16px 20px 18px;
  position: relative;
  z-index: 2;
}

#ship-map-grid {
  display: flex;
  gap: 8px;
  flex: 1;
}

.sm-zone {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sm-zone-lbl {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  text-transform: uppercase;
  padding-bottom: var(--space-1);
  border-bottom: 1px solid var(--color-border-dim);
  margin-bottom: var(--space-1);
  text-align: center;
}

.sm-slot {
  background: rgba(7,17,30,0.8);
  border: 1px solid var(--color-border-dim);
  padding: 8px 10px;
  cursor: default;
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: border-color var(--anim-fast), background var(--anim-fast), box-shadow var(--anim-fast);
}

.sm-slot[data-z] {
  cursor: pointer;
}

.sm-slot[data-z]:hover {
  border-color: var(--color-cyan);
  background: rgba(0,212,255,0.06);
  box-shadow: inset 0 0 8px rgba(0,212,255,0.08);
}

.sm-slot.sm-current {
  border-color: var(--color-primary);
  background: rgba(240,160,48,0.07);
  box-shadow: inset 0 0 10px rgba(240,160,48,0.06);
}

/* ACTIVE indicator pip for current slot */
.sm-slot.sm-current::after {
  content: '';
  position: absolute;
  top: 6px; right: 7px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 6px var(--color-primary);
  animation: dot-blink 1.4s ease-in-out infinite;
}

.sm-slot.sm-locked {
  opacity: 0.28;
  cursor: default;
}

.sm-slot.sm-stub {
  opacity: 0.14;
  cursor: default;
}

.sm-slot-num {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.sm-slot-stars {
  font-size: 14px;
  color: var(--color-amber);
  line-height: 1;
  letter-spacing: 2px;
}

.sm-slot.sm-locked .sm-slot-stars,
.sm-slot.sm-stub .sm-slot-stars {
  color: var(--color-text-dark);
  font-size: 13px;
}

.sm-slot-time {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  margin-top: var(--space-1);
}

/* Footer status bar */
#ship-map-footer {
  flex-shrink: 0;
  padding: 8px 20px;
  border-top: 1px solid var(--color-border-dim);
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}

#ship-map-footer-left {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

#ship-map-footer-right {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.sm-cells-total {
  font-size: 11px;
  letter-spacing: var(--ls-normal);
  color: var(--color-amber);
  text-transform: uppercase;
}

/* ── Heading label (inside MOTE status widget) ── */
#heading-label {
  font-size: 10px;
  letter-spacing: var(--ls-tight);
  color: var(--color-text-dark);
  text-transform: uppercase;
}

#heading-label span {
  color: var(--color-primary);
  font-size: 14px;
  font-weight: bold;
  display: block;
  margin-top: 2px;
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
