@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&family=Exo+2:wght@300;400;600&display=swap');

/* ─── Variables ──────────────────────────────────────────────────────────────── */
:root {
  --g:      #00ff41;
  --gd:     #00aa2a;
  --g2:     rgba(0,255,65,0.08);
  --g3:     rgba(0,255,65,0.15);
  --a:      #ffb000;
  --r:      #ff3333;
  --c:      #00eeff;
  --b:      #0077ff;
  --bg:     #000902;
  --panel:  rgba(2,12,4,0.93);
  --border: rgba(0,255,65,0.18);
  --mono:   'Share Tech Mono', monospace;
  --head:   'Orbitron', monospace;
  --body:   'Exo 2', sans-serif;

  /* AZ flag accent */
  --az-blue: #0092BC;
  --az-red:  #EF3340;
  --az-green:#00B140;
}

/* ─── Reset ──────────────────────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html, body { width: 100%; height: 100%; overflow: hidden; background: var(--bg); color: var(--g); font-family: var(--mono); cursor: crosshair; }

/* ─── CRT layers ─────────────────────────────────────────────────────────────── */
.crt-lines {
  position: fixed; inset: 0; pointer-events: none; z-index: 9999;
  background: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,0,0,0.06) 3px, rgba(0,0,0,0.06) 4px);
}
.vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 9998;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.75) 100%);
}
.scanline {
  position: fixed; left: 0; right: 0; height: 2px; z-index: 9997; pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(0,255,65,0.07), transparent);
  animation: scanmove 9s linear infinite;
}
@keyframes scanmove { from { top: 44px } to { top: calc(100vh - 40px) } }

.noise-overlay {
  position: fixed; inset: 0; z-index: 9996; pointer-events: none; opacity: 0.022;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px;
}

/* ─── Top bar ────────────────────────────────────────────────────────────────── */
#topbar {
  position: fixed; top: 0; left: 0; right: 0; height: 44px; z-index: 1000;
  background: rgba(0,6,2,0.98);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px;
  box-shadow: 0 2px 20px rgba(0,255,65,0.06);
}

/* AZ flag stripe at very top */
#topbar::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--az-blue) 33.3%, var(--az-red) 33.3% 66.6%, var(--az-green) 66.6%);
}

.top-left { display: flex; align-items: center; gap: 14px; }

/* Logo */
.logo { font-family: var(--head); font-size: 15px; font-weight: 900; letter-spacing: 1px; display: flex; align-items: baseline; gap: 2px; }
.logo-i     { color: var(--az-blue); text-shadow: 0 0 12px var(--az-blue); }
.logo-play  { color: #fff; }
.logo-dot   { color: var(--az-red); }
.logo-az    { color: var(--az-green); text-shadow: 0 0 12px var(--az-green); }
.logo-sep   { color: var(--border); margin: 0 6px; }
.logo-wv    { color: var(--g); font-size: 11px; letter-spacing: 4px; text-shadow: 0 0 14px var(--g); }

.top-badges { display: flex; gap: 8px; }
.badge { font-size: 8px; padding: 2px 7px; letter-spacing: 2px; font-family: var(--mono); }
.badge-red  { color: var(--r); border: 1px solid var(--r); }
.badge-dim  { color: var(--gd); border: 1px solid var(--border); }
.anim-blink { animation: blink 1.5s infinite; }
@keyframes blink { 50% { opacity: 0.2 } }

.top-center { flex: 1; text-align: center; }
.coord-text { font-size: 10px; color: var(--c); letter-spacing: 1px; font-family: var(--mono); }

.top-right { display: flex; align-items: center; gap: 18px; font-size: 10px; }
.status-cluster { display: flex; align-items: center; gap: 5px; color: var(--gd); }
#clock { font-size: 13px; color: var(--g); letter-spacing: 2px; }
.dim-text { color: var(--gd); }

/* ─── Globe ──────────────────────────────────────────────────────────────────── */
#cesiumContainer { position: fixed; inset: 0; z-index: 1; }

/* Hide Cesium default UI */
.cesium-widget-credits, .cesium-credit-logoContainer { display: none !important; }

/* ─── Panel shared ───────────────────────────────────────────────────────────── */
#lpanel, #rpanel {
  position: fixed; top: 54px; bottom: 50px; z-index: 100;
  width: 220px; display: flex; flex-direction: column; gap: 6px;
  overflow-y: auto; padding: 0 2px;
  scrollbar-width: thin; scrollbar-color: var(--gd) transparent;
}
#lpanel::-webkit-scrollbar, #rpanel::-webkit-scrollbar { width: 2px; }
#lpanel::-webkit-scrollbar-thumb, #rpanel::-webkit-scrollbar-thumb { background: var(--gd); }
#lpanel { left: 12px; }
#rpanel { right: 12px; }

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 9px 12px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color 0.2s;
}
.card:hover { border-color: rgba(0,255,65,0.3); }

