/* ============================================================
   F.I.N.C.H. — Operations Console
   Theme: dark sci-fi HUD, cyan/amber accents
   ============================================================ */

:root {
  --c-bg: #030a12;
  --c-bg-panel: rgba(8, 24, 38, 0.72);
  --c-primary: #14d8f5;
  --c-primary-dim: rgba(20, 216, 245, 0.35);
  --c-primary-faint: rgba(20, 216, 245, 0.10);
  --c-amber: #ffb347;
  --c-red: #ff4d5e;
  --c-green: #3dffa0;
  --c-text: #bfeaf5;
  --c-text-dim: #5a8da0;
  --font-main: "Rajdhani", "Avenir Next", "Segoe UI", system-ui, sans-serif;
  --font-mono: "SF Mono", "Menlo", "Consolas", monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html, body {
  height: 100%;
  overflow: hidden;
  background: var(--c-bg);
  color: var(--c-text);
  font-family: var(--font-main);
}

body {
  background-image:
    radial-gradient(ellipse at 50% -20%, rgba(20, 216, 245, 0.12), transparent 60%),
    radial-gradient(ellipse at 50% 120%, rgba(20, 100, 245, 0.08), transparent 60%),
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(20, 216, 245, 0.03) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(20, 216, 245, 0.03) 39px 40px);
  transition: background-color 0.8s;
}

/* ---- alert mode (scenario: incident) ---- */
body.alert-mode {
  background-image:
    radial-gradient(ellipse at 50% -20%, rgba(255, 77, 94, 0.16), transparent 60%),
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(255, 77, 94, 0.04) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(255, 77, 94, 0.04) 39px 40px);
}
body.alert-mode .panel { border-color: rgba(255, 77, 94, 0.4); }
body.alert-mode .status-dot { background: var(--c-red); box-shadow: 0 0 12px var(--c-red); }
body.alert-mode #system-status-text { color: var(--c-red); }
body.alert-mode .core { background: radial-gradient(circle, #fff 0%, var(--c-red) 35%, rgba(255,77,94,0.25) 70%, transparent 100%); box-shadow: 0 0 40px var(--c-red), 0 0 90px rgba(255,77,94,0.5); }

/* ---- scanlines overlay ---- */
.scanlines {
  position: fixed; inset: 0; z-index: 100; pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.12) 0 1px, transparent 1px 3px);
  mix-blend-mode: multiply;
}

/* ============ LAYOUT ============ */

.hud {
  display: flex;
  flex-direction: column;
  height: 100vh;
  padding: 14px 18px 0;
  gap: 12px;
}

.hud-grid {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1.25fr 1.1fr;
  gap: 12px;
  min-height: 0;
}

.col { display: flex; flex-direction: column; gap: 12px; min-height: 0; }

/* ============ HEADER ============ */

.hud-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  border: 1px solid var(--c-primary-dim);
  background: var(--c-bg-panel);
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
}

.logo { display: flex; align-items: center; gap: 12px; }

.logo-ring {
  width: 26px; height: 26px; border-radius: 50%;
  border: 2px solid var(--c-primary);
  border-top-color: transparent;
  animation: spin 3s linear infinite;
  box-shadow: 0 0 12px var(--c-primary-dim), inset 0 0 8px var(--c-primary-dim);
}

.logo h1 {
  font-size: 26px; letter-spacing: 6px; font-weight: 600;
  color: var(--c-primary);
  text-shadow: 0 0 14px var(--c-primary-dim);
}

.subtitle { font-size: 11px; letter-spacing: 2px; color: var(--c-text-dim); margin-left: 38px; display: block; }

.system-status {
  display: flex; align-items: center; gap: 10px;
  font-size: 15px; letter-spacing: 3px; font-weight: 600;
}

.status-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--c-green); box-shadow: 0 0 12px var(--c-green);
  animation: pulse 2s ease-in-out infinite;
}

.header-right { display: flex; align-items: center; gap: 18px; }

