/* observ.css — ON1 observability hub.
 *
 * Aesthetic flavour: "MISSION-CONTROL / CONTROL-ROOM" — a flight-ops
 * annunciator console. Distinct from every prior surface flavour
 * (cyberpunk/dashboard/newspaper/schematic/sparkline/editorial/
 * river-delta/ledger/observatory). The motifs:
 *   - deep console graphite + a thin amber rule "instrument bezel"
 *   - status lamps (annunciator tiles) that glow GO / NO-GO / STALE
 *   - segmented mono readouts, console-strip header, plate-glass cards
 *
 * Three project fonts (loaded by observ.html):
 *   Chakra Petch   → display headlines / console plate marks
 *   Familjen Grotesk → body / sans
 *   IBM Plex Mono  → telemetry numerals + technical labels
 *
 * Palette verified for WCAG AA (>=4.5:1 body text). Worst case body
 * pair: --ink-1 (#c3d0d8) on --bg-1 (#12181d) ≈ 9.6:1. Muted label
 * --ink-2 (#9fb1bb) on --bg-1 ≈ 6.7:1. Both clear AA comfortably.
 */

:root {
  --bg-0:   #0a0f13;   /* room dark */
  --bg-1:   #12181d;   /* console plate */
  --bg-2:   #1a2228;   /* recessed well */
  --rule:   #2c3a43;   /* bezel hairline */
  --rule-2: #3a4c57;   /* raised bezel */

  --ink-0:  #f2f6f8;   /* headline ink */
  --ink-1:  #c3d0d8;   /* body ink */
  --ink-2:  #9fb1bb;   /* muted label (AA-safe) */

  --amber:  #f4b740;   /* instrument bezel accent */
  --amber-d:#caa24a;   /* dim amber for borders */
  --go:     #57d98a;   /* lamp GO (up) */
  --nogo:   #ff6b5e;   /* lamp NO-GO (down) */
  --stale:  #e0c24a;   /* lamp STALE / probing */
  --info:   #6fd3e6;   /* informational cyan */
  --violet: #c79bff;   /* private-plane marker */

  --pad: clamp(16px, 4vw, 40px);

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

* { box-sizing: border-box; }

html { background: var(--bg-0); }

body {
  margin: 0;
  background:
    radial-gradient(1200px 600px at 50% -10%, #16202740 0%, transparent 70%),
    var(--bg-0);
  color: var(--ink-1);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--info); text-decoration: none; }
a:hover, a:focus-visible { text-decoration: underline; }
:focus-visible { outline: 2px solid var(--amber); outline-offset: 2px; }

/* ── console-strip header ───────────────────────────────────────── */
.console-strip {
  position: sticky; top: 0; z-index: 10;
  display: flex; flex-wrap: wrap; gap: 14px;
  align-items: baseline; justify-content: space-between;
  padding: 12px var(--pad);
  background: linear-gradient(180deg, #0e141980, #0a0f13f2);
  border-bottom: 1px solid var(--rule);
  backdrop-filter: blur(6px);
}
.cs-l { display: flex; align-items: baseline; gap: 10px; }
.cs-mark {
  font-family: var(--font-display); font-weight: 700;
  letter-spacing: .18em; color: var(--ink-0); font-size: 18px;
}
.cs-sep { color: var(--rule-2); }
.cs-mode {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--amber);
}
.cs-sub {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em;
  color: var(--ink-2);
}
.cs-r { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cs-pill {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em;
  color: var(--ink-1); padding: 4px 10px;
  border: 1px solid var(--rule); border-radius: 2px;
  background: var(--bg-1); text-transform: uppercase;
}
.cs-pill.link:hover { border-color: var(--amber-d); }
.cs-pill .acc { color: var(--go); }

/* private-plane caution banner */
.caution {
  margin: var(--pad) var(--pad) 0;
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 16px;
  border: 1px solid var(--amber-d);
  border-left: 4px solid var(--amber);
  background: #1c1a1240;
  border-radius: 3px;
}
.caution .glyph { font-size: 18px; color: var(--amber); line-height: 1.4; }
.caution .txt { font-size: 13px; color: var(--ink-1); }
.caution .txt strong { color: var(--amber); font-weight: 600; }

/* ── headline ───────────────────────────────────────────────────── */
.lede { padding: var(--pad) var(--pad) 6px; }
.lede h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(34px, 7vw, 64px); line-height: .98;
  letter-spacing: -.01em; margin: 0; color: var(--ink-0);
}
.lede .tagline {
  margin-top: 12px; font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2);
}