.card-title {
  font-size: 8px; letter-spacing: 3px; color: var(--gd);
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px; padding-bottom: 5px;
  text-transform: uppercase;
}

/* ─── Layer rows ─────────────────────────────────────────────────────────────── */
.layer-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 0; font-size: 11px; cursor: pointer;
  border-bottom: 1px solid rgba(0,255,65,0.05);
  transition: color 0.15s;
}
.layer-row:last-child { border: none; }
.layer-row:hover { color: #fff; }

.lr-left { display: flex; align-items: center; gap: 8px; }
.lr-right { display: flex; align-items: center; gap: 6px; }

.ldot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.ldot.f  { background: var(--a);  box-shadow: 0 0 6px var(--a); }
.ldot.q  { background: var(--r);  box-shadow: 0 0 6px var(--r); }
.ldot.s  { background: var(--c);  box-shadow: 0 0 6px var(--c); }
.ldot.rd { background: #44ff88;   box-shadow: 0 0 6px #44ff88; }
.ldot.cm { background: #ff88ff;   box-shadow: 0 0 6px #ff88ff; }

.cnt {
  font-size: 9px; color: var(--gd);
  border: 1px solid var(--border);
  padding: 1px 5px; min-width: 26px; text-align: center;
}

/* Toggle */
.tog {
  width: 30px; height: 15px;
  background: rgba(0,20,5,0.8);
  border: 1px solid var(--gd);
  border-radius: 8px; position: relative;
  cursor: pointer; transition: background 0.2s; flex-shrink: 0;
}
.tog.on { background: rgba(0,255,65,0.12); }
.tog::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 9px; height: 9px; background: var(--gd);
  border-radius: 50%; transition: all 0.2s;
}
.tog.on::after { transform: translateX(15px); background: var(--g); box-shadow: 0 0 5px var(--g); }

/* ─── Stat rows ──────────────────────────────────────────────────────────────── */
.stat-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; padding: 3px 0;
  border-bottom: 1px solid rgba(0,255,65,0.05);
}
.stat-row:last-child { border: none; }
.sk { color: var(--gd); display: flex; align-items: center; gap: 5px; }
.sv { color: var(--g); }
.sv-a { color: var(--a); }
.sv-r { color: var(--r); }
.sv-c { color: var(--c); }
.sv.small { font-size: 9px; max-width: 110px; text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ─── Sliders ────────────────────────────────────────────────────────────────── */
.slider-block { padding: 4px 0; }
.sl-label {
  display: flex; justify-content: space-between;
  font-size: 9px; color: var(--gd); margin-bottom: 4px; letter-spacing: 1px;
}
.sl-label span { color: var(--g); }
input[type=range] {
  -webkit-appearance: none; width: 100%; height: 3px;
  background: linear-gradient(to right, var(--g) var(--pct, 65%), rgba(0,255,65,0.1) var(--pct, 65%));
  border-radius: 2px; cursor: pointer; outline: none;
}
input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; width: 11px; height: 11px;
  background: var(--g); border-radius: 50%;
  box-shadow: 0 0 6px var(--g), 0 0 2px #fff;
  cursor: pointer;
}
input[type=range]::-moz-range-thumb {
  width: 11px; height: 11px; background: var(--g);
  border-radius: 50%; box-shadow: 0 0 6px var(--g); border: none;
}

/* ─── Status dots ────────────────────────────────────────────────────────────── */
.sdot {
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; flex-shrink: 0;
}
.sdot-on     { background: var(--g); box-shadow: 0 0 5px var(--g); animation: pulse 2.5s infinite; }
.sdot-pulse  { background: var(--a); box-shadow: 0 0 5px var(--a); animation: pulse 0.7s infinite; }
.sdot-off    { background: var(--r); }
@keyframes pulse { 50% { opacity: 0.35 } }

/* ─── Alert feed ─────────────────────────────────────────────────────────────── */
.card-flex { display: flex; flex-direction: column; }
.card-flex .card-title { flex-shrink: 0; }
#alertfeed {
  overflow-y: auto; max-height: 170px; flex: 1;
  scrollbar-width: thin; scrollbar-color: var(--gd) transparent;
}
#alertfeed::-webkit-scrollbar { width: 2px; }
#alertfeed::-webkit-scrollbar-thumb { background: var(--gd); }

