/* ═══════════════════════════════════════════════════════════════
   STRATOS TACTICAL — Design System v4.0
   Military Ground Control Station Aesthetic
═══════════════════════════════════════════════════════════════ */

:root {
  /* ── Backgrounds ─────────────────────────────── */
  --bg-base:      #050a14;
  --bg-surface:   #0e1a2c;
  --bg-surface-2: #1a2840;
  --bg-surface-3: #243352;
  --bg-overlay:   rgba(5, 10, 20, 0.94);
  --bg-glass:     rgba(14, 26, 44, 0.88);

  /* ── Borders ─────────────────────────────────── */
  --border-dim:    #2a3e5a;
  --border-med:    #4a6080;
  --border-bright: #6a8aae;

  /* ── Brand / Accent ──────────────────────────── */
  --amber:         #e8a030;
  --amber-bright:  #f0b840;
  --amber-dim:     rgba(232, 160, 48, 0.12);
  --amber-glow:    rgba(232, 160, 48, 0.04);
  --blue:          #1a68cc;
  --blue-bright:   #2480f0;
  --blue-dim:      rgba(36, 128, 240, 0.12);

  /* ── Legacy / compat aliases ─────────────────── */
  --brand-primary:  #e8a030;
  --brand-accent:   #1a68cc;
  --tac-accent:     #e8a030;
  --tac-border:     #4a6080;
  --tac-surface:    #0e1a2c;

  /* ── Text ────────────────────────────────────── */
  --text-primary:   #d8e6f2;
  --text-pri:       #d8e6f2;
  --text-secondary: #98b4cc;
  --text-sec:       #98b4cc;
  --text-tertiary:  #7894b0;
  --text-ter:       #7894b0;
  --text-accent:    #f0b840;
  --text-white:     #f0f6fc;

  /* ── Status ──────────────────────────────────── */
  --color-success: #00cc66;
  --color-warning: #f0a020;
  --color-danger:  #d83030;
  --color-info:    #1a68cc;

  /* ── Typography ──────────────────────────────── */
  --font-display: 'Share Tech Mono', 'Courier Prime', monospace;
  --font-body:    'Barlow Condensed', 'Arial Narrow', sans-serif;
  --font-mono:    'JetBrains Mono', 'Courier New', monospace;
  --font-sans:    'Barlow Condensed', sans-serif;

  /* ── Font sizes ──────────────────────────────── */
  --fs-xxs:  0.60rem;
  --fs-xs:   0.70rem;
  --fs-sm:   0.82rem;
  --fs-base: 0.95rem;
  --fs-md:   1.05rem;
  --fs-lg:   1.3rem;
  --fs-xl:   1.6rem;
  --fs-2xl:  2.1rem;

  /* ── Font weights ────────────────────────────── */
  --fw-light:    300;
  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;

  /* ── Spacing ─────────────────────────────────── */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* ── Layout ──────────────────────────────────── */
  --sidebar-width:     248px;
  --sidebar-collapsed:  56px;
  --topbar-height:      44px;
  --content-max:      1440px;

  /* ── Shape — zero radius for military aesthetic ── */
  --radius:    0px;
  --radius-sm: 0px;
  --radius-lg: 0px;

  /* ── Shadows ─────────────────────────────────── */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.6);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.7);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.8);

  /* ── Transitions ─────────────────────────────── */
  --transition-fast: 110ms ease;
  --transition-med:  220ms ease;
  --transition-slow: 380ms ease;

  /* ── Z-index ─────────────────────────────────── */
  --z-dropdown: 1000;
  --z-sticky:   1100;
  --z-overlay:  1200;
  --z-modal:    1300;
  --z-tooltip:  9000;

  /* ── Form inputs (dedicated tokens) ──────────── */
  --input-bg:          #1a2840;
  --input-bg-focus:    #243352;
  --input-border:      #4a6080;
  --input-border-hover:#6a8aae;
  --input-text:        #f0f6fc;
  --input-placeholder: #7894b0;
  --input-min-height:  36px;

  /* ── Status backgrounds (alerts, badges, buttons) ── */
  --success-bg:        rgba(0,204,102,0.10);
  --success-bg-strong: rgba(0,204,102,0.18);
  --success-border:    rgba(0,204,102,0.45);
  --danger-bg:         rgba(216,48,48,0.10);
  --danger-bg-strong:  rgba(216,48,48,0.18);
  --danger-border:     rgba(216,48,48,0.45);
  --warning-bg:        rgba(240,160,32,0.10);
  --warning-bg-strong: rgba(240,160,32,0.18);
  --warning-border:    rgba(240,160,32,0.45);
  --info-bg:           rgba(36,128,240,0.10);
  --info-bg-strong:    rgba(36,128,240,0.18);
  --info-border:       rgba(36,128,240,0.45);

  /* ── Overlays & map ──────────────────────────── */
  --overlay-dark:      rgba(5,10,20,0.88);
  --map-bg:            rgba(14,26,44,0.94);
  --map-bg-strong:     rgba(14,26,44,0.98);
  --table-hover:       rgba(232,160,48,0.08);

  /* ── Component-specific overrides ────────────── */
  --btn-primary-fg:    #08090c;
  --select-arrow:      %234a6080;
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  background: var(--bg-base);
  color: var(--text-pri);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.55;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Tactical scrollbar */
