/* GLOBAL SEEK — defense analyst dashboard */
:root {
  --bg-0: oklch(0.13 0.012 250);
  --bg-1: oklch(0.16 0.014 250);
  --bg-2: oklch(0.19 0.016 250);
  --bg-3: oklch(0.22 0.018 250);
  --bg-panel: oklch(0.155 0.013 250 / 0.92);
  --line: oklch(0.28 0.02 250);
  --line-soft: oklch(0.24 0.018 250);
  --line-strong: oklch(0.36 0.025 250);
  --ink-0: oklch(0.96 0.01 250);
  --ink-1: oklch(0.82 0.012 250);
  --ink-2: oklch(0.62 0.012 250);
  --ink-3: oklch(0.45 0.012 250);
  --ink-4: oklch(0.34 0.012 250);

  /* Signal coding */
  --sig-mil: oklch(0.78 0.16 75);      /* amber - military */
  --sig-fly: oklch(0.78 0.13 215);     /* cyan - flights */
  --sig-osint: oklch(0.72 0.20 330);   /* magenta - OSINT */
  --sig-civ: oklch(0.78 0.16 145);     /* green - civilian */
  --sig-mar: oklch(0.74 0.13 175);     /* teal - maritime */
  --sig-orb: oklch(0.72 0.18 295);     /* violet - orbital */
  --sig-wx:  oklch(0.78 0.05 230);     /* steel - weather */
  --sig-alert: oklch(0.68 0.22 25);    /* red - alerts */

  --sig-mil-rgb: 224 168 70;
  --sig-fly-rgb: 110 200 230;
  --sig-osint-rgb: 230 110 190;
  --sig-civ-rgb: 110 210 145;
  --sig-mar-rgb: 110 210 200;
  --sig-orb-rgb: 180 130 230;
  --sig-wx-rgb: 165 190 215;
  --sig-alert-rgb: 235 90 75;

  --font-sans: "IBM Plex Sans", system-ui, sans-serif;
  --font-cond: "IBM Plex Sans Condensed", "IBM Plex Sans", system-ui, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body, #root { height: 100%; margin: 0; }
body {
  background: var(--bg-0);
  color: var(--ink-1);
  font-family: var(--font-sans);
  font-size: 12px;
  line-height: 1.4;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
}

/* === App shell === */
.app {
  display: grid;
  grid-template-rows: 40px 1fr 156px;
  grid-template-columns: 260px 1fr 300px;
  grid-template-areas:
    "header header header"
    "left   stage  right"
    "bottom bottom bottom";
  height: 100vh;
  width: 100vw;
  background:
    radial-gradient(ellipse at 50% 40%, oklch(0.18 0.02 245) 0%, var(--bg-0) 70%);
}

.header { grid-area: header; }
.left   { grid-area: left; }
.right  { grid-area: right; }
.stage  { grid-area: stage; position: relative; overflow: hidden; }
.bottom { grid-area: bottom; }

/* === Top bar === */
.header {
  display: flex;
  align-items: stretch;
  background: linear-gradient(180deg, oklch(0.18 0.018 250) 0%, oklch(0.14 0.014 250) 100%);
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-1);
}
.brand {
  display: flex; align-items: center; gap: 10px;
  padding: 0 12px;
  border-right: 1px solid var(--line);
  width: 200px;
  flex-shrink: 0;
}
.brand-name { font-size: 12px; }
.brand-sub { display: none; }
.brand-mark {
  width: 18px; height: 18px;
  border-radius: 50%;
  background:
    conic-gradient(from 90deg, var(--sig-fly), var(--sig-orb), var(--sig-osint), var(--sig-mil), var(--sig-civ), var(--sig-fly));
  filter: blur(0px) saturate(1.1);
  position: relative;
}
.brand-mark::after {
  content: "";
  position: absolute; inset: 3px;
  border-radius: 50%;
  background: var(--bg-0);
  border: 1px solid var(--line-strong);
}
.brand-mark::before {
  content: "";
  position: absolute; inset: 7px;
  border-radius: 50%;
  background: var(--ink-0);
  box-shadow: 0 0 6px var(--ink-0);
}
.brand-name {
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ink-0);
}
.brand-sub {
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing: 0.12em;
}