.alert-item { font-size: 9px; padding: 4px 0; border-bottom: 1px solid rgba(0,255,65,0.06); line-height: 1.5; }
.alert-item:last-child { border: none; }
.alert-time { color: var(--gd); font-size: 8px; }
.alert-msg { color: var(--g); }
.alert-msg.amber { color: var(--a); }
.alert-msg.red   { color: var(--r); }
.alert-msg.cyan  { color: var(--c); }

.scroll-btn {
  width: 100%; height: 18px;
  background: rgba(0,255,65,0.04); border: 1px solid var(--border);
  color: var(--gd); font-size: 9px; cursor: pointer;
  font-family: var(--mono); letter-spacing: 2px; transition: all 0.15s;
  flex-shrink: 0;
}
.scroll-btn:hover { background: rgba(0,255,65,0.12); color: var(--g); border-color: var(--gd); }
.scroll-btn-b { margin-top: 2px; }

/* ─── Camera panel ───────────────────────────────────────────────────────────── */
#cam-panel {
  position: fixed; right: 244px; top: 54px; width: 320px; z-index: 100;
  transition: opacity 0.3s, transform 0.3s;
}
#cam-panel.hidden { opacity: 0; pointer-events: none; transform: translateX(10px); }

.cam-tabs { display: flex; gap: 3px; margin-bottom: 7px; flex-wrap: wrap; }
.ctab {
  padding: 3px 8px; border: 1px solid var(--border); background: transparent;
  color: var(--gd); font-family: var(--mono); font-size: 8px;
  cursor: pointer; transition: all 0.15s; letter-spacing: 1px;
}
.ctab:hover, .ctab.active { background: var(--g3); color: var(--g); border-color: var(--gd); }

.cam-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }

.cam-feed {
  position: relative; aspect-ratio: 4/3; background: #000;
  border: 1px solid rgba(0,255,65,0.12); overflow: hidden; cursor: pointer;
  transition: border-color 0.2s;
}
.cam-feed:hover { border-color: var(--gd); }
.cam-feed:hover .cam-overlay { opacity: 1; }

.cam-feed img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: contrast(1.08) saturate(0.65) brightness(0.88);
  transition: filter 0.3s;
}
.cam-feed:hover img { filter: contrast(1.12) saturate(0.8) brightness(1); }

.cam-rec {
  position: absolute; top: 4px; right: 4px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--r); box-shadow: 0 0 5px var(--r);
  animation: blink 1s infinite;
}
.cam-ts {
  position: absolute; top: 3px; left: 4px;
  font-size: 6px; color: rgba(0,255,65,0.65); font-family: var(--mono);
  text-shadow: 0 0 3px rgba(0,0,0,0.8);
}
.cam-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,0.85));
  font-size: 7px; padding: 6px 4px 3px; color: var(--gd);
  letter-spacing: 1px; font-family: var(--mono);
}
.cam-overlay {
  position: absolute; inset: 0; background: rgba(0,255,65,0.05);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.2s;
  font-size: 9px; color: var(--g); letter-spacing: 2px;
}

