*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #22263a;--border: #2e3348;--accent: #4f8ef7;--accent2: #34d399;--warn: #f59e0b;--danger: #ef4444;--text: #e2e8f0;--muted: #8892a4;--saf: #7c3aed;--best: #0ea5e9;--vh: #10b981}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:14px;min-height:100vh;overflow-x:hidden}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:500;display:flex;align-items:center;justify-content:center}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 48px;width:380px;max-width:95vw}.login-logo{text-align:center;margin-bottom:10px}.login-logo img{height:52px;object-fit:contain}.login-sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:18px}.login-tabs{display:flex;gap:0;margin-bottom:24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.login-tabs button{flex:1;background:none;border:none;color:var(--muted);padding:9px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.login-tabs button.active{background:var(--accent);color:#fff}.login-tabs button:not(.active):hover{background:var(--border)}.login-err{color:var(--danger);font-size:12px;text-align:center;margin-bottom:12px;min-height:16px}.login-ok{color:#10b981;font-size:12px;text-align:center;margin-bottom:12px}.lf-row{margin-bottom:16px}.lf-row label{display:block;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.lf-row input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 14px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.lf-row input:focus{border-color:var(--accent)}.btn-login{width:100%;background:var(--accent);border:none;color:#fff;padding:11px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;margin-top:4px;transition:background .15s}.btn-login:hover{background:#3a7ef0}.login-hint{text-align:center;color:var(--muted);font-size:11px;margin-top:14px}.app{display:flex;flex-direction:column;min-height:100vh}header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.logo img{height:32px;object-fit:contain}nav{display:flex;gap:4px}nav button{background:none;border:none;color:var(--muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}nav button:hover{background:var(--surface2);color:var(--text)}nav button.active{background:var(--surface2);color:var(--accent)}.header-right{display:flex;align-items:center;gap:10px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--accent2);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes spin{to{transform:rotate(360deg)}}.ts{font-size:12px;color:var(--muted)}.btn-icon{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.btn-icon:hover{color:var(--text);border-color:var(--accent)}.outage-btn{background:var(--danger);color:#fff;border:none;padding:7px 16px;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s}.outage-btn:hover{background:#dc2626}.outage-btn svg{width:14px;height:14px}main{padding:24px;max-width:1600px;margin:0 auto;width:100%}.portfolio-tabs{display:flex;gap:8px;margin-bottom:20px}.ptab{padding:7px 18px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;font-weight:600;font-size:13px;transition:all .15s}.ptab:hover{border-color:var(--accent);color:var(--text)}.ptab.active[data-p=SAF]{background:#3b1f6a;border-color:var(--saf);color:#c4b5fd}.ptab.active[data-p=BEST]{background:#0c3654;border-color:var(--best);color:#7dd3fc}.ptab.active[data-p=VH]{background:#064e3b;border-color:var(--vh);color:#6ee7b7}.ptab.active[data-p=ALL]{background:var(--surface2);border-color:var(--accent);color:var(--accent)}.summary-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.sum-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px}.sum-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.sum-value{font-size:26px;font-weight:700}.sum-unit{font-size:12px;color:var(--muted)}.section-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}.site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-bottom:28px}.site-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:border-color .15s,transform .15s;position:relative;overflow:hidden}.site-card:hover{border-color:var(--accent);transform:translateY(-2px)}.site-card.construction{opacity:.65;cursor:default}.site-card.construction:hover{transform:none;border-color:var(--border)}.site-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.site-name{font-weight:700;font-size:15px}.site-region{font-size:11px;color:var(--muted);margin-top:2px}.status-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}.status-pill.operational{background:#064e3b;color:#6ee7b7}.status-pill.construction{background:#1e3a5f;color:#93c5fd}.metrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.metric-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.metric-value{font-size:20px;font-weight:700;line-height:1}.metric-unit{font-size:10px;color:var(--muted);margin-top:1px}.sparkline-wrap{margin-top:14px;height:50px}.c-green{color:var(--accent2)}.c-blue{color:var(--accent)}.c-yellow{color:var(--warn)}.c-red{color:var(--danger)}.rev-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.card-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:16px}.chart-wrap{position:relative}.badge-p{display:inline-block;font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;margin-right:6px;vertical-align:middle}.badge-SAF{background:#3b1f6a;color:#c4b5fd}.badge-BEST{background:#0c3654;color:#7dd3fc}.badge-VH{background:#064e3b;color:#6ee7b7}.rev-site-table{width:100%;border-collapse:collapse}.rev-site-table th{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;text-align:right;border-bottom:1px solid var(--border)}.rev-site-table th:first-child{text-align:left}.rev-site-table td{padding:8px 10px;text-align:right;border-bottom:1px solid #1e2236;font-size:13px}.rev-site-table td:first-child{text-align:left;font-weight:600}.rev-site-table tr:last-child td{border-bottom:none}.outage-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.btn-primary{background:var(--accent);border:none;color:#fff;padding:8px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#3a7ef0}.filter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.filter-sel{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:7px;font-size:12px;outline:none;cursor:pointer}.outage-table{width:100%;border-collapse:collapse;table-layout:fixed}.outage-table th{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;padding:7px 6px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface)}.outage-table td{padding:7px 6px;border-bottom:1px solid #1a1e2e;font-size:11px;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.outage-table tbody tr:hover td{background:#1e2236}.outage-table tbody tr{cursor:pointer}.pill-ongoing{background:#7f1d1d;color:#fca5a5;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}.pill-resolved{background:#064e3b;color:#6ee7b7;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}.pill-fault{background:#451a03;color:#fcd34d;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;white-space:nowrap}.pill-network{background:#172554;color:#93c5fd;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;white-space:nowrap}.tbl-btn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:4px 10px;border-radius:5px;font-size:11px;cursor:pointer;font-weight:600;transition:all .15s;margin-right:4px}.tbl-btn:hover{color:var(--text);border-color:var(--accent)}.tbl-btn.resolve{color:var(--accent2);border-color:#064e3b}.tbl-btn.resolve:hover{background:#064e3b;color:#fff}.tbl-btn.del{color:var(--danger);border-color:#7f1d1d;padding:4px 7px}.tbl-btn.del:hover{background:#7f1d1d;color:#fff}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.back-btn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.back-btn:hover{color:var(--text);border-color:var(--accent)}.detail-site-name{font-size:22px;font-weight:700}.detail-site-meta{color:var(--muted);font-size:13px;margin-top:2px}.detail-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:24px}.detail-stat{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px}.detail-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-stat-value{font-size:20px;font-weight:700}.detail-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px}.chart-card-title{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}.chart-controls{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;align-items:center}.cc-btn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:4px 10px;border-radius:5px;font-size:11px;cursor:pointer;font-weight:600;transition:all .15s}.cc-btn:hover{color:var(--text)}.cc-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.cc-toggle{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);cursor:pointer;margin-left:4px}.cc-toggle input{accent-color:var(--accent2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;width:500px;max-width:95vw;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.modal-title{font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:20px;line-height:1;padding:4px}.modal-close:hover{color:var(--text)}.form-row{margin-bottom:16px}.form-row label{display:block;font-size:11px;color:var(--muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.form-row input,.form-row select,.form-row textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:9px 12px;font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent)}.form-row select option{background:var(--surface)}.form-row textarea{resize:vertical;min-height:70px}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.btn-cancel{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:9px 18px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.btn-cancel:hover{color:var(--text)}.btn-submit{background:var(--danger);border:none;color:#fff;padding:9px 22px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700}.btn-submit:hover{background:#dc2626}.toast{position:fixed;bottom:24px;right:24px;background:var(--accent2);color:#022c22;padding:12px 20px;border-radius:10px;font-weight:700;font-size:13px;opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none;z-index:300}.toast.show{opacity:1;transform:translateY(0)}.oa-asset-chip{padding:4px 12px;font-size:11px;font-weight:700;border-radius:20px;border:1px solid var(--border);cursor:pointer;background:var(--surface2);color:var(--muted);transition:all .15s}.market-series-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 8px 4px 12px;font-size:11px;font-weight:600;border-radius:20px;border:1px solid}.market-series-chip button{background:none;border:none;cursor:pointer;font-size:14px;line-height:1;padding:0 2px;opacity:.7;transition:opacity .15s}.market-series-chip button:hover{opacity:1}.market-add-series-btn{padding:4px 12px;font-size:11px;font-weight:600;border-radius:20px;border:1px dashed var(--border);background:none;color:var(--muted);cursor:pointer;transition:all .15s}.market-add-series-btn:hover{border-color:var(--accent);color:var(--accent)}.market-series-panel{position:absolute;top:calc(100% + 8px);left:0;z-index:100;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:240px;box-shadow:0 8px 24px #0006}.msp-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:10px}.msp-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.msp-row label{font-size:12px;color:var(--muted);white-space:nowrap}.msp-row select{flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:5px 8px;border-radius:7px;font-size:12px;outline:none}.msp-add-btn{width:100%;background:var(--accent);border:none;color:#fff;padding:8px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;margin-top:4px}.msp-divider{border:none;border-top:1px solid var(--border);margin:14px 0 10px}.msp-coming-soon{font-size:9px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--muted);background:var(--surface2);padding:2px 6px;border-radius:10px;margin-left:6px}.msp-bw-asset{padding:7px 10px;font-size:12px;border-radius:8px;color:var(--muted)}.msp-bw-asset.disabled{opacity:.4;cursor:not-allowed}.mrev-date-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:7px;font-size:12px;outline:none;color-scheme:dark}.mrev-date-input:focus{border-color:var(--accent)}.mrev-clear-btn{background:none;border:1px solid var(--border);color:var(--muted);border-radius:7px;padding:3px 8px;font-size:11px;cursor:pointer}.mrev-clear-btn:hover{border-color:var(--danger);color:var(--danger)}.stat-card{background:var(--surface2);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:4px;border:1px solid var(--border)}.stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}.stat-value{font-size:18px;font-weight:700;color:var(--text)}
