/*═══════════════════════════════════════════════════════
  JARVIS V2.0 — Iron Man HUD Design System
  Based on design-mockup.html visual specification
  Arc Reactor Blue #00FFFF · Deep Space #060b18
  ═══════════════════════════════════════════════════════*/

/*── Color / Surface Tokens ──────────────────────────*/
:root {
  /* Background levels */
  --bg-root:    #060b18;
  --bg-base:    #0a1226;
  --bg-raised:  #111d36;
  --bg-overlay: #192842;
  
  /* Arc Reactor Blue */
  --ac-primary:   #00FFFF;
  --ac-secondary: #00B4F0;
  --ac-glow:      rgba(0,255,255,.22);
  --ac-surface:   rgba(0,255,255,.07);
  
  /* Semantic colors */
  --ok:      #10B981;
  --ok-bg:   rgba(16,185,129,.10);
  --warn:    #F59E0B;
  --warn-bg: rgba(245,158,11,.10);
  --bad:     #EF4444;
  --bad-bg:  rgba(239,68,68,.10);
  --info:    #6366F1;
  --info-bg: rgba(99,102,241,.10);
  
  /* Text colors */
  --tx-primary:   #E6EDF6;
  --tx-secondary: #7589A3;
  --tx-tertiary:  #3D4F66;
  --tx-inverse:   #060B18;
  
  /* Border colors */
  --bd-subtle:  rgba(255,255,255,.04);
  --bd-default: rgba(255,255,255,.07);
  --bd-strong:  rgba(255,255,255,.11);
  --bd-focus:   rgba(0,255,255,.40);
  
  /* Typography */
  --ff-ui:   "Inter", "Noto Sans SC", -apple-system, system-ui, sans-serif;
  --ff-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;
  --fs-display: 48px;
  --fs-number:  32px;
  --fs-title:   22px;
  --fs-h:       17px;
  --fs-ui:      14px;
  --fs-body:    13px;
  --fs-label:   11px;
  --fs-caption: 10px;
  
  /* Weights */
  --fw-n:  400;
  --fw-m:  500;
  --fw-sb: 600;
  --fw-b: 700;
  
  /* Spacing */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px;
  --s5:20px; --s6:24px; --s8:32px; --s10:40px; --s12:48px;
  
  /* Radius */
  --r1:3px; --r2:6px; --r3:8px; --r4:12px; --r-pill:9999px;
  
  /* Shadows */
  --shadow-card:     0 1px 3px rgba(0,0,0,.4);
  --shadow-elevated: 0 4px 16px rgba(0,0,0,.5);
  --shadow-glow:     0 0 20px var(--ac-glow);
  
  /* Sizes */
  --nav-h: 44px;
  
  /* ═══ Legacy aliases → spec vars (base.css) ═══ */
  /* Backgrounds */
  --bg-root:    var(--bg-deepest);
  --bg-base:    var(--bg-deep);
  --bg-raised:  var(--bg-panel);
  --bg-overlay: var(--bg-hover);
  
  /* Arc Reactor Blue → Brand */
  --ac-primary:   var(--brand-blue);
  --ac-secondary: var(--brand-blue-hover);
  --ac-glow:      var(--brand-blue-glow);
  --ac-surface:   var(--bg-info);
  
  /* Semantic → Status */
  --ok:      var(--color-success);
  --ok-bg:   var(--bg-success);
  --warn:    var(--color-warning);
  --warn-bg: var(--bg-warning);
  --bad:     var(--color-error);
  --bad-bg:  var(--bg-error);
  --info:    var(--color-info);
  --info-bg: var(--bg-info);
  
  /* Text */
  --tx-primary:   var(--text-primary);
  --tx-secondary: var(--text-secondary);
  --tx-tertiary:  var(--text-disabled);
  --tx-inverse:   var(--bg-deepest);
  
  /* Border */
  --bd-subtle:  var(--border-default);
  --bd-default: var(--border-default);
  --bd-strong:  var(--border-emphasis);
  
  /* Typography */
  --ff-ui:     var(--font-sans);
  --ff-mono:   var(--font-mono);
  --fs-title:  var(--text-h1);
  --fs-ui:     var(--text-body);
  --fs-label:  var(--text-caption);
  --fs-caption:var(--text-caption);
  --fs-number: var(--text-data-large);
  --fs-body:   var(--text-body);
  --fw-b:      700;
  --fw-sb:     600;
  --fw-m:      500;
  
  /* Spacing */
  --s1:  var(--space-1);
  --s2:  var(--space-2);
  --s3:  var(--space-3);
  --s4:  var(--space-4);
  --s5:  var(--space-5);
  --s6:  var(--space-6);
  --s10: var(--space-12);
  
  /* Radius */
  --r1: var(--radius-sm);
  --r2: var(--radius-md);
  --r3: var(--radius-lg);
  --r-pill: var(--radius-full);
  
  /* Navigation */
  --nav-h: 48px;
}