.cam-placeholder {
  grid-column: 1 / -1; height: 60px;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; color: var(--gd); letter-spacing: 2px;
  animation: blink 1s infinite;
}

.cam-status { font-size: 8px; color: var(--gd); text-align: center; margin-top: 5px; letter-spacing: 2px; }
.cam-credit { font-size: 7px; color: rgba(0,255,65,0.25); text-align: right; margin-top: 3px; }
.cam-credit a { color: rgba(0,255,65,0.35); text-decoration: none; }

.cam-error {
  grid-column: 1/-1; background: rgba(255,51,51,0.05);
  border: 1px solid rgba(255,51,51,0.2); padding: 10px;
  font-size: 9px; color: var(--r); text-align: center; letter-spacing: 1px;
}

/* ─── Bottom bar ─────────────────────────────────────────────────────────────── */
#bottombar {
  position: fixed; bottom: 0; left: 0; right: 0; height: 40px; z-index: 1000;
  background: rgba(0,6,2,0.98); border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 14px;
}
#bottombar::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--az-blue) 33.3%, var(--az-red) 33.3% 66.6%, var(--az-green) 66.6%);
}

.view-tabs { display: flex; gap: 3px; }
.vtab {
  padding: 4px 13px; border: 1px solid var(--border); background: transparent;
  color: var(--gd); font-family: var(--mono); font-size: 9px;
  letter-spacing: 2px; cursor: pointer; transition: all 0.15s;
}
.vtab:hover, .vtab.active {
  background: var(--g3); color: var(--g);
  border-color: var(--gd); box-shadow: 0 0 10px rgba(0,255,65,0.1);
}

.bottom-right { display: flex; gap: 16px; align-items: center; font-size: 9px; color: var(--gd); }

/* ─── Coord bar ──────────────────────────────────────────────────────────────── */
#coord-bar {
  position: fixed; left: 12px; bottom: 48px; z-index: 500;
  font-size: 9px; color: var(--gd); letter-spacing: 1px;
  background: rgba(0,6,2,0.85); border: 1px solid var(--border);
  padding: 3px 8px;
}

/* ─── Tooltip ────────────────────────────────────────────────────────────────── */
.tooltip {
  position: fixed; z-index: 5000; pointer-events: none; display: none;
  background: rgba(0,10,3,0.97); border: 1px solid var(--g);
  padding: 10px 14px; min-width: 170px;
  box-shadow: 0 0 24px rgba(0,255,65,0.12), inset 0 0 20px rgba(0,255,65,0.02);
}
.tooltip.show { display: block; }
.tt-title { color: var(--a); font-size: 11px; margin-bottom: 6px; letter-spacing: 1px; }
.tt-row { display: flex; justify-content: space-between; gap: 12px; font-size: 9px; padding: 2px 0; border-bottom: 1px solid rgba(0,255,65,0.07); }
.tt-row:last-child { border: none; }
.tt-k { color: var(--gd); }
.tt-v { color: var(--c); }

/* ─── Corner decorations ─────────────────────────────────────────────────────── */
body::before, body::after {
  content: ''; position: fixed; width: 28px; height: 28px; z-index: 990; pointer-events: none;
}
body::before { top: 50px; left: 10px; border-top: 1px solid var(--gd); border-left: 1px solid var(--gd); }
body::after  { bottom: 48px; right: 10px; border-bottom: 1px solid var(--gd); border-right: 1px solid var(--gd); }

/* ─── Close button ───────────────────────────────────────────────────────────── */
.close-btn {
  background: transparent; border: 1px solid var(--r); color: var(--r);
  font-size: 10px; padding: 1px 6px; cursor: pointer;
  font-family: var(--mono); transition: all 0.15s;
}
.close-btn:hover { background: rgba(255,51,51,0.1); }

/* ─── Scrollbar global ───────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gd); border-radius: 2px; }

/* ─── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 1200px) {
  #cam-panel { display: none; }
}
@media (max-width: 900px) {
  #lpanel, #rpanel { width: 180px; }
  .logo-wv { display: none; }
}