.topbar-section {
  display: flex; align-items: center;
  padding: 0 10px;
  gap: 10px;
  border-right: 1px solid var(--line);
  white-space: nowrap;
  flex-shrink: 0;
}
.topbar-kv .k { font-size: 9px; }
.topbar-kv { display: flex; align-items: center; gap: 6px; }
.topbar-kv .k { color: var(--ink-3); font-size: 9.5px; letter-spacing: 0.08em; }
.topbar-kv .v { color: var(--ink-0); font-weight: 500; }
.topbar-kv.pulse .v::before {
  content: ""; display: inline-block;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--sig-civ);
  margin-right: 6px;
  vertical-align: middle;
  box-shadow: 0 0 8px var(--sig-civ);
  animation: pulse 1.4s infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

.search-wrap {
  flex: 1;
  min-width: 160px;
  display: flex; align-items: center;
  padding: 0 12px;
  border-right: 1px solid var(--line);
  gap: 8px;
}
.search-wrap input {
  background: transparent;
  border: 0;
  color: var(--ink-0);
  font-family: var(--font-mono);
  font-size: 11px;
  flex: 1;
  outline: none;
  letter-spacing: 0.04em;
}
.search-wrap input::placeholder { color: var(--ink-3); }
.search-wrap .key {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-3);
  border: 1px solid var(--line);
  padding: 1px 5px;
  border-radius: 2px;
}

.classy {
  display: flex; align-items: center;
  padding: 0 10px;
  gap: 8px;
  font-weight: 600;
  letter-spacing: 0.14em;
  font-size: 9.5px;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  flex-shrink: 0;
  transition: background 200ms, color 200ms;
}
.class-tabs { display: flex; gap: 1px; margin-left: 2px; }
.class-tabs button {
  background: oklch(0 0 0 / 0.25);
  border: 1px solid oklch(1 0 0 / 0.18);
  color: inherit;
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.08em;
  padding: 2px 4px;
  cursor: pointer;
  font-weight: 600;
  white-space: nowrap;
}
.user-chip { flex-shrink: 0; }
.classy-bar {
  width: 8px; height: 8px;
  background: var(--sig-mil);
  box-shadow: 0 0 8px var(--sig-mil);
}
.user-chip {
  display: flex; align-items: center;
  padding: 0 12px;
  gap: 10px;
  font-size: 10px;
}
.user-chip .avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, oklch(0.4 0.05 250), oklch(0.6 0.06 280));
  display: grid; place-items: center;
  color: var(--ink-0);
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: 10px;
}
.user-chip .name { color: var(--ink-0); }
.user-chip .role { color: var(--ink-3); font-size: 9.5px; letter-spacing: 0.08em; }

/* === Generic panel === */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
}
.panel + .panel { border-top: 0; }
.panel-h {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 10px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, oklch(0.19 0.018 250), oklch(0.16 0.014 250));
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.16em;
  color: var(--ink-1);
  text-transform: uppercase;
  min-height: 26px;
}
.panel-h .h-actions { display: flex; gap: 6px; align-items: center; color: var(--ink-3); }
.panel-h .h-tag {
  font-size: 8.5px;
  padding: 1px 5px;
  border: 1px solid var(--line-strong);
  border-radius: 2px;
  color: var(--ink-2);
}
.panel-h .h-pill {
  font-family: var(--font-mono);
  font-size: 9px;
  background: oklch(0.22 0.05 25);
  color: oklch(0.92 0.06 30);
  padding: 1px 5px;
  border-radius: 2px;
  letter-spacing: 0.12em;
}
.panel-b { padding: 8px 10px; overflow-y: auto; flex: 1; }

