@tailwind base;@tailwind components;@tailwind utilities;@layer base{:root{--navy-900:#0f2557;--navy-800:#1e3a8a;--navy-700:#2544a3;--navy-50:#eef2fb;--blue-600:#2563eb;--blue-500:#3b82f6;--blue-100:#dbeafe;--orange-500:#f59e0b;--orange-400:#fbbf24;--orange-50:#fff7ed;--green-600:#059669;--green-500:#10b981;--green-50:#d1fae5;--red-600:#dc2626;--red-50:#fef2f2;--yellow-500:#f59e0b;--yellow-50:#fef3c7;--slate-950:#0b1220;--slate-900:#0f172a;--slate-800:#1e293b;--slate-700:#334155;--slate-600:#475569;--slate-500:#64748b;--slate-400:#94a3b8;--slate-300:#cbd5e1;--slate-200:#e2e8f0;--slate-100:#f1f5f9;--slate-50:#f8fafc;--bg-app:#f5f7fa;--card:#fff;--border:#0f172a14;--border-strong:#cfd5e0;--shadow-card:0 1px 2px #0f172a0a, 0 1px 0 #0f172a05 inset;--shadow-pop:0 12px 32px -8px #0f172a2e, 0 4px 12px #0f172a14;--radius-sm:4px;--radius:8px;--radius-lg:14px;--wo-accent:#0ea5a4;--wo-accent-strong:#0e7490;--wo-accent-soft:#cffafe;--sidebar-width:240px;--sidebar-bg:#0b1220;--sidebar-border:#ffffff0f;--sidebar-text:#94a3b8;--sidebar-active:#fff;--sidebar-accent:var(--wo-accent)}body{background-color:var(--bg-app);color:var(--slate-900);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.45}code,.mono,.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}:root{--wo-mono:"JetBrains Mono", ui-monospace, monospace}}@layer components{.washops-app{background:var(--bg-app);height:100vh;display:flex;overflow:hidden}.washops-sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:10px;padding:20px 16px 16px;display:flex}.sidebar-logo-text{color:#fff;letter-spacing:-.01em;font-size:16px;font-weight:700}.sidebar-logo-sub{color:var(--sidebar-text);letter-spacing:.04em;margin-top:1px;font-size:10px}.sidebar-nav{flex:1;padding:8px 0}.sidebar-section{letter-spacing:.12em;text-transform:uppercase;color:#4a5568;padding:10px 12px 4px;font-size:9.5px;font-weight:600}.sidebar-item{color:var(--sidebar-text);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;margin:1px 8px;padding:8px 12px;font-size:13px;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.sidebar-item:hover{color:#cbd5e1;background:#ffffff0f}.sidebar-item.active{color:var(--sidebar-active);background:#ffffff14}.sidebar-item.active:before{content:"";background:var(--wo-accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:-8px;transform:translateY(-50%)}.sidebar-item .icon{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar-item.active .icon{opacity:1}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px 16px}.system-status-badge{color:var(--slate-400);align-items:center;gap:8px;font-size:11px;font-weight:500;display:flex}.system-status-badge .dot{background:var(--wo-accent);border-radius:50%;width:7px;height:7px;animation:2s infinite pulse-green}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}.washops-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.washops-topbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex}.topbar-title{color:var(--slate-900);font-size:16px;font-weight:600}.topbar-subtitle{color:var(--slate-500);margin-top:1px;font-size:12px}.topbar-actions{align-items:center;gap:10px;display:flex}.washops-content{flex:1;padding:24px;overflow:auto}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.kpi-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);background:#fff;padding:16px 20px}.kpi-label{letter-spacing:.1em;text-transform:uppercase;color:var(--slate-500);margin-bottom:6px;font-size:10.5px;font-weight:600}.kpi-value{font-size:30px;font-weight:600;font-family:var(--wo-mono);color:var(--slate-900);letter-spacing:-.02em;line-height:1}.kpi-value.green{color:var(--green-600)}.kpi-value.red{color:var(--red-600)}.kpi-value.blue{color:var(--blue-600)}.kpi-unit{color:var(--slate-500);margin-left:3px;font-size:13px;font-weight:400}.kpi-sub{color:var(--slate-500);margin-top:4px;font-size:12px}.stress-gauge-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);background:#fff;flex-direction:column;align-items:center;gap:12px;padding:20px;display:flex}.stress-level-label{letter-spacing:.16em;text-transform:uppercase;border-radius:10px;padding:3px 10px;font-size:11px;font-weight:700}.stress-level-label.low{background:var(--green-50);color:var(--green-600)}.stress-level-label.medium{background:var(--yellow-50);color:#92400e}.stress-level-label.high{background:var(--red-50);color:var(--red-600)}.spain-map-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);background:#fff;overflow:hidden}.spain-map-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.spain-map-legend{color:var(--slate-500);align-items:center;gap:12px;font-size:11px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.legend-dot.healthy{background:var(--green-500)}.legend-dot.warning{background:var(--yellow-500)}.legend-dot.incident{background:var(--red-600)}.station-table{border-collapse:collapse;width:100%;font-size:13px}.station-table thead th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-500);border-bottom:1px solid var(--border);background:var(--slate-50);padding:10px 16px;font-size:10.5px;font-weight:600}.station-table tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.station-table tbody tr:hover{background:var(--slate-50)}.station-table td{vertical-align:middle;padding:11px 16px}.status-pill{white-space:nowrap;border:1px solid;border-radius:10px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-pill .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.status-pill.online{color:var(--green-600);background:var(--green-50);border-color:#bbf7d0}.status-pill.degraded{color:#d97706;background:#fffbeb;border-color:#fde68a}.status-pill.offline{color:var(--red-600);background:var(--red-50);border-color:#fecaca}.status-pill.unknown{color:var(--slate-500);background:var(--slate-100);border-color:var(--slate-300)}.status-pill.calculating{color:var(--blue-600);background:var(--blue-100);border-color:#bfdbfe}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-primary{background:var(--wo-accent);color:#fff;border-color:var(--wo-accent)}.btn-primary:hover{background:var(--wo-accent-strong);border-color:var(--wo-accent-strong)}.btn-secondary{color:var(--slate-700);border-color:var(--border-strong);background:#fff}.btn-secondary:hover{background:var(--slate-50)}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:4px 9px;font-size:11px}.channel-bar-grid{flex-direction:column;gap:10px;display:flex}.channel-bar-row{grid-template-columns:120px 1fr 60px;align-items:center;gap:10px;font-size:13px;display:grid}.channel-bar-label{color:var(--slate-700);font-weight:500}.channel-bar-track{background:var(--slate-100);border-radius:5px;height:10px;overflow:hidden}.channel-bar-fill{border-radius:5px;height:100%;transition:width .4s}.channel-bar-fill.waylet{background:var(--blue-500)}.channel-bar-fill.suscripcion{background:#8b5cf6}.channel-bar-fill.camara{background:var(--green-500)}.channel-bar-fill.analogico{background:var(--slate-400)}.channel-bar-pct{color:var(--slate-600);text-align:right;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500}.ri-seg-strong{color:#1a1a1a;font-weight:600}.ri-seg-metric{color:#004dff;font-family:JetBrains Mono,monospace;font-size:.95em;font-weight:600}.ri-seg-highlight{color:#3730a3;background:#eef2ff;border-radius:3px;padding:0 3px;font-weight:500}.ri-seg-warning{color:#b45309;font-weight:500}.ri-seg-hypothesis{color:#6366f1;font-style:italic}.ri-seg-muted{color:#9ca3af}.ri-seg-positive{color:#059669;font-weight:500}.ri-seg-weak-sample{color:#b45309;font-size:.88em}.ri-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:4px;align-items:center;padding:1px 6px;font-size:9px;font-weight:700;display:inline-flex}.ri-badge--hypothesis{color:#5b21b6;background:#ede9fe}.ri-badge--weak,.ri-badge--caveat{color:#92400e;background:#fef3c7}.ri-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-top:2px}.ri-list{flex-direction:column;gap:10px;display:flex}.ri-insight{flex-direction:column;gap:3px;display:flex}.ri-title-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.ri-title{text-transform:uppercase;letter-spacing:.12em;color:#737373;font-size:10px;font-weight:700}.ri-body{color:#404040;margin:0;font-size:13px;line-height:1.55}.ri-caveat{color:#9ca3af;margin:0;font-size:11px;font-style:italic}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--slate-300);border:2px solid var(--bg-app);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--slate-400)}.data-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:5px;flex-shrink:0;align-items:center;padding:2px 6px;font-size:9px;font-weight:700;line-height:1.7;display:inline-flex}.data-badge.otea{color:#1d4ed8;background:#dbeafe}.data-badge.derivado{color:#166534;background:#dcfce7}.data-badge.demo{color:#b45309;background:#fef3c7}.demo-inline-notice{color:var(--slate-400);margin-top:5px;font-size:10.5px;font-style:italic}.dashboard-flex{align-items:flex-start;gap:16px;display:flex}.dashboard-center-col{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.dashboard-map-col{flex-direction:column;flex-shrink:0;width:390px;display:flex}.topbar-date-chip{background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius);color:var(--slate-700);align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:flex}.topbar-refresh-chip{color:var(--slate-500);align-items:center;gap:5px;font-size:12px;display:flex}.refresh-dot{background:var(--green-500);border-radius:50%;width:7px;height:7px}.map-footer{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px;padding:10px 14px;font-size:12px;display:flex}.map-stat{align-items:center;gap:5px;display:flex}.map-stat strong{font-size:14px;font-weight:700}.map-stat.healthy strong{color:var(--green-600)}.map-stat.warning strong{color:#d97706}.map-stat.incident strong{color:var(--red-600)}}