/*── Reset ───────────────────────────────────────────*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{
  background:var(--bg-root);color:var(--tx-primary);
  font-family:var(--ff-ui);font-size:var(--fs-body);line-height:1.5;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  position:relative;
}
::selection{background:var(--ac-primary);color:var(--tx-inverse)}
:focus-visible{outline:2px solid var(--ac-primary);outline-offset:2px;border-radius:var(--r1)}
img,svg{display:block;max-width:100%}
input,button,select,textarea{font:inherit;color:inherit}

/*── Scanline Overlay ────────────────────────────────*/
body::after{
  content: ""; position: fixed; inset: 0; z-index: 9998; pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,255,255,.012) 2px,
    rgba(0,255,255,.012) 4px
  );
}

/*── Particles Canvas ───────────────────────────────*/
#particles {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

/*═══ Top Navigation ═══════════════════════════════════*/
.nav {
  height: var(--nav-h);
  background: rgba(6,11,24,.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--bd-subtle);
  display: flex;
  align-items: center;
  padding: 0 var(--s4);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: var(--s2);
  font-size: var(--fs-ui);
  font-weight: var(--fw-b);
  color: var(--ac-primary);
  text-decoration: none;
}

.nav-logo::before {
  content: "●";
  color: var(--ac-primary);
  animation: arc-pulse 2s ease-in-out infinite;
  width: 10px;
  height: 10px;
  display: inline-block;
  border-radius: 50%;
}

.nav-tabs {
  display: flex;
  gap: var(--s4);
  margin-left: var(--s6);
  flex: 1;
}

.nav-tab {
  background: transparent;
  border: none;
  color: var(--tx-secondary);
  font-size: var(--fs-label);
  font-weight: var(--fw-m);
  padding: var(--s2) 0;
  cursor: pointer;
  position: relative;
  transition: color 120ms ease-out;
}

.nav-tab:hover {
  color: var(--tx-primary);
}

.nav-tab.active {
  color: var(--ac-secondary);
}

.nav-tab.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--ac-primary);
  border-radius: 1px;
}

.nav-right {
  display: flex;
  align-items: center;
  gap: var(--s3);
  font-size: var(--fs-label);
  color: var(--tx-secondary);
}

.status-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ok);
  animation: pulse 2s ease-in-out infinite;
}

/*═══ Main Content ════════════════════════════════════*/
#main {
  padding: calc(var(--nav-h) + var(--s4)) var(--s4) var(--s4);
}

.pg-hd {
  margin-bottom: var(--s4);
}

.pg-hd h2 {
  font-size: var(--fs-title);
  font-weight: var(--fw-b);
  color: var(--tx-primary);
  margin-bottom: var(--s1);
}

.pg-hd p {
  font-size: var(--fs-body);
  color: var(--tx-secondary);
}

/*═══ Grids ──────────────────────────────────────────*/
.grid2 { display: grid; gap: var(--s3); grid-template-columns: repeat(2, 1fr); }
.grid3 { display: grid; gap: var(--s3); grid-template-columns: repeat(3, 1fr); }
.grid4 { display: grid; gap: var(--s3); grid-template-columns: repeat(4, 1fr); }

/*═══ Card ───────────────────────────────────────────*/
.card {
  background: var(--bg-base);
  border: 1px solid var(--bd-subtle);
  border-radius: var(--r3);
  padding: var(--s5);
  transition: border-color 120ms ease-out, box-shadow 120ms ease-out;
}

.card:hover {
  border-color: var(--bd-default);
  box-shadow: 0 0 6px rgba(0,255,255,.08);
}

.card.active {
  border-color: rgba(0,255,255,.18);
  box-shadow: 0 0 12px rgba(0,255,255,.06);
}

/*═══ Metric ─────────────────────────────────────────*/
.metric-value {
  font-size: var(--fs-number);
  font-weight: var(--fw-b);
  line-height: 1.1;
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
  color: var(--ac-secondary);
  text-shadow: 0 0 4px rgba(0,255,255,.15);
}

.metric-label {
  font-size: var(--fs-label);
  color: var(--tx-secondary);
  margin-top: var(--s1);
}

.metric-sub {
  font-size: var(--fs-caption);
  color: var(--tx-tertiary);
  margin-top: 2px;
}

