/* ═══════════════════════════════════════════════
   CORE — INTELLIGENCE DASHBOARD
   ═══════════════════════════════════════════════ */

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

:root {
  --g:    #00ff41;
  --gd:   #007a1f;
  --gg:   #001a00;
  --gb:   #003300;
  --cy:   #00e5ff;
  --rd:   #ff2222;
  --rdd:  #330000;
  --yw:   #ffcc00;
  --wh:   #d8d8d8;
  --bg:   #040404;
  --sbg:  #020802;
  --pbg:  #030903;
  --font: 'Courier New', 'Lucida Console', monospace;
}

html, body {
  height: 100%;
  overflow: hidden;
  background: var(--bg);
  color: var(--g);
  font-family: var(--font);
  font-size: 12px;
  line-height: 1.5;
}

.scanlines {
  position: fixed; inset: 0; pointer-events: none; z-index: 9999;
  background: repeating-linear-gradient(
    0deg, transparent 0, transparent 3px,
    rgba(0,0,0,0.055) 3px, rgba(0,0,0,0.055) 4px
  );
}

/* ─── APP SHELL ─── */
#app {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

/* ─── TOP BAR ─── */
#top-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 12px;
  background: var(--rd);
  flex-shrink: 0;
  min-height: 26px;
}

.tb-class {
  color: #000;
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1.5px;
}

.tb-right {
  display: flex;
  align-items: center;
  gap: 6px;
  color: rgba(0,0,0,0.7);
  font-size: 10px;
}
#clock { color: #000; font-weight: bold; letter-spacing: 2px; }
.tb-utc { font-size: 9px; }
.tb-sep { opacity: 0.4; }
.tb-ses { letter-spacing: 1px; }

/* ─── WORKSPACE ─── */
#workspace {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

/* ════════════════════════════════
   SIDEBAR
════════════════════════════════ */
#sidebar {
  width: 220px;
  flex-shrink: 0;
  background: var(--sbg);
  border-right: 1px solid var(--gg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Brand */
.sb-brand {
  padding: 16px 14px 12px;
  border-bottom: 1px solid var(--gg);
  flex-shrink: 0;
}
.sb-logo {
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 12px;
  color: var(--g);
  text-shadow: 0 0 14px var(--g), 0 0 28px rgba(0,255,65,0.2);
  line-height: 1;
  margin-bottom: 5px;
}
.sb-tagline {
  font-size: 8.5px;
  color: var(--gd);
  letter-spacing: 1.5px;
  line-height: 1.4;
}

/* Divider */
.sb-divider {
  height: 1px;
  background: var(--gg);
  flex-shrink: 0;
  margin: 0;
}

/* Nav */
.sb-nav {
  padding: 8px 0;
  flex-shrink: 0;
}
.sb-nav-label {
  font-size: 8.5px;
  color: #1a3a1a;
  letter-spacing: 2px;
  padding: 0 14px 5px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  font-size: 11px;
  color: var(--gd);
  cursor: pointer;
  letter-spacing: 1px;
  transition: background 0.1s;
  border-left: 2px solid transparent;
  text-decoration: none;
}
.nav-item:hover {
  background: rgba(0, 255, 65, 0.04);
  color: var(--g);
}
.nav-item.active {
  background: rgba(0, 255, 65, 0.07);
  color: var(--g);
  border-left-color: var(--g);
}
.nav-item.active .nav-icon { color: var(--g); }

.nav-icon {
  font-size: 8px;
  color: var(--gg);
  width: 10px;
  text-align: center;
  flex-shrink: 0;
}
.nav-item.active .nav-icon { content: '▶'; }

.nav-badge {
  margin-left: auto;
  background: var(--gg);
  color: var(--gd);
  font-size: 9px;
  padding: 1px 5px;
  letter-spacing: 0.5px;
}
.badge-red  { background: var(--rdd) !important; color: var(--rd) !important; }

/* Stats section */
.sb-section { padding: 8px 14px; flex-shrink: 0; }
.sb-section-label {
  font-size: 8.5px;
  color: #1a3a1a;
  letter-spacing: 2px;
  margin-bottom: 6px;
}
.sb-stat {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 10px;
  color: var(--gd);
  padding: 2px 0;
}
.dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.dot-green  { background: var(--g);  box-shadow: 0 0 4px var(--g); }
.dot-red    { background: var(--rd); box-shadow: 0 0 4px var(--rd); }
.dot-yellow { background: var(--yw); box-shadow: 0 0 4px var(--yw); }

.sb-val { margin-left: auto; color: var(--g); font-size: 10px; }
.val-red    { color: var(--rd) !important; }
.val-yellow { color: var(--yw) !important; }

/* System status */
.sb-sys-row {
  font-size: 9.5px;
  padding: 2px 0;
  color: var(--gd);
  letter-spacing: 0.5px;
}
.sb-sys-row.ok { color: var(--gd); }
.sb-sys-row.ok:hover { color: var(--g); }

/* Bottom */
.sb-bottom {
  margin-top: auto;
  padding: 10px 14px;
  border-top: 1px solid var(--gg);
  flex-shrink: 0;
}
.sb-session {
  font-size: 9px;
  color: #1a3a1a;
  letter-spacing: 2px;
  margin-bottom: 3px;
}
.sb-ses-id { color: var(--gd); }
.sb-clock {
  font-size: 14px;
  color: var(--g);
  text-shadow: 0 0 8px var(--g);
  letter-spacing: 2px;
}

/* ════════════════════════════════
   MAIN
════════════════════════════════ */
#main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
  min-width: 0;
}

