@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;700&display=swap');

:root {
  --green: #10b981; --green-dim: #047857; 
  --red: #ef4444; --amber: #f59e0b; --cyan: #0ea5e9; 
  --bg: #080c16; 
  --panel: rgba(23, 33, 48, 0.75); 
  --border: rgba(51, 65, 85, 0.6);
  --text-main: #f8fafc; --text-muted: #94a3b8;
  --font-sans: 'Inter', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Courier New', monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100vh;overflow:hidden;background:var(--bg);color:var(--text-main);
  font-family:var(--font-sans);font-size:13px; -webkit-font-smoothing: antialiased;}

body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.05) 2px,rgba(0,0,0,.05) 4px);}

/* HEADER */
header{
  height:60px;display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;background:var(--panel);border-bottom:1px solid var(--border);
  position:relative;z-index:200;flex-shrink:0;box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}
.title{font-size:18px;font-weight:700;letter-spacing:2px;color:var(--green);
  text-shadow:0 0 16px rgba(16, 185, 129, 0.4); display:flex; align-items:center; gap:8px;}
.badge{padding:4px 12px;border:1px solid;font-size:11px;letter-spacing:1px;font-weight:600;border-radius:6px; font-family:var(--font-mono);}
.badge-green{border-color:var(--green);background:rgba(16, 185, 129, 0.1);color:var(--green);}
.badge-amber{border-color:var(--amber);background:rgba(245, 158, 11, 0.1);color:var(--amber);}
.badge-red{border-color:var(--red);background:rgba(239, 68, 68, 0.1);color:var(--red);animation:blr 1.2s infinite alternate;}
.badge-gray{border-color:var(--border);background:rgba(148, 163, 184, 0.05);color:var(--text-muted);}
@keyframes blr{from{box-shadow:0 0 4px var(--red);} to{box-shadow:0 0 16px var(--red);}}

/* MENUBAR */
#menubar{
  height:48px;display:flex;align-items:center;background:var(--bg);
  border-bottom:1px solid var(--border);position:relative;z-index:190;flex-shrink:0;
}
.mb-sep{width:1px;height:24px;background:var(--border);flex-shrink:0;margin:0 8px;}
.mb-group{display:flex;align-items:center;gap:12px;padding:0 16px;height:100%;border-right:1px solid var(--border);}
.mb-group:last-child{border-right:none;}
.mb-label{font-size:11px;letter-spacing:0.5px;color:var(--text-muted);white-space:nowrap;font-weight:600;}
.mb-slider-wrap{display:flex;align-items:center;gap:10px;}
.mb-slider{
  -webkit-appearance:none;appearance:none;width:90px;height:4px;
  background:var(--border);border-radius:2px;outline:none;cursor:pointer;
  transition: background 0.2s;
}
.mb-slider:hover { background: #475569; }
.mb-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:14px;height:14px;
  border-radius:50%;background:var(--cyan);cursor:pointer; box-shadow: 0 0 8px rgba(14, 165, 233, 0.5);
}
.mb-slider::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;border:none;background:var(--cyan);cursor:pointer; box-shadow: 0 0 8px rgba(14, 165, 233, 0.5);
}
.mb-val{font-size:12px;color:var(--cyan);min-width:36px;font-weight:600; font-family:var(--font-mono);}
.mb-btn{
  background:var(--panel);border:1px solid var(--border);border-radius:6px;
  color:var(--text-muted);font-family:var(--font-sans);
  font-size:12px;font-weight:500;padding:6px 12px;cursor:pointer;transition:all .2s;
}
.mb-btn:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(14, 165, 233, 0.05);}
.mb-btn.active{background:rgba(14, 165, 233, 0.15);border-color:var(--cyan);color:var(--cyan);font-weight:600;}
.mb-btn.alert-btn {border-color:var(--amber); color:var(--amber); font-weight:600; background:rgba(245, 158, 11, 0.1);}
.mb-btn.alert-btn:hover {background:rgba(245, 158, 11, 0.2); box-shadow:0 0 12px rgba(245, 158, 11, 0.3);}
.mb-select{
  background:var(--panel);border:1px solid var(--border);color:var(--green);
  font-family:var(--font-sans);font-size:12px;font-weight:500;
  padding:5px 10px;cursor:pointer;outline:none;border-radius:6px; transition:border-color 0.2s;
}
.mb-select:hover{border-color:var(--green);}

/* PANTALLA DIAGNÓSTICO */
#diag-overlay{position:fixed;inset:0;background:rgba(15, 23, 42, 0.95);z-index:9000;
  display:flex;align-items:center;justify-content:center;transition:opacity 0.4s; backdrop-filter: blur(8px);}