/*═══ Progress ───────────────────────────────────────*/
.progress {
  height: 3px;
  background: var(--bg-overlay);
  border-radius: 2px;
  overflow: hidden;
  margin: var(--s2) 0;
}

.progress-bar {
  height: 100%;
  border-radius: 2px;
  transition: width 600ms cubic-bezier(.16,1,.3,1);
}

.progress-bar.ok  { background: var(--ok); }
.progress-bar.warn{ background: var(--warn); }
.progress-bar.bad { background: var(--bad); }
.progress-bar.blue{ background: var(--ac-secondary); }

/*═══ Badge ──────────────────────────────────────────*/
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-caption);
  font-weight: var(--fw-sb);
  padding: 2px 8px;
  border-radius: var(--r-pill);
  letter-spacing: .3px;
}

.badge-ok     { background: var(--ok-bg);   color: var(--ok); }
.badge-warn   { background: var(--warn-bg); color: var(--warn); }
.badge-bad    { background: var(--bad-bg);  color: var(--bad); }
.badge-info   { background: var(--ac-surface); color: var(--ac-secondary); }
.badge-neutral { background: var(--bg-overlay); color: var(--tx-tertiary); }

/*═══ Tag ────────────────────────────────────────────*/
.tag {
  display: inline-flex;
  align-items: center;
  font-size: var(--fs-caption);
  font-family: var(--ff-mono);
  padding: 1px 6px;
  border-radius: var(--r1);
  letter-spacing: .2px;
}

.tag-blue   { background: var(--ac-surface); color: var(--ac-secondary); }
.tag-green  { background: var(--ok-bg);      color: var(--ok); }
.tag-orange { background: var(--warn-bg);    color: var(--warn); }
.tag-red    { background: var(--bad-bg);     color: var(--bad); }

/*═══ Agent Fleet Container ──────────────────────────*/
.agent-fleet-container {
  height: 400px;
  background: var(--bg-base);
  border: 1px solid var(--bd-subtle);
  border-radius: var(--r3);
  overflow: hidden;
  position: relative;
}

#agent-force-graph {
  width: 100%;
  height: 100%;
}

/*═══ Animations ─────────────────────────────────────*/
@keyframes arc-pulse {
  0%, 100% {
    box-shadow: 0 0 6px var(--ac-glow), 0 0 14px rgba(0,255,255,.12);
  }
  50% {
    box-shadow: 0 0 12px var(--ac-glow), 0 0 26px rgba(0,255,255,.18);
  }
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .4; transform: scale(1.3); }
}

@keyframes value-flash {
  0%   { color: var(--ac-secondary); text-shadow: 0 0 8px var(--ac-glow); }
  100% { color: var(--tx-primary); }
}

.pulse {
  animation: pulse 2s ease-in-out infinite;
}

.value-updated {
  animation: value-flash 600ms ease-out;
}

/*═══ Responsive ─────────────────────────────────────*/
@media (max-width: 1024px) {
  .grid4 { grid-template-columns: repeat(2, 1fr); }
  .grid3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .grid2, .grid3, .grid4 { grid-template-columns: 1fr; }
  .nav-tabs { display: none; }
  #main { padding: calc(var(--nav-h) + var(--s3)) var(--s3) var(--s3); }
  .metric-value { font-size: 24px; }
}

/*═══ Fullscreen Mode ────────────────────────────────*/
#main.fullscreen { height: calc(100vh - var(--nav-h)); overflow: hidden; }
#main.fullscreen .pg.on { height: 100%; overflow: hidden; display: flex; flex-direction: column; }
#main.fullscreen .pg.on .pg-hd { flex-shrink: 0; }
#main.fullscreen .pg.on .pg-content { flex: 1; overflow-y: auto; overflow-x: hidden; }

/*═══ Chart ──────────────────────────────────────────*/
.chart { width: 100%; height: 240px; }

/*═══ Table ──────────────────────────────────────────*/
.data-table { width: 100%; border-collapse: collapse; font-size: var(--fs-body); font-family: var(--ff-mono); }
.data-table th { text-align: left; color: var(--tx-tertiary); font-weight: var(--fw-sb); padding: var(--s2) var(--s3); border-bottom: 2px solid var(--bd-strong); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: .5px; }
.data-table td { padding: var(--s2) var(--s3); border-bottom: 1px solid var(--bd-subtle); }
.data-table tbody tr:hover td { background: var(--bg-raised); }