/* === Left rail === */
.left {
  border-right: 1px solid var(--line);
  background: var(--bg-0);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.left-inner { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.layer-list { display: flex; flex-direction: column; gap: 1px; }
.layer {
  display: grid;
  grid-template-columns: 18px 14px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 5px 4px;
  cursor: pointer;
  border-radius: 2px;
  user-select: none;
}
.layer:hover { background: oklch(0.2 0.02 250 / 0.6); }
.layer .toggle {
  width: 18px; height: 10px;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  background: var(--bg-2);
  position: relative;
  transition: background 120ms;
}
.layer .toggle::after {
  content: "";
  position: absolute;
  top: 1px; left: 1px;
  width: 6px; height: 6px;
  background: var(--ink-3);
  border-radius: 50%;
  transition: left 120ms, background 120ms;
}
.layer.on .toggle { background: var(--col); border-color: var(--col); }
.layer.on .toggle::after { left: 9px; background: var(--bg-0); }
.layer .swatch {
  width: 10px; height: 10px;
  background: var(--col);
  box-shadow: 0 0 8px var(--col);
}
.layer .lbl {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-1);
  letter-spacing: 0.04em;
}
.layer.on .lbl { color: var(--ink-0); }
.layer .ct {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-3);
}
.layer.on .ct { color: var(--ink-1); }

.scope-tabs {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  margin-bottom: 8px;
}
.scope-tabs button {
  background: var(--bg-2);
  border: 1px solid var(--line);
  color: var(--ink-2);
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.12em;
  padding: 4px 0;
  cursor: pointer;
}
.scope-tabs button.on {
  background: oklch(0.28 0.03 250);
  color: var(--ink-0);
  border-color: var(--line-strong);
}

.kv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
}
.kv-cell {
  padding: 6px 8px;
  background: oklch(0.17 0.014 250);
  border: 1px solid var(--line-soft);
}
.kv-cell .k {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.kv-cell .v {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-0);
  font-weight: 500;
  margin-top: 2px;
}
.kv-cell .v.up { color: var(--sig-civ); }
.kv-cell .v.down { color: var(--sig-alert); }
.kv-cell .v.warn { color: var(--sig-mil); }

/* threat meter */
.threat-meter { padding: 8px 10px 12px; }
.threat-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.threat-row .lbl { font-family: var(--font-mono); font-size: 9.5px; color: var(--ink-2); letter-spacing: 0.12em; }
.threat-row .val { font-family: var(--font-cond); font-weight: 700; font-size: 18px; color: var(--sig-mil); letter-spacing: 0.06em; }
.threat-bar {
  height: 8px;
  display: grid;
  grid-template-columns: repeat(20, 1fr);
  gap: 2px;
}
.threat-bar > span {
  background: var(--bg-3);
  border-radius: 1px;
}
.threat-bar > span.lit { background: var(--sig-civ); }
.threat-bar > span.lit.med { background: var(--sig-mil); }
.threat-bar > span.lit.high { background: var(--sig-alert); box-shadow: 0 0 6px var(--sig-alert); }
.threat-cap { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9px; color: var(--ink-3); margin-top: 4px; letter-spacing: 0.1em; }

/* === Right rail === */
.right {
  border-left: 1px solid var(--line);
  background: var(--bg-0);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.right-inner { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.feed-item {
  display: grid;
  grid-template-columns: 8px 1fr;
  gap: 8px;
  padding: 7px 0;
  border-bottom: 1px dashed var(--line-soft);
  cursor: pointer;
}
.feed-item:hover { background: oklch(0.18 0.02 250 / 0.6); }
.feed-item .stripe {
  width: 3px;
  background: var(--col);
  align-self: stretch;
  box-shadow: 0 0 6px var(--col);
}
.feed-item .meta {
  display: flex; gap: 8px; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}
.feed-item .meta .src { color: var(--col); font-weight: 500; }
.feed-item .meta .conf { margin-left: auto; }
.feed-item .meta .conf b { color: var(--ink-1); font-weight: 500; }
.feed-item .ttl { font-size: 11.5px; color: var(--ink-0); line-height: 1.35; }
.feed-item .geo { font-family: var(--font-mono); font-size: 9px; color: var(--ink-3); margin-top: 3px; letter-spacing: 0.05em; }
.feed-item.alert .ttl { color: oklch(0.94 0.05 30); }

/* OSINT */
.osint-row {
  display: grid; grid-template-columns: 16px 1fr auto;
  gap: 8px; align-items: center;
  padding: 5px 0;
  border-bottom: 1px dashed var(--line-soft);
}
.osint-row .net {
  font-family: var(--font-mono);
  font-size: 8.5px;
  color: var(--sig-osint);
  letter-spacing: 0.04em;
  text-align: center;
}
.osint-row .txt { font-size: 10.5px; color: var(--ink-1); line-height: 1.3; }
.osint-row .v {
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--ink-0);
  text-align: right;
}
.osint-row .v.up::before { content: "▲ "; color: var(--sig-civ); }
.osint-row .v.down::before { content: "▼ "; color: var(--sig-alert); }

/* === Stage / globe === */
.stage-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(oklch(0.2 0.02 250 / 0.18) 1px, transparent 1px),
    linear-gradient(90deg, oklch(0.2 0.02 250 / 0.18) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse 60% 60% at 50% 50%, black, transparent);
}