.diag-box{border:1px solid var(--green-dim);padding:40px 50px;min-width:550px;background:var(--panel);box-shadow:0 0 40px rgba(0,0,0,.6); border-radius:12px;}
.diag-box.error{border-color:var(--red);box-shadow:0 0 40px rgba(239, 68, 68, 0.2);}
.diag-title{font-size:15px;letter-spacing:2px;color:var(--cyan);font-weight:700;margin-bottom:24px;
  border-bottom:1px solid var(--border);padding-bottom:12px;}
.diag-row{display:flex;align-items:center;gap:16px;margin-bottom:16px;font-size:13px;font-family:var(--font-mono);}
.diag-label{color:var(--text-muted);flex:1;}
.diag-status{font-weight:700;min-width:240px;font-size:12px;letter-spacing:1px;}
.ds-wait{color:#64748b;}.ds-ok{color:var(--green);}.ds-err{color:var(--red);}.ds-spin{color:var(--amber);}
.diag-dot{width:14px;height:14px;border-radius:50%;background:#1e293b;border:1px solid var(--border);flex-shrink:0;}

/* LAYOUT BLINDADO */
.layout{
  display:grid;grid-template-columns:300px 1fr 340px;grid-template-rows:1fr 220px; 
  height:calc(100vh - 60px - 48px - 44px);gap:12px;padding:12px;background:var(--bg);min-height:0;
}
.panel, .map-cell, .charts-row, .chart-cell { min-height:0; }
.panel{
  background:var(--panel); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border); border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,0.4);
  padding:20px;overflow-y:auto; display:flex; flex-direction:column; gap:16px;
}
.panel::-webkit-scrollbar { width: 6px; }
.panel::-webkit-scrollbar-thumb { background: #475569; border-radius: 3px; }
.panel::-webkit-scrollbar-track { background: var(--panel); }

.panel-title{
  font-size:12px; letter-spacing:1px; color:var(--cyan); text-transform:uppercase;
  border-bottom:1px solid var(--border); padding-bottom:10px; margin-bottom:4px;font-weight:700;
}

/* CENTRO DE VISUALIZACIÓN MULTIPROPÓSITO */
.map-cell{grid-row:1; grid-column:2; position:relative; background:#000; border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:0 8px 32px rgba(0,0,0,0.4);}
#map-container { width:100%; height:100%; position:absolute; inset:0; }
#map{height:100%;width:100%;}
.leaflet-container{background:#000 !important;}
.map-hud{position:absolute;top:10px;left:10px;z-index:1000;
  background:rgba(11,17,32,.9);border:1px solid var(--border);border-radius:4px;
  padding:6px 12px;font-size:11px;letter-spacing:1px;color:var(--text-main);pointer-events:none;}

/* NUEVO: CONTENEDOR INSAR GRID 3x2 */
#insar-container { 
  display:none; position:absolute; inset:0; background:var(--bg); z-index:1500; overflow:hidden;
}
.insar-panel {
  display: flex; flex-direction: column; background: #000; border: 1px solid var(--border); 
  border-radius: 4px; overflow: hidden; position: relative;
}
.insar-label {
  background: rgba(15, 23, 42, 0.95); color: var(--cyan); font-size: 9px; font-weight: bold; 
  text-align: center; padding: 5px; letter-spacing: 2px; border-bottom: 1px solid var(--border); 
  z-index: 2; position: relative; text-transform: uppercase;
}
/* Imágenes InSAR: object-fit contain para que no se recorten y filtro de modo oscuro */
.insar-img {
  flex: 1; width: 100%; height: 100%; object-fit: contain; cursor: zoom-in;
  filter: invert(1) hue-rotate(180deg) brightness(1.2) contrast(1.5);
  transition: transform 0.3s;
}
.insar-img:hover { transform: scale(1.05); }

/* NUEVO: LIGHTBOX (VISOR A PANTALLA COMPLETA) */
#lightbox-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.95);
  z-index: 9999; align-items: center; justify-content: center; cursor: zoom-out;
  backdrop-filter: blur(5px);
}
#lightbox-img {
  max-width: 95%; max-height: 95%; border: 2px solid var(--cyan);
  box-shadow: 0 0 40px rgba(56,189,248,0.4); border-radius: 4px;
  filter: invert(1) hue-rotate(180deg) brightness(1.2) contrast(1.5);
}

/* CHARTS (6 COLUMNAS) */
.charts-row{grid-row:2;grid-column:1/4;display:grid;
  grid-template-columns:repeat(6, 1fr);gap:12px;background:transparent;}
.chart-cell{
  background:var(--panel); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border); border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,0.3);
  padding:16px;display:flex;flex-direction:column;
}
.chart-container{flex:1;position:relative;min-height:100px;width:100%;} 