/*═══ Button ─────────────────────────────────────────*/
.j-btn {
  display: inline-flex; align-items: center; gap: var(--s1);
  background: var(--bg-raised); color: var(--tx-primary); border: 1px solid var(--bd-default);
  border-radius: var(--r2); padding: var(--s2) var(--s4); font-size: var(--fs-label); font-weight: var(--fw-m);
  cursor: pointer; transition: all 120ms ease-out; white-space: nowrap;
  font-family: var(--ff-ui);
}
.j-btn:hover { background: var(--bg-overlay); border-color: var(--ac-primary); }

/*═══ Select ─────────────────────────────────────────*/
.j-select {
  background: var(--bg-overlay); color: var(--tx-primary); border: 1px solid var(--bd-default);
  border-radius: var(--r2); padding: 6px 10px; font-size: var(--fs-label); cursor: pointer;
  transition: border-color 120ms;
  font-family: var(--ff-ui);
}
.j-select:hover { border-color: var(--bd-strong); }
.j-select:focus { border-color: var(--ac-primary); outline: none; box-shadow: 0 0 0 2px var(--ac-surface); }

/*═══ Iframes ────────────────────────────────────────*/
.comm-iframe { width: 100%; border: none; border-radius: var(--r3); background: var(--bg-root); }
.aitown-frame { width: 100%; border: none; border-radius: var(--r3); background: var(--bg-root); }

/*═══ Empty State ────────────────────────────────────*/
.empty { text-align: center; padding: var(--s10) var(--s4); color: var(--tx-tertiary); }
.empty-icon { font-size: 36px; margin-bottom: var(--s3); opacity: .6; }
.empty-text { font-size: var(--fs-body); }

/*═══ Stat Row ───────────────────────────────────────*/
.stat-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--s2) 0; border-bottom: 1px solid var(--bd-subtle);
  font-size: var(--fs-body); font-family: var(--ff-ui);
}
.stat-row:last-child { border-bottom: none; }
.stat-label { color: var(--tx-secondary); flex-shrink: 0; margin-right: var(--s2); }
.stat-value { font-family: var(--ff-mono); font-weight: var(--fw-sb); text-align: right; font-variant-numeric: tabular-nums; }
.stat-value.ok { color: var(--ok); }
.stat-value.warn { color: var(--warn); }
.stat-value.bad { color: var(--bad); }
.stat-value.ac { color: var(--ac-secondary); }

/*═══ Page Shell ─────────────────────────────────────*/
.pg { display: none; }
.pg.on { display: block; }

/*═══ Fullscreen HUD Overlay ─────────────────────────*/
#hud-overlay {
  display: none; position: fixed; inset: 0; z-index: 9998; background: var(--bg-root);
  flex-direction: column; align-items: center; justify-content: center;
}
#hud-overlay.active { display: flex; }
.hud-exit {
  position: absolute; top: var(--s4); right: var(--s4);
  background: var(--bg-raised); border: 1px solid var(--bd-default); color: var(--tx-secondary);
  padding: var(--s2) var(--s4); border-radius: var(--r2); font-size: var(--fs-label);
  font-family: var(--ff-ui); cursor: pointer; transition: all 120ms;
}
.hud-exit:hover { color: var(--bad); border-color: var(--bad); }
.hud-core { position: relative; width: 280px; height: 280px; text-align: center; }
.hud-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid var(--ac-primary);
  animation: hud-spin 8s linear infinite; opacity: .12;
}
.hud-ring:nth-child(2) { inset: 18px; animation-duration: 12s; animation-direction: reverse; opacity: .08; }
.hud-ring:nth-child(3) { inset: 36px; animation-duration: 6s; opacity: .18; }
.hud-center {
  position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
}
.hud-name {
  font-size: 44px; font-weight: var(--fw-b); color: var(--ac-primary);
  font-family: var(--ff-mono); letter-spacing: -1px;
  text-shadow: 0 0 12px rgba(0,229,255,.5), 0 0 30px rgba(0,229,255,.2);
}
.hud-status {
  font-size: var(--fs-label); color: var(--tx-tertiary);
  font-family: var(--ff-mono); letter-spacing: 4px; text-transform: uppercase; margin-top: var(--s2);
}
.hud-stats {
  margin-top: var(--s6); display: flex; gap: var(--s10);
  font-family: var(--ff-mono); font-size: var(--fs-body); color: var(--tx-secondary);
}
.hud-stat { text-align: center; }
.hud-stats .val,
.hud-stat .val { display: block; font-size: var(--fs-title); color: var(--tx-primary); font-weight: var(--fw-b); }

@keyframes hud-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/*═══ Scrollbar ──────────────────────────────────────*/
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg-overlay); border-radius: var(--r-pill); }
::-webkit-scrollbar-thumb:hover { background: var(--tx-tertiary); }

/*═══ Reduced Motion ─────────────────────────────────*/
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }