@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--primary:#0052ff;--primary-active:#003ecc;--primary-disabled:#a8b8cc;--accent-yellow:#f4b000;--canvas:#fff;--surface-soft:#f7f7f7;--surface-strong:#eef0f3;--surface-dark:#0a0b0d;--surface-dark-elevated:#16181c;--hairline:#dee1e6;--hairline-soft:#eef0f3;--ink:#0a0b0d;--body:#5b616e;--body-strong:#0a0b0d;--muted:#7c828a;--muted-soft:#a8acb3;--on-primary:#fff;--on-dark:#fff;--on-dark-soft:#a8acb3;--semantic-up:#05b169;--semantic-down:#cf202f;--bg-dark:var(--surface-soft);--bg-panel:var(--canvas);--danger:var(--semantic-down);--warning:var(--accent-yellow);--success:var(--semantic-up);--text-main:var(--ink);--text-muted:var(--body);--glass-border:1px solid var(--hairline);--glass-shadow:0 4px 12px #0000000a;--neon-glow:none;--font-main:"Inter", -apple-system, system-ui, sans-serif;--font-mono:"Inter", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background-color:var(--surface-soft);color:var(--text-main);font-family:var(--font-main);overflow:hidden}h1,h2,h3{letter-spacing:-1px;color:var(--ink);margin-bottom:.5rem;font-weight:400}.text-primary{color:var(--primary)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-success{color:var(--success)}.app-container{grid-template-columns:260px 1fr;height:100vh;display:grid}.sidebar{background:var(--canvas);border-right:var(--glass-border);flex-direction:column;gap:2rem;padding:1.5rem;display:flex}.logo-area{color:var(--primary);align-items:center;gap:12px;display:flex}.logo-icon{font-size:1.8rem}.logo-text{flex-direction:column;display:flex}.logo-title{font-size:1.2rem;font-weight:700;line-height:1.1}.logo-subtitle{color:var(--text-muted);font-size:.7rem;line-height:1.1}.nav-menu{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-item{cursor:pointer;color:var(--text-muted);border-left:3px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.nav-item:hover,.nav-item.active{color:var(--primary);border-left-color:var(--primary);background:#0056b30d}.main-content{flex-direction:column;flex:1;gap:1.5rem;height:100vh;min-height:0;padding:1.5rem;display:flex;position:relative;overflow:hidden}.full-height{height:100%}.flex-center{justify-content:center;align-items:center;display:flex}.w-full{width:100%}.h-full{height:100%}.mt-1{margin-top:1rem}.flex-grid{flex:1;gap:1.5rem;min-height:0;display:grid}.glass-panel{background:var(--canvas);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:24px;flex-direction:column;padding:2rem;transition:transform .3s,box-shadow .3s;display:flex}.glass-panel:hover{box-shadow:0 10px 30px #0000001a}.chart-wrapper{flex:1;width:100%;min-height:0;position:relative}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.panel-header h3{margin-bottom:0}.filter-select{background:var(--surface-strong);border:1px solid var(--hairline);color:var(--ink);font-size:.85rem;font-family:var(--font-main);cursor:pointer;border-radius:100px;outline:none;padding:8px 16px}.filter-select:focus{border-color:var(--primary)}.top-bar{justify-content:space-between;align-items:center;width:100%;margin-bottom:1rem;display:flex}.breadcrumbs{color:var(--text-muted);align-items:center;font-size:.9rem;font-weight:500;display:flex}.current-time{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);background:var(--surface-strong);border:none;border-radius:100px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;display:flex}.dashboard-grid{grid-template-rows:auto 1fr;grid-template-columns:repeat(4,1fr)}.alert-ticker-container{background:#dc35450d;border:1px solid #dc35451a;border-radius:8px;grid-column:1/-1;align-items:center;height:40px;padding:0 1rem;display:flex;overflow:hidden}.ticker-label{background:var(--danger);color:#fff;white-space:nowrap;border-radius:4px;margin-right:1rem;padding:2px 8px;font-size:.8rem;font-weight:700;animation:2s infinite pulse}.ticker-content{white-space:nowrap;color:var(--text-main);font-size:.9rem;animation:20s linear infinite ticker-slide}.sensor-table{border-collapse:separate;border-spacing:0 4px;width:100%;margin-top:1rem;font-size:.9rem}.sensor-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:12px 16px;font-size:.85rem;font-weight:600}.sensor-table td{background:#fff6;border-top:1px solid #ffffff80;border-bottom:1px solid #ffffff80;padding:12px 16px;transition:all .2s}.sensor-table td:first-child{border-left:1px solid #ffffff80;border-top-left-radius:8px;border-bottom-left-radius:8px}.sensor-table td:last-child{border-right:1px solid #ffffff80;border-top-right-radius:8px;border-bottom-right-radius:8px}.sensor-table tr:hover td{color:var(--primary);background:#fff;transform:scale(1.01);box-shadow:0 4px 12px #0000000d}.status-badge{border-radius:20px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.status-ok{color:var(--success);background:#05b1691a;border:1px solid #05b16933}.status-warn{color:var(--warning);background:#f4b0001a;border:1px solid #f4b00033}.status-err{color:var(--danger);background:#cf202f1a;border:1px solid #cf202f33;animation:2s infinite pulse-red}.id-badge{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text-main);background:#0000000a;border:1px solid #0000000d;border-radius:4px;padding:2px 6px;font-size:.8rem}.kpi-card{background:var(--canvas);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:24px;flex-direction:column;flex:1;justify-content:space-between;padding:2rem;transition:transform .2s;display:flex}.kpi-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.kpi-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem}.kpi-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);letter-spacing:-.02em;font-size:1.6rem;font-weight:500}.kpi-footer{color:var(--text-muted);align-items:center;gap:4px;margin-top:.5rem;font-size:.75rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;opacity:0;visibility:hidden;background:#0006;justify-content:center;align-items:center;transition:all .3s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{width:90%;max-width:500px;transition:all .3s;transform:translateY(20px)}.modal-overlay.active .modal-content{transform:translateY(0)}.modal-header{border-bottom:var(--glass-border);align-items:center;gap:15px;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.modal-header h3{color:var(--primary);margin:0;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--danger)}.modal-body{flex-direction:column;gap:1rem;display:flex}.info-row{border-bottom:1px solid #00000008;justify-content:space-between;padding:8px 0;display:flex}.info-label{color:var(--text-muted);font-size:.9rem;font-weight:600}.info-value{color:var(--text-main);font-weight:700}.info-description{color:var(--text-muted);margin-top:1rem;font-size:.95rem;line-height:1.6}.modal-footer{justify-content:flex-end;margin-top:2rem;display:flex}.btn-primary{background:var(--primary);color:var(--on-primary);cursor:pointer;font-size:16px;font-weight:600;font-family:var(--font-main);border:none;border-radius:100px;padding:12px 20px;transition:background .3s}.btn-primary:hover{background:var(--primary-active)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}@keyframes ticker-slide{0%{transform:translate(100%)}to{transform:translate(-100%)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes pulse-red{0%{box-shadow:0 0 #cf202f66}70%{box-shadow:0 0 0 6px #cf202f00}to{box-shadow:0 0 #cf202f00}}.ov-container{flex-direction:column;gap:1rem;height:100%;display:flex;overflow:hidden}.ov-grid{flex:1;grid-template-columns:350px 1fr 320px;gap:.8rem;min-height:0;padding-bottom:.5rem;display:grid}.ov-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.ov-card-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffc;border-bottom:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;padding:.8rem 1rem;display:flex}.ov-card-title{color:#1e293b;align-items:center;gap:6px;font-size:1rem;font-weight:800;display:flex}.ov-card-body{flex:1;min-height:0;padding:.8rem;overflow-y:auto}.ov-stat-row{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.ov-stat-item{text-align:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;padding:15px;transition:transform .2s;display:flex}.ov-stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.ov-stat-value{color:#0f172a;margin:4px 0;font-size:1.4rem;font-weight:800}.ov-stat-label{color:#64748b;font-size:.8rem;font-weight:600}.ov-alert-list{flex-direction:column;gap:8px;display:flex}.ov-alert-item{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-left:3px solid #0000;border-radius:6px;align-items:flex-start;gap:8px;padding:8px;transition:all .2s;display:flex}.ov-alert-item:hover{background:#f8fafc;border-color:#cbd5e1}.ov-alert-item.critical{background:#fff1f2;border-left-color:#ef4444}.ov-alert-item.warning{background:#fffbeb;border-left-color:#f59e0b}.ov-alert-icon{background:#0000000d;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;display:flex}.ov-alert-title{color:#334155;font-size:.9rem;font-weight:700}.ov-alert-desc{color:#475569;font-size:.8rem}.ov-alert-time{color:#64748b;font-size:.7rem;font-family:var(--font-mono);margin-top:2px}.ov-alert-title.critical-text{color:#991b1b}.ov-alert-desc.critical-text{color:#7f1d1d}.ov-alert-time.critical-text{color:#991b1b}.ov-alert-title.warning-text{color:#b45309}.ov-alert-desc.warning-text{color:#92400e}.ov-alert-time.warning-text{color:#b45309}.ov-map-wrapper{border:1px solid #cbd5e1;border-radius:16px;position:relative;overflow:hidden}.ov-map-controls{z-index:1000;flex-direction:column;gap:8px;display:flex;position:absolute;top:20px;right:20px}.ov-map-btn{cursor:pointer;color:#475569;text-align:left;width:120px;font-weight:600;font-family:var(--font-main);background:#fff;border:1px solid #cbd5e1;border-radius:8px;align-items:center;gap:8px;padding:10px;font-size:.85rem;transition:all .2s;display:flex;box-shadow:0 4px 6px #0000001a}.ov-map-btn:hover{color:#0f172a;transform:translate(-2px)}.ov-map-btn.active{color:#fff;background:#0f172a;border-color:#0f172a}.ov-map-status-bar{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#ffffffe6;border:1px solid #cbd5e1;border-radius:12px;gap:20px;padding:10px 20px;display:flex;position:absolute;bottom:20px;left:20px;right:20px;box-shadow:0 4px 12px #0000001a}.ov-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.ov-detail-group{flex-direction:column;gap:10px;height:100%;min-height:0;display:flex;overflow-y:auto}.ov-detail-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;flex:1;min-height:0;padding:12px;display:flex}.ov-detail-header{color:#334155;border-bottom:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;font-size:.95rem;font-weight:700;display:flex}.ov-cctv-image{background:#f1f5f9;border-radius:8px;flex-shrink:0;width:100%;height:140px;margin-bottom:10px;position:relative;overflow:hidden}.ov-cctv-image img{object-fit:cover;width:100%;height:100%}.ov-live-badge{color:#fff;background:#dc2626e6;border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:700;animation:2s infinite ov-blink;position:absolute;top:8px;left:8px}.ov-sensor-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:15px;display:grid}.ov-sensor-cell{text-align:center;background:#f8fafc;border-radius:8px;padding:10px}.ov-sensor-label{color:#64748b;font-size:.8rem}.ov-sensor-val{font-size:1.1rem;font-weight:700}.ov-facility-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:15px;display:grid}.ov-facility-item{border-radius:6px;align-items:center;gap:8px;padding:8px;display:flex}.ov-facility-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.ov-detail-btn{color:#fff;cursor:pointer;width:100%;font-weight:700;font-family:var(--font-main);background:#1e293b;border:none;border-radius:8px;margin-top:auto;padding:10px;transition:background .2s}.ov-detail-btn:hover{background:#0f172a}.ov-risk-item{margin-bottom:12px}.ov-risk-label-row{color:#334155;justify-content:space-between;margin-bottom:4px;font-size:.85rem;font-weight:700;display:flex}.ov-risk-track{background:#e2e8f0;border-radius:4px;width:100%;height:8px;overflow:hidden}.ov-risk-fill{border-radius:4px;height:100%;transition:width .5s,background .5s}.marker-pulse-critical{animation:1.5s infinite ov-pulse-red}.marker-pulse-warning{animation:2s infinite ov-pulse-yellow}.ov-alert-new{animation:.4s ease-out ov-slide-in}.ov-card-body::-webkit-scrollbar{width:4px}.ov-detail-group::-webkit-scrollbar{width:4px}.ov-card-body::-webkit-scrollbar-track{background:0 0}.ov-detail-group::-webkit-scrollbar-track{background:0 0}.ov-card-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.ov-detail-group::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}@keyframes ov-pulse-red{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes ov-pulse-yellow{0%{box-shadow:0 0 #f59e0bb3}70%{box-shadow:0 0 0 8px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@keyframes ov-slide-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes ov-blink{0%,to{opacity:1}50%{opacity:.5}}
