/* theme.css — Kaobra "orbit black" design language (KAOBRA_BRAND_THEME.md).
 * Single source of truth for the WAKESCAN app AND the kaobra.com extension.
 * One accent color; amber/red/cyan are semantic status only, never decoration.
 */

@font-face {
  font-family: 'Space Grotesk';
  src: url('/assets/fonts/SpaceGrotesk.woff2') format('woff2');
  font-weight: 300 700;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/Inter.woff2') format('woff2');
  font-weight: 100 900;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('/assets/fonts/JetBrainsMono.woff2') format('woff2');
  font-weight: 100 800;
  font-display: swap;
}

:root {
  /* palette — "orbit black" */
  --bg-0: #05070a;
  --bg-1: #0c1116;
  --bg-2: #121a22;
  --hairline: #1c2530;
  --text-0: #f2f5f7;
  --text-1: #8b98a5;

  /* THE accent (DELTASCAN continuity) */
  --accent: #22c55e;
  --accent-hot: #37ff8b;

  /* semantic status only */
  --warn: #f59e0b;
  --alert: #ef4444;
  --watch: #22d3ee;

  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-ui: 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --radius: 4px;              /* never rounder */
  --motion: 150ms ease;       /* restrained */
}

/* ---- shared primitives -------------------------------------------------- */

.eyebrow {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-1);
}

.wordmark {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-0);
}
.wordmark.accent { color: var(--accent); }

.mono { font-family: var(--font-mono); }

/* status chip: hairline border, uppercase mono 10px */
.chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 8px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius);
  color: var(--text-1);
  background: transparent;
  cursor: default;
  user-select: none;
}
.chip.on { color: var(--accent); border-color: var(--accent); }
.chip.clickable { cursor: pointer; transition: border-color var(--motion), color var(--motion); }
.chip.clickable:hover { border-color: var(--text-1); color: var(--text-0); }

.chip.s-underway   { color: var(--accent); border-color: var(--accent); }
.chip.s-anchored   { color: var(--warn); border-color: var(--warn); }
.chip.s-moored     { color: var(--text-0); border-color: var(--text-1); }
.chip.s-stale      { color: var(--text-1); }
.chip.s-sanctioned { color: var(--alert); border-color: var(--alert); }
.chip.s-watched    { color: var(--watch); border-color: var(--watch); }

/* buttons/inputs on the 8px grid */
.btn {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--text-0);
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: var(--radius);
  padding: 6px 12px;
  cursor: pointer;
  transition: border-color var(--motion), background var(--motion);
}
.btn:hover { border-color: var(--accent); }
.btn.primary { background: var(--accent); color: #04120a; border-color: var(--accent); font-weight: 600; }
.btn.primary:hover { background: var(--accent-hot); }

.input {
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--text-0);
  background: var(--bg-0);
  border: 1px solid var(--hairline);
  border-radius: var(--radius);
  padding: 8px 10px;
  outline: none;
  transition: border-color var(--motion);
  width: 100%;
  box-sizing: border-box;
}
.input:focus { border-color: var(--accent); }
.input.mono { font-family: var(--font-mono); }

/* hairline rules only — no shadows, no gradients */
.hr { border: 0; border-top: 1px solid var(--hairline); margin: 12px 0; }

/* live indicator: slow pulse */
.live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--text-1);
  display: inline-block;
}
.live-dot.on {
  background: var(--accent-hot);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* big-numeral stat block */
.stat .num {
  font-family: var(--font-mono);
  font-size: 64px;
  font-weight: 700;
  color: var(--text-0);
  line-height: 1;
}
.stat .lbl {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-1);
  margin-top: 6px;
}