/* ── annunciator summary panel ──────────────────────────────────── */
.annunciator {
  margin: 18px var(--pad);
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 1px; background: var(--rule); border: 1px solid var(--rule);
}
.ann-cell {
  background: var(--bg-1); padding: 14px 16px;
  display: flex; flex-direction: column; gap: 6px;
}
.ann-cell .ann-k {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--ink-2);
}
.ann-cell .ann-v {
  font-family: var(--font-mono); font-size: 26px; font-weight: 500;
  color: var(--ink-0); font-variant-numeric: tabular-nums;
}
.ann-cell .ann-v.go { color: var(--go); }
.ann-cell .ann-v.nogo { color: var(--nogo); }
.ann-cell .ann-v.stale { color: var(--stale); }

/* ── section ────────────────────────────────────────────────────── */
.sect { padding: 8px var(--pad) 0; }
.sect-head {
  display: flex; align-items: baseline; gap: 12px;
  padding: 20px 0 12px; border-bottom: 1px solid var(--rule);
}
.sect-head .sect-tag {
  font-family: var(--font-display); font-weight: 700; font-size: 16px;
  letter-spacing: .08em; color: var(--ink-0); text-transform: uppercase;
}
.sect-head .sect-sub {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em;
  color: var(--ink-2);
}

/* ── lamp grid (dashboards + exporters) ─────────────────────────── */
.lamp-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px; padding: 16px 0;
}
.lamp {
  display: flex; flex-direction: column; gap: 10px;
  background: var(--bg-1); border: 1px solid var(--rule);
  border-radius: 4px; padding: 16px; position: relative;
  transition: border-color 120ms ease, transform 120ms ease;
}
.lamp:hover { border-color: var(--rule-2); transform: translateY(-1px); }
.lamp.private { border-left: 3px solid var(--violet); }

.lamp-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.lamp-id {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-2);
}
.lamp-state {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ink-2);
}
.lamp-led {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--rule-2); box-shadow: 0 0 0 0 transparent;
}
.lamp-state[data-state="up"]   .lamp-led { background: var(--go);   box-shadow: 0 0 8px 1px #57d98a99; }
.lamp-state[data-state="up"]   { color: var(--go); }
.lamp-state[data-state="down"] .lamp-led { background: var(--nogo); box-shadow: 0 0 8px 1px #ff6b5e99; }
.lamp-state[data-state="down"] { color: var(--nogo); }
.lamp-state[data-state="probe"] .lamp-led { background: var(--stale); }
.lamp-state[data-state="probe"] { color: var(--stale); }
.lamp-state[data-state="static"] .lamp-led { background: var(--info); }
.lamp-state[data-state="static"] { color: var(--info); }

.lamp-name {
  font-family: var(--font-display); font-weight: 600; font-size: 17px;
  color: var(--ink-0); margin: 0;
}
.lamp-blurb { font-size: 13px; color: var(--ink-1); margin: 0; }
.lamp-meta {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em;
  color: var(--ink-2); word-break: break-all;
}
.lamp-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; padding-top: 6px; }
.lamp-btn {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase; padding: 6px 12px;
  border: 1px solid var(--rule-2); border-radius: 2px;
  color: var(--ink-0); background: var(--bg-2);
}
.lamp-btn:hover { border-color: var(--amber); color: var(--amber); text-decoration: none; }
.lamp-btn.primary { border-color: var(--amber-d); color: var(--amber); }

.plane-tag {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .16em;
  text-transform: uppercase; padding: 2px 6px; border-radius: 2px;
}
.plane-tag.public  { color: var(--info);   border: 1px solid #2c4a52; }
.plane-tag.private { color: var(--violet); border: 1px solid #46365a; }

/* ── loading placeholder ────────────────────────────────────────── */
.boot {
  padding: 40px var(--pad); text-align: center;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--ink-2);
}
.boot .dot { color: var(--amber); animation: blink 1.2s steps(2,start) infinite; }
@keyframes blink { 0%,50% { opacity: 1; } 51%,100% { opacity: .2; } }

/* ── footer ─────────────────────────────────────────────────────── */
.console-foot {
  margin-top: 28px; padding: 16px var(--pad);
  border-top: 1px solid var(--rule);
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-between;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em;
  color: var(--ink-2);
}
.console-foot a { color: var(--ink-2); }
.console-foot a:hover { color: var(--amber); }

@media (max-width: 560px) {
  .lamp-grid { grid-template-columns: 1fr; }
}