.stage-vignette {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 80% 70% at 50% 45%, transparent 50%, oklch(0.08 0.01 250 / 0.7) 100%);
}

.stage-frame-corners > i {
  position: absolute;
  width: 18px; height: 18px;
  border: 1px solid var(--line-strong);
  pointer-events: none;
}
.stage-frame-corners > i.tl { top: 8px; left: 8px; border-right: 0; border-bottom: 0; }
.stage-frame-corners > i.tr { top: 8px; right: 8px; border-left: 0; border-bottom: 0; }
.stage-frame-corners > i.bl { bottom: 8px; left: 8px; border-right: 0; border-top: 0; }
.stage-frame-corners > i.br { bottom: 8px; right: 8px; border-left: 0; border-top: 0; }

/* HUD overlays */
.hud {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-2);
  letter-spacing: 0.08em;
  pointer-events: none;
  text-transform: uppercase;
}
.hud.tl { display: none; }
.hud.tr { display: none; }
.hud.bl { display: none; }
.hud.br { display: none; }
.hud .row { font-size: 9px; }
.hud h2 { font-size: 9.5px; margin: 0 0 3px; }
.hud .row { display: flex; gap: 10px; align-items: baseline; }
.hud .row + .row { margin-top: 2px; }
.hud .lbl { color: var(--ink-3); }
.hud .val { color: var(--ink-0); font-weight: 500; }
.hud h2 {
  font-family: var(--font-cond);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.22em;
  margin: 0 0 4px;
  font-weight: 600;
}

.proj-tabs {
  position: absolute;
  top: 10px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 0;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 2px;
  z-index: 10;
  white-space: nowrap;
}
.proj-tabs button {
  background: transparent;
  border: 0;
  color: var(--ink-2);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  cursor: pointer;
  text-transform: uppercase;
  white-space: nowrap;
}
.proj-tabs button.on {
  background: oklch(0.28 0.04 245);
  color: var(--ink-0);
}

/* === Globe === */
.globe-wrap {
  position: absolute;
  inset: 0;
  display: grid; place-items: center;
  perspective: 1800px;
}
.globe-stage {
  position: relative;
  transform-style: preserve-3d;
}

.globe-sphere {
  position: absolute; inset: 0;
  border-radius: 50%;
  overflow: hidden;
  box-shadow:
    inset -40px -30px 80px oklch(0.05 0.02 250 / 0.9),
    inset 30px 20px 60px oklch(0.85 0.05 220 / 0.08),
    0 0 100px oklch(0.5 0.1 220 / 0.18);
}
.globe-tex {
  position: absolute;
  top: 0; left: -100%;
  width: 400%;
  height: 100%;
  background-size: 50% 100%;
  background-repeat: repeat-x;
  filter: brightness(0.78) saturate(1.05) contrast(1.05);
  /* Bend the equirectangular texture into a sphere via radial mask */
  mask-image: radial-gradient(circle at center, black 65%, transparent 100%);
}
.globe-atmo {
  position: absolute; inset: -22px;
  border-radius: 50%;
  background: radial-gradient(circle, transparent 60%, oklch(0.55 0.13 230 / 0.35) 75%, transparent 88%);
  pointer-events: none;
  filter: blur(4px);
}
.globe-atmo-2 {
  position: absolute; inset: -8px;
  border-radius: 50%;
  box-shadow: 0 0 36px oklch(0.7 0.12 220 / 0.45), inset 0 0 32px oklch(0.7 0.12 220 / 0.18);
  pointer-events: none;
}