/* KPIs Y TENDENCIAS */
.kpi{border:1px solid var(--border); border-radius:12px; padding:16px; background:rgba(15, 23, 42, 0.6); position:relative; overflow:hidden; transition: transform 0.2s, box-shadow 0.2s;}
.kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.kpi-label{font-size:11px; letter-spacing:1px; color:var(--text-muted); margin-bottom:8px; font-weight:600; text-transform:uppercase;}
.kpi-value{font-size:32px; font-weight:700; color:var(--green); line-height:1; font-family:var(--font-mono);}
.kpi-value.warn{color:var(--amber);}
.kpi-value.danger{color:var(--red);}
.kpi-sub{font-size:12px; color:var(--cyan); margin-top:8px; font-weight:500;}

#irv-card { border-width: 2px; }
#kpi-irv { font-size: 42px; text-shadow: 0 0 10px rgba(16,185,129,0.3); }

.trend-box { border-left: 4px solid var(--cyan); background: rgba(14, 165, 233, 0.05); padding: 12px 16px; border-radius:0 8px 8px 0;}
.trend-box.danger { border-left-color: var(--red); background: rgba(239, 68, 68, 0.05); }
.trend-box.warn { border-left-color: var(--amber); background: rgba(245, 158, 11, 0.05); }
.trend-box.safe { border-left-color: var(--green); background: rgba(16, 185, 129, 0.05); }
.trend-title { font-size:10px; color:var(--text-muted); letter-spacing:1px; margin-bottom:6px; font-weight:600; text-transform:uppercase;}
.trend-val { font-size:14px; font-weight:700; color:var(--text-main); }
.trend-meta { font-size:10px; color:#64748b; margin-top:6px; text-transform:uppercase; font-family:var(--font-mono);}

/* EVENT FEED */
.event-item{border-left:4px solid var(--green-dim); padding:12px; border-radius:4px 8px 8px 4px;
  margin-bottom:8px; background:rgba(15, 23, 42, 0.6); font-size:12px; line-height:1.6;
  cursor:pointer; transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1); border-top:1px solid transparent; border-right:1px solid transparent; border-bottom:1px solid transparent;}
.event-item:hover { background: rgba(30, 41, 59, 0.9); border-color:var(--border); border-left-color:var(--green); transform:translateX(4px); box-shadow: 0 4px 12px rgba(0,0,0,0.2);}
.event-item.ev-red{border-left-color:var(--red); background:rgba(239, 68, 68, 0.05);}
.ev-mag{float:right;font-size:18px;font-weight:700;line-height:1;font-family:var(--font-mono);}
.ev-mag.c-green{color:var(--green);}
.ev-mag.c-amber{color:var(--amber);}
.ev-mag.c-red{color:var(--red);}
.ev-time{color:var(--text-main);font-weight:600;font-family:var(--font-mono);font-size:11px;}
.ev-place{color:var(--text-muted);margin:4px 0;font-size:13px;}
.ev-meta{font-size:11px; color:#64748b;}

/* FOOTER */
footer{height:44px;background:var(--panel);border-top:1px solid var(--border);
  display:flex;align-items:center;overflow:hidden;flex-shrink:0;}
.ticker-tag{padding:0 20px;background:var(--cyan);color:#0f172a;font-size:12px;
  letter-spacing:1px;font-weight:700;height:100%;display:flex;
  align-items:center;white-space:nowrap;flex-shrink:0;z-index:10;}
.ticker-scroll{white-space:nowrap;animation:ticker 60s linear infinite;
  font-size:13px;color:var(--text-main);padding-left:30px; display:inline-block; font-family:var(--font-mono);}
@keyframes ticker{from{transform:translateX(100vw)}to{transform:translateX(-100%)}}

/* EVENT DRAWER */
.drawer {
  position: fixed; top: 0; right: -450px; width: 450px; height: 100vh;
  background: rgba(11, 18, 33, 0.95); backdrop-filter: blur(20px);
  border-left: 1px solid var(--border); z-index: 10000;
  transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex; flex-direction: column;
  box-shadow: -10px 0 30px rgba(0,0,0,0.5);
}
.drawer.open { right: 0; }
.drawer-header {
  padding: 24px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.drawer-title { font-size: 14px; font-weight: 700; letter-spacing: 1px; color: var(--cyan); }
.drawer-close { background: transparent; border: none; color: var(--text-muted); cursor: pointer; transition: color 0.2s; }
.drawer-close:hover { color: var(--red); }
.drawer-content { flex: 1; overflow-y: auto; padding: 24px; }
.drawer-section { margin-bottom: 30px; }
.drawer-sec-title { font-size: 11px; font-weight: 700; color: var(--text-muted); margin-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,0.05); padding-bottom: 4px; }
.drawer-data-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.data-item { display: flex; flex-direction: column; gap: 4px; }
.data-label { font-size: 10px; color: #64748b; text-transform: uppercase; }
.data-val { font-size: 13px; font-weight: 600; color: var(--text-main); font-family: var(--font-mono); }