::-webkit-scrollbar       { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--bg-surface); }
::-webkit-scrollbar-thumb { background: var(--border-bright); }
::-webkit-scrollbar-thumb:hover { background: var(--amber); }

/* Headings */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-white);
}

a { color: var(--amber); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--amber-bright); }
p { font-family: var(--font-body); }
code,kbd,samp,pre { font-family: var(--font-mono); font-size: 0.88em; }

::selection { background: var(--amber-dim); color: var(--amber-bright); }
:focus-visible { outline: 1px solid var(--amber); outline-offset: 2px; }

input,select,textarea,button { font-family: inherit; font-size: inherit; }
img,svg { display: block; max-width: 100%; }
table { border-collapse: collapse; width: 100%; }

/* ── KEYFRAMES ──────────────────────────────────────────────── */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes blink {
  0%,100% { opacity: 1; }
  50%      { opacity: 0; }
}
@keyframes amberPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(232,160,48,0.35); }
  50%      { box-shadow: 0 0 0 5px rgba(232,160,48,0); }
}
@keyframes slideUpIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes scanBar {
  0%   { top: 0; opacity: 0; }
  5%   { opacity: 0.4; }
  95%  { opacity: 0.4; }
  100% { top: 100%; opacity: 0; }
}

/* ── ANIMATION CLASSES ──────────────────────────────────────── */
.animate-in   { animation: fadeSlideUp 0.32s ease both; }
.animate-in-1 { animation-delay: 0.04s; }
.animate-in-2 { animation-delay: 0.08s; }
.animate-in-3 { animation-delay: 0.12s; }
.animate-in-4 { animation-delay: 0.16s; }
.animate-in-5 { animation-delay: 0.20s; }
.blink        { animation: blink 1.4s step-end infinite; }
.pulse-amber  { animation: amberPulse 2s ease-in-out infinite; }

/* ── STATUS DOTS ────────────────────────────────────────────── */
.dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.dot-green  { background: var(--color-success); box-shadow: 0 0 5px rgba(0,204,102,0.6); }
.dot-amber  { background: var(--amber);         box-shadow: 0 0 5px rgba(232,160,48,0.6); }
.dot-red    { background: var(--color-danger);  box-shadow: 0 0 5px rgba(216,48,48,0.6); }
.dot-blue   { background: var(--blue-bright); }
.dot-dim    { background: var(--text-ter); }

/* ── TACTICAL CORNER CARD ───────────────────────────────────── */
.tac-card {
  position: relative;
  background: var(--bg-surface);
  border: 1px solid var(--border-med);
  padding: var(--space-5);
}
.tac-card::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px;
  width: 10px; height: 10px;
  border-top: 1px solid var(--amber);
  border-left: 1px solid var(--amber);
  opacity: 0.5;
}
.tac-card::after {
  content: '';
  position: absolute;
  bottom: -1px; right: -1px;
  width: 10px; height: 10px;
  border-bottom: 1px solid var(--amber);
  border-right: 1px solid var(--amber);
  opacity: 0.5;
}

/* ── STATUS BADGE ───────────────────────────────────────────── */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid;
}
.status-badge.ok   { color: var(--color-success); border-color: var(--success-border); background: var(--success-bg); }
.status-badge.warn { color: var(--color-warning); border-color: var(--warning-border); background: var(--warning-bg); }
.status-badge.err  { color: var(--color-danger);  border-color: var(--danger-border);  background: var(--danger-bg); }
.status-badge.idle { color: var(--text-sec); border-color: var(--border-med); }

/* ── UTILITY CLASSES ────────────────────────────────────────── */
.text-amber   { color: var(--amber); }
.text-blue    { color: var(--blue-bright); }
.text-dim     { color: var(--text-sec); }
.text-white   { color: var(--text-white); }
.text-success { color: var(--color-success); }
.text-danger  { color: var(--color-danger); }
.text-upper   { text-transform: uppercase; letter-spacing: 0.1em; }
.text-mono    { font-family: var(--font-mono); }
.text-display { font-family: var(--font-display); }
.text-xs      { font-size: var(--fs-xs); }
.text-sm      { font-size: var(--fs-sm); }
.font-mono    { font-family: var(--font-mono); }
.d-flex       { display: flex; }
.items-center { align-items: center; }
.gap-2        { gap: var(--space-2); }
.gap-3        { gap: var(--space-3); }
.gap-4        { gap: var(--space-4); }
.flex-1       { flex: 1; }
.mt-auto      { margin-top: auto; }
.mb-4         { margin-bottom: var(--space-4); }
.mb-6         { margin-bottom: var(--space-6); }
.mb-8         { margin-bottom: var(--space-8); }