.globe-grid {
  position: absolute; inset: 0;
  border-radius: 50%;
  pointer-events: none;
  background:
    repeating-conic-gradient(from 0deg, transparent 0 14deg, oklch(0.95 0.04 220 / 0.06) 14deg 14.4deg),
    repeating-radial-gradient(circle at center, transparent 0 24px, oklch(0.95 0.04 220 / 0.04) 24px 24.5px);
  mix-blend-mode: screen;
}
.globe-terminator {
  position: absolute; inset: 0;
  border-radius: 50%;
  background:
    linear-gradient(75deg, oklch(0.05 0.01 250 / 0.6) 0%, transparent 45%, transparent 55%, oklch(0.05 0.01 250 / 0.55) 100%);
  pointer-events: none;
  mix-blend-mode: multiply;
}

/* Orbital rings */
.orbit {
  position: absolute;
  border: 1px dashed oklch(0.7 0.08 295 / 0.35);
  border-radius: 50%;
  pointer-events: none;
}
.orbit.leo { inset: -28px; transform: rotate3d(1, 0.2, 0, 70deg); border-color: oklch(0.7 0.08 295 / 0.4); }
.orbit.meo { inset: -56px; transform: rotate3d(1, 0.4, 0, 65deg); border-color: oklch(0.7 0.08 295 / 0.3); }
.orbit.geo { inset: -90px; transform: rotate3d(1, 0.1, 0, 75deg); border-color: oklch(0.7 0.08 295 / 0.22); }

.sat {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--sig-orb);
  box-shadow: 0 0 8px var(--sig-orb);
  transform: translate(-50%, -50%);
}
.sat::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid var(--sig-orb);
  opacity: 0.5;
}

/* Pins / signals on the globe surface */
.pin {
  position: absolute;
  transform: translate(-50%, -50%);
  cursor: pointer;
  pointer-events: auto;
}
.pin .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--col);
  box-shadow: 0 0 0 1px oklch(0.05 0 0 / 0.6), 0 0 10px var(--col);
  position: relative;
}
.pin.alert .dot {
  width: 11px; height: 11px;
}
.pin .ring {
  position: absolute;
  top: 50%; left: 50%;
  width: 24px; height: 24px;
  margin: -12px 0 0 -12px;
  border-radius: 50%;
  border: 1px solid var(--col);
  opacity: 0.6;
  animation: ring 2.4s ease-out infinite;
}
.pin.alert .ring { animation-duration: 1.4s; border-width: 1.2px; }
@keyframes ring {
  0% { transform: scale(0.4); opacity: 0.9; }
  100% { transform: scale(2.2); opacity: 0; }
}
.pin .stub {
  position: absolute;
  top: 50%; left: 50%;
  height: 1px;
  background: linear-gradient(90deg, var(--col), transparent);
  transform-origin: 0 0;
  pointer-events: none;
}
.pin .lbl {
  position: absolute;
  top: 50%;
  white-space: nowrap;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-0);
  letter-spacing: 0.06em;
  background: oklch(0.1 0.01 250 / 0.85);
  padding: 2px 5px;
  border: 1px solid var(--col);
  border-left-width: 2px;
  text-transform: uppercase;
  pointer-events: none;
  transform: translateY(-50%);
}
.pin .lbl b { color: var(--col); font-weight: 500; }

/* Flight glyphs */
.flight {
  position: absolute;
  width: 14px; height: 14px;
  margin: -7px 0 0 -7px;
  pointer-events: none;
}
.flight svg { display: block; }

/* Selected callout */
.callout {
  position: absolute;
  width: 240px;
  background: oklch(0.13 0.012 250 / 0.96);
  border: 1px solid var(--col);
  font-family: var(--font-mono);
  color: var(--ink-1);
  z-index: 8;
  box-shadow: 0 12px 40px oklch(0.05 0 0 / 0.6), 0 0 0 1px oklch(0.95 0.04 220 / 0.04);
  pointer-events: auto;
}
.callout .head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 8px;
  background: linear-gradient(180deg, oklch(0.2 0.02 250), oklch(0.16 0.014 250));
  border-bottom: 1px solid var(--col);
  font-size: 9.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.callout .head .id { color: var(--col); font-weight: 600; }
.callout .head button {
  background: transparent; border: 0; color: var(--ink-3);
  cursor: pointer; font-family: var(--font-mono);
  font-size: 11px;
}
.callout .body { padding: 8px; }
.callout .ttl {
  font-family: var(--font-sans);
  font-size: 12.5px;
  color: var(--ink-0);
  line-height: 1.35;
  margin-bottom: 6px;
}
.callout .grid2 {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin-bottom: 6px;
}
.callout .grid2 .c {
  background: oklch(0.16 0.014 250);
  padding: 4px 6px;
}
.callout .grid2 .k { font-size: 8.5px; color: var(--ink-3); letter-spacing: 0.1em; }
.callout .grid2 .v { font-size: 11px; color: var(--ink-0); }
.callout .desc { font-family: var(--font-sans); font-size: 11px; color: var(--ink-2); line-height: 1.45; }
.callout .actions {
  display: flex; gap: 6px; margin-top: 8px;
}
.callout .actions button {
  flex: 1;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink-1);
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.12em;
  padding: 5px 0;
  cursor: pointer;
  text-transform: uppercase;
}
.callout .actions button.primary {
  border-color: var(--col);
  color: var(--col);
}
.callout .leader {
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%;
  height: 1px;
  pointer-events: none;
}

/* === Mercator === */
.merc-wrap {
  position: absolute;
  inset: 56px 18px 18px 18px;
  display: grid; place-items: center;
}
.merc-canvas {
  position: relative;
  width: 100%;
  height: 100%;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  overflow: hidden;
  box-shadow: inset 0 0 60px oklch(0.05 0.01 250 / 0.7);
}
.merc-img {
  position: absolute; inset: 0;
  background-size: 100% 100%;
  background-position: center;
  filter: brightness(0.7) saturate(1.05) contrast(1.05);
}
.merc-tint {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 50%, oklch(0.08 0.01 250 / 0.65) 100%);
  mix-blend-mode: multiply;
}
.merc-grat {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none;
  mix-blend-mode: screen;
}
.merc-term {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none;
  opacity: 0.7;
}
.merc-ticks-x, .merc-ticks-y { position: absolute; pointer-events: none; }
.merc-ticks-x {
  left: 0; right: 0; bottom: 4px; height: 12px;
  font-family: var(--font-mono); font-size: 8.5px; color: var(--ink-3);
  letter-spacing: 0.1em;
}
.merc-ticks-x span { position: absolute; transform: translateX(-50%); }
.merc-ticks-y {
  top: 0; bottom: 0; left: 4px; width: 28px;
  font-family: var(--font-mono); font-size: 8.5px; color: var(--ink-3);
  letter-spacing: 0.1em;
}
.merc-ticks-y span { position: absolute; }
.merc-pin .lbl { display: none; }
.bottom {
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, oklch(0.16 0.014 250), oklch(0.14 0.012 250));
  display: grid;
  grid-template-columns: 320px 1fr 320px;
  overflow: hidden;
}
.bottom-section {
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.bottom-section:last-child { border-right: 0; }
.bottom-h {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 10px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line);
  height: 22px;
}
.bottom-b { flex: 1; padding: 6px 10px; overflow: hidden; }

/* time scrubber */
.scrub {
  position: relative;
  height: 100%;
  display: flex; flex-direction: column;
}
.scrub-tracks {
  position: relative;
  flex: 1;
  display: grid;
  grid-template-rows: repeat(6, 1fr);
  gap: 2px;
}
.track {
  position: relative;
  background: oklch(0.17 0.014 250);
  border: 1px solid var(--line-soft);
  overflow: hidden;
}
.track .label {
  position: absolute;
  top: 50%; left: 4px;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 8.5px;
  color: var(--ink-3);
  letter-spacing: 0.1em;
  z-index: 2;
  background: oklch(0.17 0.014 250 / 0.85);
  padding: 0 4px;
  pointer-events: none;
}
.track .tick {
  position: absolute;
  top: 8%; bottom: 8%;
  width: 2px;
  background: var(--col);
  box-shadow: 0 0 4px var(--col);
  opacity: 0.85;
}
.track .heat {
  position: absolute;
  top: 0; bottom: 0;
  background: linear-gradient(90deg, transparent, var(--col), transparent);
  opacity: 0.18;
}