/* ── View area ── */
#view-area {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.view {
  display: none;
  flex: 1;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}
.view.active { display: flex; }

/* View header */
.view-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 14px;
  background: var(--sbg);
  border-bottom: 1px solid var(--gg);
  flex-shrink: 0;
}
.vh-title {
  font-size: 11px;
  color: var(--gd);
  letter-spacing: 1px;
}
.vh-sub { font-size: 9px; color: #1a3a1a; }

/* ─── STAT CARDS ─── */
#stat-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--gg);
  flex-shrink: 0;
}

.sc {
  background: var(--pbg);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-bottom: 2px solid transparent;
}
.sc-green { border-bottom-color: var(--g);  }
.sc-red   { border-bottom-color: var(--rd); }
.sc-cyan  { border-bottom-color: var(--cy); }

.sc-val {
  font-size: 28px;
  font-weight: bold;
  line-height: 1;
}
.sc-green .sc-val { color: var(--g);  text-shadow: 0 0 10px var(--g); }
.sc-red   .sc-val { color: var(--rd); text-shadow: 0 0 10px var(--rd); }
.sc-cyan  .sc-val { color: var(--cy); text-shadow: 0 0 10px var(--cy); }

.sc-lbl { font-size: 9px; color: var(--gd); letter-spacing: 1.5px; }
.sc-sub { font-size: 9px; color: #1a3a1a; }

/* ─── INICIO PANELS ─── */
#inicio-panels {
  display: flex;
  gap: 1px;
  background: var(--gg);
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

/* Generic panel */
.panel {
  background: var(--pbg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}

#map-panel        { flex: 1.5; }
#side-alerts-panel { flex: 1; }

.panel-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 10px;
  background: var(--sbg);
  border-bottom: 1px solid var(--gg);
  font-size: 9.5px;
  color: var(--gd);
  letter-spacing: 1px;
  flex-shrink: 0;
}
.pt-badge {
  font-size: 8px;
  padding: 1px 5px;
  background: var(--gg);
  color: var(--g);
}
.pt-badge.badge-red { background: var(--rdd); color: var(--rd); }

.panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 5px 8px;
  min-height: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--gg) transparent;
}
.panel-body::-webkit-scrollbar { width: 3px; }
.panel-body::-webkit-scrollbar-thumb { background: var(--gg); }

