/* dash.css — ON1 dash, "mission control" surface.
 *
 * 12th distinct aesthetic surface (CLAUDE.md variety rule):
 *   index → cyberpunk · panel → utilitarian dashboard
 *   aedln0d → Swedish-newspaper · aedln0d/kg → engineering schematic
 *   healthlog → terminal sparklines · docs → warm-paper editorial
 *   metacyc → orrery · syskg → sys-kg gallery
 *   timeline → observatory logbook · ssmailab → SSM-magenta gov light
 *   nrs → IAEA quiet/diplomatic slate (warm parchment)
 *   dash → MISSION CONTROL / RADAR WALL  (this file)
 *
 * Register: dark navy ground, cool cyan accents, hex-grid texture,
 * subtle scan-pulse glow on active tiles. The page is a *portal*
 * showing summary cards for every installed dashboard; clicking a
 * tile expands the surface into an embedded iframe inline (no
 * navigation), so the operator never loses the dash context.
 *
 * No innerHTML in the sibling JS. Pure stdlib for any backend probes.
 */

:root {
  /* Mission-control palette — dark navy ground, cyan readouts.
   * Contrast: ink-0 against bg-page = ~14.8:1 (WCAG AAA). */
  --bg-page:        #08101a;
  --bg-card:        #0e1827;
  --bg-card-hot:    #14233a;
  --bg-faint:       #0b1421;
  --bg-strip:       #050a12;

  --ink-0:          #d8e6f4;
  --ink-1:          #b6c6d8;
  --ink-2:          #7e96b3;
  --ink-3:          #54688a;

  --line-soft:      #142235;
  --line-mid:       #1f3550;
  --line-strong:    #38567d;

  --cyan-0:         #49d2ff;
  --cyan-deep:      #2196c7;
  --cyan-soft:      #93e3ff;
  --amber-0:        #ffba49;
  --green-ok:       #4cd998;
  --rose-warn:      #ff7a8a;

  --font-display:   "Chakra Petch", monospace;
  --font-mono:      "IBM Plex Mono", monospace;
  --font-sans:      "Familjen Grotesk", sans-serif;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg-page);
  color: var(--ink-0);
  font-family: var(--font-sans);
  min-height: 100vh;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern","liga","calt";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Subtle radar-grid background — pure CSS, no images.
 * Two layered linear-gradients for the hex-ish illusion + a thin
 * radial fade so the centre feels "calmer" than the edges. */
body.mc {
  background:
    radial-gradient(circle at 50% 25%, rgba(73,210,255,0.05) 0%, transparent 60%),
    repeating-linear-gradient(0deg,
      transparent 0px, transparent 23px,
      rgba(73,210,255,0.025) 23px, rgba(73,210,255,0.025) 24px),
    repeating-linear-gradient(90deg,
      transparent 0px, transparent 23px,
      rgba(73,210,255,0.025) 23px, rgba(73,210,255,0.025) 24px),
    var(--bg-page);
}

/* ── HUD strip ───────────────────────────────────────────────── */
.hud {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 28px;
  background: var(--bg-strip);
  border-bottom: 1px solid var(--line-mid);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-1);
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(6px);
}
.hud-l, .hud-r { display: flex; align-items: center; gap: 12px; }
.callsign {
  font-family: var(--font-display);
  font-size: 16px; letter-spacing: 0.22em;
  color: var(--cyan-0);
}
.hud-mode {
  color: var(--amber-0);
  font-weight: 600;
}
.hud-sep { color: var(--ink-3); }
.hud-sub { color: var(--ink-2); }

.hud-pill {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: 0.14em;
  padding: 3px 10px;
  border: 1px solid var(--line-mid);
  border-radius: 11px;
  color: var(--ink-1);
  background: var(--bg-card);
}
.hud-link {
  text-decoration: none;
  color: var(--cyan-soft);
  border-color: var(--cyan-deep);
}
.hud-link:hover { background: var(--bg-card-hot); }

/* ── main stage ───────────────────────────────────────────────── */
.mc-stage {
  padding: 24px 28px 80px;
  max-width: 1600px;
  margin: 0 auto;
}

.mc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 14px;
}

/* ── tile card ────────────────────────────────────────────────── */
.tile {
  background: var(--bg-card);
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  padding: 16px 18px 14px;
  display: flex; flex-direction: column;
  gap: 10px;
  cursor: pointer;
  position: relative;
  transition: background 160ms, border-color 160ms, transform 160ms;
}
.tile:hover, .tile:focus-visible {
  background: var(--bg-card-hot);
  border-color: var(--cyan-deep);
  transform: translateY(-1px);
  outline: none;
}
.tile:hover::before, .tile:focus-visible::before {
  /* Sweep glow line top of tile */
  content: "";
  position: absolute;
  top: 0; left: 8px; right: 8px;
  height: 1px;
  background: linear-gradient(90deg,
    transparent, var(--cyan-0), transparent);
  opacity: 0.7;
}

.tile-head {
  display: flex; justify-content: space-between; align-items: baseline;
}
.tile-id {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: 0.18em;
  color: var(--cyan-deep);
  text-transform: uppercase;
}
.tile-pill {
  font-family: var(--font-mono);
  font-size: 9.5px; letter-spacing: 0.14em;
  padding: 2px 7px;
  border: 1px solid var(--line-mid);
  border-radius: 9px;
  color: var(--ink-2);
  text-transform: uppercase;
}
.tile-pill[data-state="up"] {
  color: var(--green-ok);
  border-color: rgba(76,217,152,0.4);
  background: rgba(76,217,152,0.06);
}
.tile-pill[data-state="down"] {
  color: var(--rose-warn);
  border-color: rgba(255,122,138,0.4);
  background: rgba(255,122,138,0.05);
}
.tile-pill[data-state="probe"] {
  color: var(--amber-0);
  border-color: rgba(255,186,73,0.4);
  background: rgba(255,186,73,0.06);
}
.tile-pill[data-state="static"] {
  color: var(--ink-2);
}

.tile-name {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.04em;
  color: var(--ink-0);
  margin: 0;
  line-height: 1.15;
}
.tile-blurb {
  font-family: var(--font-sans);
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--ink-1);
  margin: 0;
  flex-grow: 1;
}
.tile-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-3);
}
.tile-cta {
  color: var(--cyan-0);
  letter-spacing: 0.1em;
}
.tile-cta::after {
  content: " →";
}

/* ── Q51 category strip + freshness pill ───────────────────────── */
.group-strip {
  grid-column: 1 / -1;
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 14px 4px 6px;
  border-bottom: 1px solid var(--line-soft);
  margin-top: 4px;
}
.group-strip:first-child { margin-top: 0; }

.group-strip-tag {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.12em;
  color: var(--cyan-0);
  text-shadow: 0 0 6px rgba(73,210,255,0.32);
}
.group-strip-sub {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.05em;
  color: var(--ink-3);
  flex-grow: 1;
}
.group-strip-count {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--ink-2);
  padding: 2px 8px;
  border: 1px solid var(--line-mid);
  border-radius: 9px;
  background: var(--bg-faint);
}

/* Per-group accent colour on the strip tag, lifted from the freshness
 * palette so the page reads as one system. */
.group-strip[data-group="revenue"] .group-strip-tag    { color: var(--amber-0); text-shadow: 0 0 6px rgba(255,186,73,0.32); }
.group-strip[data-group="ops"] .group-strip-tag        { color: var(--cyan-0); }
.group-strip[data-group="products"] .group-strip-tag   { color: var(--green-ok); text-shadow: 0 0 6px rgba(76,217,152,0.28); }
.group-strip[data-group="ssm"] .group-strip-tag        { color: #d987ff; text-shadow: 0 0 6px rgba(217,135,255,0.28); }
.group-strip[data-group="benchmarks"] .group-strip-tag { color: #ffce4d; }
.group-strip[data-group="library"] .group-strip-tag    { color: var(--ink-2); }

.tile-fresh {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: lowercase;
  padding: 2px 7px;
  border-radius: 9px;
  border: 1px solid var(--line-mid);
  color: var(--ink-2);
  background: var(--bg-faint);
}
.tile-fresh[data-bucket="loading"]  { color: var(--ink-3); }
.tile-fresh[data-bucket="fresh"]    { color: var(--green-ok); border-color: rgba(76,217,152,0.4); background: rgba(76,217,152,0.06); }
.tile-fresh[data-bucket="warm"]     { color: var(--cyan-0); border-color: rgba(73,210,255,0.4); background: rgba(73,210,255,0.06); }
.tile-fresh[data-bucket="stale"]    { color: var(--amber-0); border-color: rgba(255,186,73,0.4); background: rgba(255,186,73,0.06); }
.tile-fresh[data-bucket="cold"]     { color: var(--rose-warn); border-color: rgba(255,122,138,0.4); background: rgba(255,122,138,0.06); }
.tile-fresh[data-bucket="unknown"]  { color: var(--ink-3); }
.tile-fresh[data-bucket="missing"]  { color: var(--ink-3); }
.tile-fresh[data-bucket="loading"]  { color: var(--ink-3); font-style: italic; }

/* Subtle left border on tile by freshness for at-a-glance scan
 * without forcing the eye to the bottom pill. */
.tile:has(.tile-fresh[data-bucket="cold"])  { border-left: 3px solid var(--rose-warn); }
.tile:has(.tile-fresh[data-bucket="stale"]) { border-left: 3px solid var(--amber-0); }
.tile:has(.tile-fresh[data-bucket="fresh"]) { border-left: 3px solid var(--green-ok); }
.tile:has(.tile-fresh[data-bucket="warm"])  { border-left: 3px solid var(--cyan-0); }

/* ── embed view ──────────────────────────────────────────────── */
.mc-embed {
  display: flex; flex-direction: column;
  height: calc(100vh - 110px);
  border: 1px solid var(--line-mid);
  border-radius: 4px;
  background: var(--bg-card);
  overflow: hidden;
}
.mc-embed.hidden { display: none; }

.embed-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 16px;
  background: var(--bg-strip);
  border-bottom: 1px solid var(--line-mid);
  font-family: var(--font-mono);
  font-size: 12px;
}
.embed-bar-l { display: flex; align-items: center; gap: 12px; }
.embed-mark { color: var(--cyan-0); }
.embed-title {
  color: var(--ink-0);
  font-weight: 500;
}
.embed-sep { color: var(--ink-3); }
.embed-link {
  color: var(--cyan-soft);
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.08em;
}
.embed-link:hover { text-decoration: underline; }

.embed-btn {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-1);
  background: transparent;
  border: 1px solid var(--line-mid);
  border-radius: 3px;
  padding: 4px 12px;
  cursor: pointer;
  transition: background 140ms, color 140ms, border-color 140ms;
}
.embed-btn:hover {
  color: var(--cyan-0);
  border-color: var(--cyan-deep);
  background: var(--bg-card-hot);
}

.embed-frame-wrap {
  flex-grow: 1;
  background: var(--bg-page);
  overflow: hidden;
}
#embed-frame {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* ── footer pills ─────────────────────────────────────────────── */
.mc-foot {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  padding: 8px 28px;
  background: var(--bg-strip);
  border-top: 1px solid var(--line-mid);
  display: flex; gap: 14px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.12em;
  color: var(--ink-2);
  text-transform: uppercase;
}
.foot-pill {
  padding: 2px 9px;
  border: 1px solid var(--line-mid);
  border-radius: 9px;
  background: var(--bg-card);
}

@media (max-width: 720px) {
  .hud { padding: 10px 14px; flex-wrap: wrap; gap: 8px; }
  .mc-stage { padding: 14px 14px 80px; }
  .mc-grid { grid-template-columns: 1fr; }
  .mc-foot { font-size: 9px; flex-wrap: wrap; }
}