.scrub-axis {
  height: 18px;
  position: relative;
  display: flex; justify-content: space-between;
  align-items: flex-end;
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 8.5px;
  color: var(--ink-3);
  letter-spacing: 0.08em;
  padding: 2px 0 0;
  margin-top: 4px;
}
.scrub-axis .ax { padding: 0 2px; }
.scrub-playhead {
  position: absolute;
  top: 0; bottom: 0;
  width: 1px;
  background: var(--ink-0);
  box-shadow: 0 0 8px oklch(0.96 0.04 220);
  z-index: 3;
  cursor: ew-resize;
}
.scrub-playhead::before {
  content: "";
  position: absolute;
  top: -4px; left: 50%; transform: translateX(-50%);
  width: 8px; height: 8px;
  background: var(--ink-0);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.scrub-now-band {
  position: absolute;
  top: 0; bottom: 0;
  background: oklch(0.96 0.04 220 / 0.05);
  pointer-events: none;
}

.scrub-controls {
  display: flex; gap: 6px; align-items: center;
  padding: 4px 10px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--ink-2);
  letter-spacing: 0.12em;
  height: 22px;
}
.scrub-controls button {
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink-1);
  font-family: var(--font-mono);
  font-size: 9.5px;
  padding: 1px 6px;
  cursor: pointer;
  letter-spacing: 0.1em;
}
.scrub-controls button.on {
  background: oklch(0.28 0.05 245);
  color: var(--ink-0);
  border-color: var(--line-strong);
}
.scrub-controls .sep { color: var(--ink-3); }
.scrub-controls .now { margin-left: auto; color: var(--ink-0); }

/* Telemetry */
.tele-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  height: 100%;
}
.tele {
  background: oklch(0.16 0.014 250);
  padding: 5px 8px;
  display: flex; flex-direction: column;
  justify-content: space-between;
  border: 1px solid var(--line-soft);
}
.tele .k { font-family: var(--font-mono); font-size: 8.5px; color: var(--ink-3); letter-spacing: 0.12em; text-transform: uppercase; }
.tele .v { font-family: var(--font-cond); font-weight: 700; font-size: 18px; color: var(--ink-0); letter-spacing: 0.04em; }
.tele .v small { font-family: var(--font-mono); font-size: 9px; color: var(--ink-3); font-weight: 400; letter-spacing: 0.08em; margin-left: 4px; }
.tele .spark {
  height: 14px;
  display: flex; align-items: flex-end; gap: 1px;
}
.tele .spark > i {
  flex: 1;
  background: var(--col, var(--ink-2));
  opacity: 0.85;
}

/* alert ribbon */
.alert-ribbon {
  display: flex; align-items: center; gap: 14px;
  padding: 4px 10px;
  background: oklch(0.22 0.06 25);
  color: oklch(0.96 0.06 30);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  border-top: 1px solid oklch(0.4 0.1 25);
  border-bottom: 1px solid oklch(0.4 0.1 25);
  text-transform: uppercase;
}
.alert-ribbon .tag {
  background: var(--sig-alert);
  color: oklch(0.16 0.014 250);
  padding: 1px 5px;
  font-weight: 700;
  letter-spacing: 0.18em;
}

/* misc */
.divider { height: 1px; background: var(--line); margin: 6px 0; }

.scroll::-webkit-scrollbar { width: 6px; height: 6px; }
.scroll::-webkit-scrollbar-track { background: transparent; }
.scroll::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

/* tiny chart */
.minichart { height: 36px; display: flex; align-items: flex-end; gap: 2px; }
.minichart > i { flex: 1; background: var(--col, var(--sig-fly)); opacity: 0.8; }

/* equator/lat band on globe (subtle) */
.globe-meridian {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  pointer-events: none;
  background:
    linear-gradient(0deg, transparent 49.6%, oklch(0.95 0.04 220 / 0.18) 49.8%, oklch(0.95 0.04 220 / 0.18) 50.2%, transparent 50.4%);
  mask-image: radial-gradient(circle, black 92%, transparent 100%);
}