/* ─── MAP ─── */
#map-body {
  display: flex;
  flex-direction: column;
  padding: 4px 6px;
  gap: 4px;
  overflow: hidden;
}
#map-display {
  flex: 1;
  font-size: 9.5px;
  line-height: 1.25;
  white-space: pre;
  overflow: hidden;
  font-family: var(--font);
}
.mc-ag  { color: var(--g);  text-shadow: 0 0 5px var(--g); }
.mc-co  { color: var(--rd); text-shadow: 0 0 5px var(--rd); }
.mc-ob  { color: var(--rd); }
.mc-hq  { color: var(--cy); text-shadow: 0 0 5px var(--cy); }
.mc-bg  { color: #002200; }
.mc-br  { color: #003800; }
.mc-cm  { color: var(--gd); }

#map-legend {
  display: flex;
  gap: 12px;
  font-size: 8.5px;
  color: var(--gd);
  border-top: 1px solid var(--gg);
  padding-top: 3px;
  flex-wrap: wrap;
}

/* ─── SIDE ALERTS ─── */
.sa-item {
  padding: 6px 0;
  border-bottom: 1px solid #080808;
}
.sa-head { display: flex; gap: 5px; align-items: center; margin-bottom: 2px; }
.sa-badge {
  font-size: 7.5px;
  font-weight: bold;
  padding: 1px 4px;
  letter-spacing: 1px;
}
.al-critico { background: var(--rd); color: #000; animation: bfast 1.2s step-end infinite; }
.al-alto    { background: #3a1800; color: var(--yw); }
.al-medio   { background: #001e2e; color: var(--cy); }
.sa-id   { font-size: 8.5px; color: #2a2a2a; }
.sa-hora { font-size: 8.5px; color: #1a1a1a; margin-left: auto; }
.sa-msg  { font-size: 9.5px; color: var(--wh); line-height: 1.3; }
.sa-src  { font-size: 8px; color: var(--gd); margin-top: 1px; }

/* ─── TABLE VIEWS ─── */
.table-view {
  flex: 1;
  overflow-y: auto;
  padding: 10px 14px;
  scrollbar-width: thin;
  scrollbar-color: var(--gg) transparent;
}
.table-view::-webkit-scrollbar { width: 4px; }
.table-view::-webkit-scrollbar-thumb { background: var(--gg); }

.tv-region-label {
  font-size: 9px;
  color: var(--cy);
  letter-spacing: 2px;
  padding: 8px 10px 6px;
  border-bottom: 1px solid var(--gg);
  margin-bottom: 0;
  background: #001020;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}
.data-table th {
  text-align: left;
  padding: 6px 10px;
  color: var(--gd);
  font-size: 9px;
  letter-spacing: 1.5px;
  border-bottom: 1px solid var(--gb);
  background: var(--sbg);
  font-weight: normal;
}
.data-table td {
  padding: 7px 10px;
  border-bottom: 1px solid #080808;
  color: var(--g);
  font-size: 11px;
  vertical-align: middle;
}
.data-table tr:hover td { background: rgba(0,255,65,0.03); }

.td-id     { color: var(--gd); font-size: 10px; }
.td-name   { color: var(--wh); }
.td-alias  { color: var(--g); font-weight: bold; }
.td-status { display: inline-block; padding: 1px 6px; font-size: 9px; letter-spacing: 1px; }
.st-activo      { background: #001a00; color: var(--g); border: 1px solid var(--gd); }
.st-inactivo    { background: #111; color: #444; border: 1px solid #333; }
.st-comprometido{ background: var(--rdd); color: var(--rd); border: 1px solid var(--rd); animation: bfast 1s step-end infinite; }
.st-kia         { background: #0a0a0a; color: #333; border: 1px solid #2a2a2a; }
.st-activa      { background: #001a00; color: var(--g); border: 1px solid var(--gd); }
.st-cerrada     { background: #111; color: #444; border: 1px solid #333; }
.st-pendiente   { background: #1a1400; color: var(--yw); border: 1px solid #443300; }
.td-class-ts    { color: var(--rd); font-size: 9px; }
.td-class-s     { color: var(--yw); font-size: 9px; }
.td-class-c     { color: var(--gd); font-size: 9px; }
.td-threat-crit { color: var(--rd); }
.td-threat-high { color: var(--yw); }

/* Alert detail rows */
.al-detail-row {
  padding: 10px 0;
  border-bottom: 1px solid #080808;
}
.al-detail-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 5px;
}
.al-d-badge {
  font-size: 8.5px;
  font-weight: bold;
  padding: 2px 6px;
  letter-spacing: 1.5px;
  flex-shrink: 0;
}
.al-d-id   { color: var(--gd); font-size: 10px; }
.al-d-hora { color: #333; font-size: 10px; margin-left: auto; }
.al-d-msg  { font-size: 11px; color: var(--wh); padding-left: 4px; line-height: 1.4; }
.al-d-meta { font-size: 9px; color: var(--gd); padding-left: 4px; margin-top: 3px; }

/* ════════════════════════════════
   LOGIN OVERLAY
════════════════════════════════ */
#login-overlay {
  position: fixed;
  inset: 0;
  background: #000;
  z-index: 50000;
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: var(--font);
}
#login-overlay.hidden { display: none; }

.lo-topbar {
  width: 100%;
  background: var(--rd);
  color: #000;
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1.5px;
  text-align: center;
  padding: 4px;
  flex-shrink: 0;
  animation: classpulse 3s ease-in-out infinite;
}

.lo-center {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 20px;
}

.lo-logo {
  font-size: 56px;
  font-weight: bold;
  letter-spacing: 20px;
  color: var(--g);
  text-shadow: 0 0 20px var(--g), 0 0 40px rgba(0,255,65,0.3);
  margin-bottom: 6px;
}
.lo-sub  { font-size: 11px; color: var(--gd); letter-spacing: 3px; margin-bottom: 3px; }
.lo-sub2 { font-size: 10px; color: #1a3a1a;  letter-spacing: 2px; }

.lo-divider {
  width: 400px;
  max-width: 90vw;
  height: 1px;
  background: var(--gg);
  margin: 24px 0;
}

.lo-field {
  width: 400px;
  max-width: 90vw;
  margin-bottom: 14px;
}
.lo-label {
  display: block;
  font-size: 9px;
  color: var(--gd);
  letter-spacing: 2px;
  margin-bottom: 5px;
}
.lo-input {
  width: 100%;
  background: #030903;
  border: 1px solid var(--gg);
  color: var(--g);
  font-family: var(--font);
  font-size: 13px;
  padding: 9px 12px;
  outline: none;
  letter-spacing: 1px;
  transition: border-color 0.15s;
}
.lo-input::placeholder { color: #1a3a1a; }
.lo-input:focus { border-color: var(--gd); box-shadow: 0 0 8px rgba(0,255,65,0.1); }

.lo-error {
  width: 400px;
  max-width: 90vw;
  min-height: 18px;
  font-size: 10px;
  color: var(--rd);
  letter-spacing: 1px;
  margin-bottom: 10px;
}

.lo-btn {
  width: 400px;
  max-width: 90vw;
  background: transparent;
  border: 1px solid var(--g);
  color: var(--g);
  font-family: var(--font);
  font-size: 12px;
  letter-spacing: 3px;
  padding: 11px;
  cursor: pointer;
  text-shadow: 0 0 6px var(--g);
  transition: background 0.15s, box-shadow 0.15s;
  margin-bottom: 20px;
}
.lo-btn:hover  { background: rgba(0,255,65,0.07); box-shadow: 0 0 12px rgba(0,255,65,0.15); }
.lo-btn:active { background: rgba(0,255,65,0.14); }
.lo-btn:disabled { border-color: var(--gd); color: var(--gd); cursor: not-allowed; text-shadow: none; }

.lo-warn {
  width: 400px;
  max-width: 90vw;
  text-align: center;
  font-size: 9px;
  color: #1a3a1a;
  letter-spacing: 1px;
  line-height: 1.8;
}

.lo-footer {
  padding: 8px;
  font-size: 9px;
  color: #111;
  letter-spacing: 1px;
  flex-shrink: 0;
}

/* ─── LOGOUT BUTTON ─── */
.logout-btn {
  width: 100%;
  background: transparent;
  border: 1px solid #1a0000;
  color: #331111;
  font-family: var(--font);
  font-size: 9px;
  letter-spacing: 1.5px;
  padding: 5px;
  cursor: pointer;
  margin-top: 8px;
  transition: border-color 0.15s, color 0.15s;
}
.logout-btn:hover { border-color: var(--rd); color: var(--rd); }

.sb-user-email {
  font-size: 9px;
  color: #1a3a1a;
  letter-spacing: 0.5px;
  word-break: break-all;
  margin-bottom: 4px;
}

/* ─── ANIMATIONS ─── */
@keyframes bfast { 0%,100%{opacity:1} 50%{opacity:0} }
.blink-anim { animation: bfast 1s step-end infinite; }

/* ─── MISC ─── */
::selection { background: var(--g); color: var(--bg); }