.voice-btn {
  background: transparent; color: var(--c-text-dim);
  border: 1px solid var(--c-primary-dim);
  font-family: var(--font-main); font-size: 11px; letter-spacing: 2px;
  padding: 6px 12px; cursor: pointer;
}
.voice-btn.on { color: var(--c-primary); border-color: var(--c-primary); box-shadow: 0 0 10px var(--c-primary-faint); }

.clock-block { text-align: right; }
#clock { font-size: 26px; font-weight: 600; color: var(--c-primary); letter-spacing: 3px; font-variant-numeric: tabular-nums; }
#date { font-size: 11px; letter-spacing: 2px; color: var(--c-text-dim); text-transform: uppercase; }

/* ============ PANELS ============ */

.panel {
  border: 1px solid var(--c-primary-dim);
  background: var(--c-bg-panel);
  display: flex; flex-direction: column;
  min-height: 0;
  position: relative;
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  transition: border-color 0.6s;
}

.panel::before {
  content: ""; position: absolute; top: 0; left: 0;
  width: 40px; height: 2px; background: var(--c-primary);
  box-shadow: 0 0 8px var(--c-primary);
}

.panel-title {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 14px;
  font-size: 12px; letter-spacing: 3px; font-weight: 600;
  color: var(--c-primary);
  border-bottom: 1px solid var(--c-primary-faint);
  flex-shrink: 0;
}

.panel-tag {
  font-size: 10px; letter-spacing: 2px;
  color: var(--c-text-dim);
  border: 1px solid var(--c-primary-faint);
  padding: 2px 8px;
}

.panel-tag.blink { animation: blink 1.4s step-end infinite; }

.panel-body { flex: 1; min-height: 0; padding: 10px 14px; overflow: hidden; }

/* ============ SERVERS ============ */

#panel-servers { flex: 1.4; }

.server-list { display: flex; flex-direction: column; gap: 8px; overflow-y: auto; }

.server-card {
  border: 1px solid var(--c-primary-faint);
  padding: 8px 10px;
  background: rgba(10, 30, 48, 0.5);
  transition: border-color 0.5s, background 0.5s;
}
.server-card.state-warning { border-color: rgba(255, 179, 71, 0.55); }
.server-card.state-critical { border-color: rgba(255, 77, 94, 0.7); background: rgba(60, 12, 18, 0.4); animation: alert-flash 1s ease-in-out infinite; }
.server-card.state-offline { opacity: 0.45; border-color: rgba(90, 141, 160, 0.3); }

.server-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.server-name { font-size: 13px; font-weight: 600; letter-spacing: 2px; }
.server-state { font-size: 10px; letter-spacing: 2px; font-weight: 600; color: var(--c-green); }
.state-warning .server-state { color: var(--c-amber); }
.state-critical .server-state { color: var(--c-red); }
.state-offline .server-state { color: var(--c-text-dim); }

.server-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.metric { font-size: 9px; letter-spacing: 1px; color: var(--c-text-dim); }
.metric-bar { height: 4px; background: rgba(20, 216, 245, 0.12); margin-top: 3px; position: relative; overflow: hidden; }
.metric-fill { position: absolute; inset: 0 auto 0 0; background: var(--c-primary); transition: width 0.8s ease; box-shadow: 0 0 6px var(--c-primary-dim); }
.metric-fill.hot { background: var(--c-amber); box-shadow: 0 0 6px rgba(255,179,71,0.5); }
.metric-fill.crit { background: var(--c-red); box-shadow: 0 0 6px rgba(255,77,94,0.5); }
.metric-value { float: right; color: var(--c-text); font-variant-numeric: tabular-nums; }

/* ============ DEPLOYMENTS ============ */

#panel-deploy { flex: 1; }

.deploy-list { display: flex; flex-direction: column; gap: 10px; overflow-y: auto; }

.deploy-item { font-size: 12px; }
.deploy-head { display: flex; justify-content: space-between; margin-bottom: 4px; }
.deploy-name { letter-spacing: 1px; font-weight: 600; }
.deploy-stage { font-size: 10px; letter-spacing: 2px; color: var(--c-amber); }
.deploy-item.done .deploy-stage { color: var(--c-green); }
.deploy-item.failed .deploy-stage { color: var(--c-red); }

.deploy-bar { height: 6px; background: rgba(20, 216, 245, 0.1); position: relative; overflow: hidden; }
.deploy-fill {
  position: absolute; inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--c-primary-dim), var(--c-primary));
  transition: width 0.6s ease;
}
.deploy-item.done .deploy-fill { background: var(--c-green); }
.deploy-item.failed .deploy-fill { background: var(--c-red); }

.deploy-steps { display: flex; gap: 6px; margin-top: 5px; }
.deploy-step { font-size: 9px; letter-spacing: 1px; color: var(--c-text-dim); padding: 1px 6px; border: 1px solid var(--c-primary-faint); }
.deploy-step.active { color: var(--c-amber); border-color: rgba(255,179,71,0.5); animation: blink 1.2s step-end infinite; }
.deploy-step.ok { color: var(--c-green); border-color: rgba(61,255,160,0.4); }

/* ============ REACTOR / RADAR ============ */

.panel-reactor { flex: 0 0 auto; align-items: center; padding: 16px 0 10px; }

.reactor-wrap { position: relative; width: 230px; height: 230px; margin: 0 auto; }

#radar { position: absolute; inset: -35px; width: 300px; height: 300px; }

.arc-reactor { position: absolute; inset: 0; }

.ring { position: absolute; border-radius: 50%; border: 1px solid var(--c-primary-dim); }
.ring-1 { inset: 0; border-width: 2px; border-style: dashed; animation: spin 22s linear infinite; }
.ring-2 { inset: 22px; border-top: 2px solid var(--c-primary); border-bottom: 2px solid var(--c-primary); animation: spin-rev 9s linear infinite; }
.ring-3 { inset: 46px; border-left: 2px solid var(--c-primary); border-right: 2px solid var(--c-primary); animation: spin 6s linear infinite; }

.core {
  position: absolute; inset: 75px; border-radius: 50%;
  background: radial-gradient(circle, #ffffff 0%, var(--c-primary) 35%, rgba(20,216,245,0.25) 70%, transparent 100%);
  box-shadow: 0 0 40px var(--c-primary), 0 0 90px var(--c-primary-dim);
  animation: pulse 2.6s ease-in-out infinite;
}

.reactor-readouts {
  display: flex; gap: 26px; margin-top: 14px; justify-content: center;
}
.readout { text-align: center; }
.readout-label { display: block; font-size: 9px; letter-spacing: 2px; color: var(--c-text-dim); }
.readout-value { font-size: 16px; font-weight: 600; color: var(--c-primary); font-variant-numeric: tabular-nums; }

/* ============ FINCH CONSOLE ============ */

.panel-finch { flex: 0 0 92px; }

.finch-console { display: flex; align-items: center; font-family: var(--font-mono); font-size: 13px; }
.finch-line { line-height: 1.5; }
.prompt { color: var(--c-amber); margin-right: 8px; }
#finch-text { color: var(--c-text); text-shadow: 0 0 8px var(--c-primary-faint); }
.cursor { color: var(--c-primary); animation: blink 1s step-end infinite; margin-left: 2px; }

/* ============ GAUGES ============ */

.panel-gauges { flex: 0 0 auto; padding: 10px 0; }
.gauge-grid { display: grid; grid-template-columns: repeat(4, 1fr); justify-items: center; }
.gauge-cell { display: flex; flex-direction: column; align-items: center; }
.gauge-cell canvas { width: 100px; height: 100px; }
.gauge-label { font-size: 10px; letter-spacing: 2px; color: var(--c-text-dim); margin-top: -6px; }

/* ============ TRAFFIC CHART ============ */

.panel-chart { flex: 1; }
.chart-body { padding: 6px 10px 10px; }
#traffic-chart { width: 100%; height: 100%; }

/* ============ LOGS ============ */

.panel-logs { flex: 1.6; }

.log-stream {
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.65;
  overflow-y: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
}

.log-line { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; opacity: 0; animation: log-in 0.3s ease forwards; }
.log-time { color: var(--c-text-dim); }
.log-service { color: var(--c-primary); }
.log-level-INFO { color: var(--c-green); }
.log-level-WARN { color: var(--c-amber); }
.log-level-ERROR { color: var(--c-red); font-weight: 700; }
.log-level-DEBUG { color: var(--c-text-dim); }
.log-msg { color: var(--c-text); }

/* ============ ANALYSIS ============ */

#panel-analysis { flex: 1; }

.analysis-body { display: flex; flex-direction: column; gap: 12px; }

.analysis-counters { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.counter { text-align: center; border: 1px solid var(--c-primary-faint); padding: 8px 0; }
.counter-value { display: block; font-size: 22px; font-weight: 700; font-variant-numeric: tabular-nums; }
.counter-label { font-size: 9px; letter-spacing: 2px; color: var(--c-text-dim); }
.counter-info .counter-value { color: var(--c-green); }
.counter-warn .counter-value { color: var(--c-amber); }
.counter-error .counter-value { color: var(--c-red); }

.threat-label { display: flex; justify-content: space-between; font-size: 10px; letter-spacing: 2px; color: var(--c-text-dim); margin-bottom: 5px; }
#threat-value { font-weight: 700; color: var(--c-green); }
.threat-bar { height: 8px; background: rgba(20, 216, 245, 0.1); overflow: hidden; }
.threat-fill {
  height: 100%; width: 8%;
  background: linear-gradient(90deg, var(--c-green), var(--c-amber), var(--c-red));
  background-size: 400px 100%;
  transition: width 1.2s ease;
}

.analysis-notes { font-family: var(--font-mono); font-size: 11px; color: var(--c-text-dim); line-height: 1.7; overflow: hidden; flex: 1; }
.analysis-notes .note-new { color: var(--c-primary); animation: log-in 0.4s ease; }

/* ============ TICKER ============ */

.ticker-bar {
  flex-shrink: 0;
  border-top: 1px solid var(--c-primary-dim);
  background: rgba(8, 24, 38, 0.9);
  overflow: hidden;
  height: 34px;
  display: flex; align-items: center;
  margin: 0 -18px;
  position: relative;
}

.brand {
  position: absolute; right: 0; top: 0; bottom: 0;
  display: flex; align-items: center;
  padding: 0 18px 0 24px;
  background: rgba(8, 24, 38, 0.95);
  border-left: 1px solid var(--c-primary-faint);
  font-size: 10px; letter-spacing: 3px;
  color: var(--c-text-dim);
  z-index: 2;
}

.ticker-track {
  display: inline-flex; gap: 60px;
  white-space: nowrap;
  font-size: 12px; letter-spacing: 2px;
  color: var(--c-text-dim);
  animation: ticker 45s linear infinite;
  padding-left: 100%;
}
.ticker-track b { color: var(--c-primary); font-weight: 600; }

/* ============ ANIMATIONS ============ */

@keyframes spin     { to { transform: rotate(360deg); } }
@keyframes spin-rev { to { transform: rotate(-360deg); } }
@keyframes pulse    { 0%, 100% { opacity: 1; } 50% { opacity: 0.55; } }
@keyframes blink    { 50% { opacity: 0; } }
@keyframes ticker   { to { transform: translateX(-100%); } }
@keyframes log-in   { from { opacity: 0; transform: translateX(-8px); } to { opacity: 1; transform: translateX(0); } }
@keyframes alert-flash { 0%, 100% { box-shadow: 0 0 0 rgba(255,77,94,0); } 50% { box-shadow: 0 0 18px rgba(255,77,94,0.35); } }
