:root{--bg:#0b0d10;--bg-2:#11141a;--bg-3:#1a1f27;--border:#232a35;--fg:#e6e9ef;--fg-dim:#8b94a3;--accent:#4cc2ff;--green:#4ade80;--yellow:#facc15;--red:#f87171;--orange:#fb923c;--purple:#c084fc;--cyan:#22d3ee;--pink:#f472b6}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;line-height:1.45;height:100%}body{min-height:100vh}.app{flex-direction:column;height:100vh}.app,header{display:flex}header{align-items:center;flex-wrap:wrap;gap:14px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border);flex:0 0 auto}header .filter-group input[type=datetime-local],header .filter-group input[type=text],header .filter-group select{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font:inherit;outline:none;color-scheme:dark}header .filter-group label{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.quick-ranges{display:inline-flex;align-items:center;gap:4px;padding-left:4px;border-left:1px solid var(--border);margin-left:2px}.tz-switch{display:inline-flex;border:1px solid var(--border);border-radius:4px;overflow:hidden}.tz-switch button{background:var(--bg-3);color:var(--fg-dim);border:none;padding:4px 10px;font:inherit;font-size:11px;letter-spacing:.4px;cursor:pointer}.tz-switch button:hover:not(.active){background:#1f2630;color:var(--fg)}.tz-switch button+button{border-left:1px solid var(--border)}.tz-switch button.active{background:rgba(76,194,255,.15);color:var(--accent);cursor:default}header h1{font-size:14px;margin:0;font-weight:600;letter-spacing:.3px}.status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-dim)}.dot{width:8px;height:8px;border-radius:50%;background:var(--fg-dim)}.dot.live{background:var(--green);box-shadow:0 0 6px var(--green)}.dot.paused{background:var(--yellow)}.dot.error{background:var(--red)}.spacer{flex:1 1}.metric{font-size:12px;color:var(--fg-dim)}.metric strong{color:var(--fg)}.filters{display:flex;flex-direction:column;gap:16px;padding:14px 16px 16px;background:var(--bg-2);border-bottom:1px solid var(--border);flex:0 0 auto}.filter-row{display:flex;flex-wrap:wrap;gap:18px;align-items:center}.filter-group{display:inline-flex;align-items:center;gap:8px}.filter-group.grow{flex:1 1 200px;min-width:180px}.filter-group.grow input[type=text]{flex:1 1}.filter-divider{width:1px;height:20px;align-self:center;background:var(--border);margin:0 4px}.filters input[type=text],.filters select{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:5px 8px;font:inherit;outline:none;min-width:140px}.filters input[type=text]:focus,.filters select:focus{border-color:var(--accent)}.filters label{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.cat-toggles{display:flex;gap:4px;flex-wrap:wrap}.cat-toggle{background:var(--bg-3);color:var(--fg-dim);border:1px solid var(--border);border-radius:999px;padding:3px 10px;font:inherit;font-size:11px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.cat-toggle.active{color:var(--fg);border-color:var(--accent);background:rgba(76,194,255,.08)}button.ghost,button.primary{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:5px 10px;font:inherit;cursor:pointer}button.primary{border-color:var(--accent);color:var(--accent)}button.ghost:hover,button.primary:hover{background:#1f2630}button.ghost:disabled,button.primary:disabled{opacity:.4;cursor:not-allowed;background:var(--bg-3)}input[type=datetime-local]{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font:inherit;outline:none;color-scheme:dark}input[type=datetime-local]:focus{border-color:var(--accent)}.tabs{display:flex;gap:2px;background:var(--bg-2);border-bottom:1px solid var(--border);padding:0 14px;flex:0 0 auto}.tab{background:transparent;color:var(--fg-dim);border:none;border-bottom:2px solid transparent;padding:8px 14px;font:inherit;font-size:12px;cursor:pointer;letter-spacing:.3px;display:inline-flex;align-items:center;gap:6px}.tab:hover{color:var(--fg)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-count{display:inline-block;background:var(--bg-3);color:var(--fg-dim);font-size:10.5px;padding:1px 6px;border-radius:999px}.tab.active .tab-count{color:var(--accent)}.log-view{flex:1 1 auto;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.log-filters{flex:0 0 auto;display:flex;flex-direction:column;gap:10px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border)}.log-filters .filter-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.log-filters input[type=text],.log-filters select{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:5px 8px;font:inherit;outline:none;min-width:120px}.log-filters input[type=text]:focus,.log-filters select:focus{border-color:var(--accent)}.log-filters label{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.evse-view,.log{flex:1 1 auto;overflow-y:auto;background:var(--bg);font-size:12px}.evse-view{padding:12px}.evse-group{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden}.evse-group>summary{list-style:none;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;align-items:center;gap:14px;padding:10px 14px;background:var(--bg-2)}.evse-group>summary::-webkit-details-marker{display:none}.evse-group>summary:before{content:"▶";color:var(--fg-dim);font-size:9px;width:10px;display:inline-block;transition:transform .12s ease}.evse-group[open]>summary:before{transform:rotate(90deg)}.evse-group:hover>summary{background:#161b23}.evse-body{padding:8px 14px 12px 30px;background:var(--bg);border-top:1px solid var(--border)}.cat-group{margin:6px 0;border:1px solid var(--border);border-radius:4px;background:var(--bg-2)}.cat-group>summary{list-style:none;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;align-items:center;gap:10px;padding:6px 10px}.cat-group>summary::-webkit-details-marker{display:none}.cat-group>summary:before{content:"▶";color:var(--fg-dim);font-size:9px;width:10px;display:inline-block;transition:transform .12s ease}.cat-group[open]>summary:before{transform:rotate(90deg)}.cat-group:hover>summary{background:#161b23}.signals{background:var(--bg);border-top:1px solid var(--border)}.signal-row{display:grid;grid-template-columns:1.2fr 60px 215px 2fr;grid-gap:10px;gap:10px;padding:4px 12px 4px 24px;align-items:baseline;border-bottom:1px solid #15191f}.signal-row:last-child{border-bottom:none}.signal-row:hover:not(.signal-header){background:#0f131a}.signal-header{background:var(--bg-2);color:var(--fg-dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px}.signal-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.signal-count,.signal-time{color:var(--fg-dim)}.signal-payload,.signal-time{white-space:nowrap}.signal-payload{color:var(--fg);overflow:hidden;text-overflow:ellipsis}.pager{display:flex;gap:10px;padding:8px 14px;background:var(--bg-2);border-top:1px solid var(--border);flex:0 0 auto;font-size:12px}.page-nav,.pager{align-items:center}.page-nav{display:inline-flex;gap:4px}.page-btn{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font:inherit;font-size:12px;cursor:pointer;min-width:28px;text-align:center}.page-btn:hover:not(:disabled):not(.active){background:#1f2630}.page-btn.active{background:rgba(76,194,255,.15);border-color:var(--accent);color:var(--accent);cursor:default}.page-btn:disabled:not(.active){opacity:.4;cursor:not-allowed}.page-btn.nav{padding:3px 9px;font-weight:700}.page-ellipsis{color:var(--fg-dim);padding:0 4px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mode-pill{display:inline-block;padding:1px 8px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.mode-pill.live{background:rgba(74,222,128,.14);color:var(--green)}.mode-pill.browse{background:rgba(250,204,21,.14);color:var(--yellow)}.row{display:grid;grid-template-columns:90px 215px 80px 56px 1fr 1.4fr;grid-gap:10px;gap:10px;padding:4px 14px;border-bottom:1px solid #15191f;align-items:baseline}.row.header-row{position:-webkit-sticky;position:sticky;top:0;background:var(--bg-2);color:var(--fg-dim);font-size:11px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);z-index:1}.row:hover:not(.header-row){background:#0f131a}.col-id,.col-time{color:var(--fg-dim)}.col-time{white-space:nowrap}.badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10.5px;font-weight:600;letter-spacing:.3px;background:var(--bg-3);color:var(--fg-dim)}.badge.evse{background:rgba(76,194,255,.12);color:var(--accent)}.badge.dispenser{background:rgba(244,114,182,.14);color:var(--pink);font-size:11.5px;padding:2px 8px}.badge.cat-Session{background:rgba(74,222,128,.12);color:var(--green)}.badge.cat-Measurement{background:rgba(34,211,238,.12);color:var(--cyan)}.badge.cat-Thermal{background:rgba(251,146,60,.14);color:var(--orange)}.badge.cat-IMD{background:rgba(192,132,252,.14);color:var(--purple)}.badge.cat-Fault{background:rgba(248,113,113,.14);color:var(--red)}.badge.cat-Status{background:rgba(250,204,21,.12);color:var(--yellow)}.badge.cat-Command{background:rgba(244,114,182,.12);color:var(--pink)}.badge.cat-Comms{background:rgba(76,194,255,.1);color:var(--accent)}.badge.cat-Config{background:rgba(139,148,163,.18);color:var(--fg-dim)}.badge.cat-Dispenser{background:rgba(217,70,239,.14);color:#d946ef}.badge.cat-Rectifier{background:rgba(129,140,248,.16);color:#818cf8}.badge.cat-QCB{background:rgba(163,230,53,.14);color:#a3e635}.badge.cat-Infrastructure{background:rgba(45,212,191,.14);color:#2dd4bf}.badge.cat-Other{background:var(--bg-3);color:var(--fg-dim)}.col-payload,.col-topic{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-payload,.empty{color:var(--fg-dim)}.empty{padding:40px;text-align:center}.empty.small{padding:14px;text-align:left;font-size:11.5px}.dash-stats{display:flex;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:14px;flex-shrink:0}.dash-stat{flex:1 1;padding:12px 18px;background:var(--bg-2)}.dash-stat-label{font-size:10.5px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.dash-stat-value{font-size:26px;font-weight:600;color:var(--fg);line-height:1}.dash-stat-fault{color:var(--red)}.sub-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:12px}.sub-tab{background:transparent;color:var(--fg-dim);border:none;border-bottom:2px solid transparent;padding:6px 14px;font:inherit;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:color 80ms}.sub-tab:hover{color:var(--fg)}.sub-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.session-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:12px;gap:12px}.session-card{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.session-card-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-3);border-bottom:1px solid var(--border)}.session-ts{font-size:11px;color:var(--fg-dim);white-space:nowrap}.badge.session-active{background:rgba(74,222,128,.12);color:var(--green)}.badge.session-ended{background:rgba(139,148,163,.18);color:var(--fg-dim)}.session-card-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}.session-metrics{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.session-metric-box{background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:6px 10px;min-width:72px}.session-metric-label{font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}.session-metric-value{font-size:14px;font-weight:600;color:var(--accent)}.session-field{display:flex;gap:10px;align-items:baseline;font-size:12px}.session-label{font-size:10.5px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.4px;min-width:56px;flex-shrink:0}.session-val{color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-unit,.session-val.dim{color:var(--fg-dim)}.session-unit{font-size:10.5px}.session-table-container{flex:1 1 auto;overflow-y:auto;background:var(--bg);font-size:12px}.session-table{width:100%;min-width:0}.session-table-header,.session-table-row{display:grid;grid-template-columns:62px 68px minmax(0,1fr) 58px 90px 72px minmax(0,1fr);grid-gap:10px;gap:10px;padding:5px 14px;align-items:center}.session-table-header{position:-webkit-sticky;position:sticky;top:0;background:var(--bg-2);border-bottom:1px solid var(--border);color:var(--fg-dim);font-size:11px;text-transform:uppercase;letter-spacing:.4px;z-index:1}.session-row-wrap{border-bottom:1px solid #15191f}.session-table-row{list-style:none;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.session-table-row::-webkit-details-marker{display:none}.session-table-row:before{content:"▶";position:absolute;left:4px;font-size:8px;color:var(--fg-dim);transition:transform .12s ease}.session-row-wrap{position:relative}.session-row-wrap[open]>.session-table-row:before{transform:rotate(90deg)}.session-row-wrap:hover>.session-table-row{background:#0f131a}.session-row-wrap[open]>.session-table-row{background:#0d1117}.session-id-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--fg-dim)}.session-detail{padding:12px 14px 14px 28px;background:var(--bg-2);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));grid-gap:14px 28px;gap:14px 28px}.session-chart-wrap{grid-column:1/-1;background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:8px 4px 4px;margin-bottom:4px}.session-summary{grid-column:1/-1;padding:8px 0 4px}.sess-drilldown-btn{display:block;width:100%;background:rgba(76,194,255,.15);border:1px solid var(--accent);color:var(--accent);font-size:11px;padding:7px 10px;border-radius:4px;cursor:pointer;font-family:inherit;margin-top:8px;text-align:center;letter-spacing:.3px}.sess-drilldown-btn:hover{background:rgba(76,194,255,.28)}.sess-drill-wrap{grid-column:1/-1;display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.sess-drill-section{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;padding:8px 12px 10px}.sess-drill-section-label{font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:6px}.sess-drill-fault-list{display:flex;flex-wrap:wrap;gap:6px}.sess-drill-fault-badge{display:inline-flex;align-items:center;background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.35);border-radius:4px;padding:2px 7px;font-size:11px}.sess-drill-fault-comp{color:var(--fg-dim)}.sess-drill-fault-sig{color:var(--red);font-weight:600}.sess-drill-fault-val{color:var(--fg-dim)}.fault-tl-wrap{display:flex;flex-direction:column;gap:5px}.fault-tl-row{display:grid;grid-template-columns:110px 1fr auto;align-items:center;grid-gap:10px;gap:10px;min-height:26px}.fault-tl-comp{font-size:10px;color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:ui-monospace,monospace}.fault-tl-bar{position:relative;height:18px;background:rgba(248,113,113,.06);border:1px solid rgba(248,113,113,.2);border-radius:3px}.fault-tl-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:9px;height:9px;border-radius:50%;cursor:default;z-index:1}.fault-tl-legend{display:flex;flex-direction:column;gap:1px;min-width:0}.fault-tl-sig{font-size:10px;white-space:nowrap}.fault-tl-cnt{opacity:.6;font-size:9px}.fault-tl-axis{display:flex;justify-content:space-between;font-size:9px;color:var(--fg-dim);padding:0 2px;opacity:.7}.fault-tl-active-range{position:absolute;top:0;height:100%;border-radius:2px;opacity:.75;min-width:3px}.sess-drill-status{grid-column:1/-1;font-size:11px;color:var(--fg-dim);padding:6px 0;font-style:italic}.sess-drill-error{color:var(--red);font-style:normal}.sess-drill-no-data{font-size:10px;color:var(--fg-dim);font-style:italic;padding:4px 0}.sess-drill-no-faults{font-size:11px;color:var(--green);opacity:.8;padding:2px 0}.sess-fault-dot{margin-left:6px;color:var(--red);font-size:11px;vertical-align:middle}.sess-soc-row{display:flex;align-items:center;gap:10px}.sess-soc-label{font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;min-width:28px}.sess-soc-bar-wrap{display:flex;align-items:center;gap:10px;flex:1 1}.sess-soc-bar-bg{flex:1 1;height:10px;background:rgba(255,255,255,.07);border-radius:5px;overflow:hidden;position:relative}.sess-soc-bar-fill{position:absolute;top:0;height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:5px;min-width:3px}.sess-soc-range{font-size:11px;color:var(--fg);white-space:nowrap}.sess-stats-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.sess-stat{font-size:13px}.sess-stat-val{font-weight:600;color:var(--accent)}.sess-stat-unit{font-size:11px;color:var(--fg-dim)}.session-group{min-width:0}.session-group-title{font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;font-weight:600;padding-bottom:3px;border-bottom:1px solid var(--border)}.session-label{min-width:112px}.tps-chart-wrap{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;padding:14px 14px 8px;margin-bottom:14px;flex-shrink:0}.tps-chart-title{font-size:10.5px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.tps-tooltip{display:flex;gap:10px;align-items:baseline;background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:5px 10px;font-size:11.5px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.tps-tooltip-time{color:var(--fg-dim)}.tps-tooltip-val{color:var(--accent);font-weight:600}.tps-tooltip-count{color:var(--fg-dim);font-size:10.5px}.thermal-view{flex:1 1 auto;overflow-y:auto;background:var(--bg);padding:12px}.thermal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));grid-gap:12px;gap:12px}.thermal-card{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.thermal-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-bottom:1px solid var(--border)}.thermal-tooltip{background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:6px 10px;font-size:11.5px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;min-width:160px}.thermal-tooltip-time{color:var(--fg-dim);margin-bottom:4px;font-size:10.5px}.thermal-tooltip-row{display:flex;align-items:center;gap:6px;padding:1px 0}.thermal-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.thermal-tooltip-name{flex:1 1;color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thermal-tooltip-val{color:var(--fg);font-weight:600;white-space:nowrap}.fault-val-active{color:var(--red)}.fault-latest-val{display:inline-flex;align-items:baseline;gap:5px;font-size:11px}.fault-latest-hex,.fault-latest-name{color:var(--fg-dim)}.fault-latest-hex{font-weight:600}.fault-latest-hex.active{color:var(--red)}.fault-tooltip-clear{color:var(--green);font-size:10.5px;margin-top:3px}.fault-tooltip-active .thermal-tooltip-name{color:var(--red)}.fault-summary-bar{padding:10px 14px;border-radius:6px;margin-bottom:14px;font-size:12.5px;font-weight:600;flex-shrink:0}.fault-summary-ok{color:var(--green)}.fault-summary-warn{color:var(--red)}.fault-clear-section{margin-top:16px;border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0}.fault-clear-section>summary{list-style:none;cursor:pointer;padding:8px 14px;font-size:11.5px;color:var(--fg-dim);background:var(--bg-2);-webkit-user-select:none;-moz-user-select:none;user-select:none}.fault-clear-section>summary::-webkit-details-marker{display:none}.fault-clear-section>summary:before{content:"▶";font-size:9px;margin-right:8px;color:var(--fg-dim);transition:transform .12s;display:inline-block}.fault-clear-section[open]>summary:before{transform:rotate(90deg)}.fault-clear-table-wrap{background:var(--bg);border-top:1px solid var(--border)}.fault-clear-table-header,.fault-clear-table-row{display:grid;grid-template-columns:160px 1fr 80px;grid-gap:12px;gap:12px;padding:6px 14px;align-items:center;font-size:11.5px}.fault-clear-table-header{background:var(--bg-2);color:var(--fg-dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0}.fault-clear-table-row{border-bottom:1px solid #15191f}.fault-clear-table-row:last-child{border-bottom:none}.fault-clear-table-row:hover{background:#0f131a}.fault-clear-signals{color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-expand-btn{margin-left:auto;background:transparent;border:none;color:var(--fg-dim);font-size:14px;cursor:pointer;padding:0 2px;line-height:1;opacity:.6;transition:opacity .1s,color .1s}.chart-expand-btn:hover{opacity:1;color:var(--accent)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-box{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;width:100%;max-width:1300px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-3);flex-shrink:0}.modal-title{font-size:13px;font-weight:600;color:var(--fg)}.modal-close{background:transparent;border:none;color:var(--fg-dim);font-size:16px;cursor:pointer;padding:0 4px;line-height:1}.modal-close:hover{color:var(--fg)}.modal-body{padding:16px;overflow-y:auto;flex:1 1;display:flex;flex-direction:column;gap:16px}.modal-table-wrap{border:1px solid var(--border);border-radius:6px;overflow:hidden;font-size:11.5px;flex-shrink:0}.modal-table-row{display:grid;grid-gap:10px;gap:10px;padding:4px 12px;border-bottom:1px solid #15191f;align-items:center}.modal-table-row:last-child{border-bottom:none}.modal-table-row:hover:not(.modal-table-header){background:#0f131a}.modal-table-header{background:var(--bg-2);color:var(--fg-dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border)!important;position:-webkit-sticky;position:sticky;top:0;z-index:1}.modal-table-row-alert{background:rgba(248,113,113,.05)}.modal-table-time{color:var(--fg-dim);white-space:nowrap}.top-topics-wrap{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0}.top-topics-title{font-size:10.5px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;padding:10px 14px 8px;border-bottom:1px solid var(--border);background:var(--bg-3)}.top-topics-total{color:var(--fg-dim);text-transform:none;letter-spacing:0}.top-topics-table{font-size:11.5px}.top-topics-header,.top-topics-row{display:grid;grid-template-columns:36px 1fr 90px 120px;grid-gap:10px;gap:10px;padding:4px 14px;align-items:center;border-bottom:1px solid #15191f}.top-topics-row:last-child{border-bottom:none}.top-topics-header{background:var(--bg-2);color:var(--fg-dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.top-topics-row:hover{background:#0f131a}.top-topics-rank{color:var(--fg-dim);text-align:right}.top-topics-topic{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--fg)}.top-topics-count{color:var(--accent);text-align:right}.top-topics-count,.top-topics-pct{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.top-topics-pct{display:flex;align-items:center;gap:6px;color:var(--fg-dim);white-space:nowrap}.top-topics-bar{display:inline-block;height:4px;background:var(--accent);border-radius:2px;opacity:.4;min-width:2px;flex-shrink:0}.sig-popover-overlay{position:fixed;inset:0;z-index:600}.sig-popover{position:fixed;background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:12px 14px;min-width:240px;max-width:320px;box-shadow:0 12px 40px rgba(0,0,0,.6);z-index:601;display:flex;flex-direction:column;gap:8px}.sig-popover-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.sig-popover-name{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.sig-popover-val{font-size:22px;font-weight:700;color:var(--fg);word-break:break-all;line-height:1.25}.sig-popover-val-Measurement{color:var(--cyan)}.sig-popover-val-Thermal{color:var(--orange)}.sig-popover-val-Fault{color:var(--red)}.sig-popover-val-Status{color:var(--yellow)}.sig-popover-val-Session{color:var(--green)}.sig-popover-val-IMD{color:var(--purple)}.sig-popover-val-Rectifier{color:#818cf8}.sig-popover-val-QCB{color:#a3e635}.sig-popover-topic{font-size:10.5px;color:var(--fg-dim);word-break:break-all;opacity:.75;border-top:1px solid var(--border);padding-top:6px}.sig-popover-time{font-size:10.5px;color:var(--fg-dim);opacity:.65;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.coming-soon-view{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--bg)}.coming-soon-label{font-size:22px;font-weight:600;color:var(--fg-dim);letter-spacing:.5px}.coming-soon-sub{font-size:12px;color:var(--fg-dim);opacity:.5}.comp-live-meta{font-size:11px;color:var(--fg-dim);padding:0 0 10px}.comp-live-loading{color:var(--accent)}.badge.comp-type{background:rgba(129,140,248,.16);color:#818cf8;font-size:11.5px;padding:2px 8px;text-transform:capitalize}.comp-type-group>summary{background:var(--bg-3)}.comp-type-group>.evse-body{padding-left:14px;background:var(--bg-2)}.live-type-section{margin-bottom:24px}.live-type-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.live-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:10px;gap:10px}@keyframes live-card-refresh{0%{box-shadow:0 0 12px 3px rgba(76,194,255,.7),0 0 0 1px rgba(76,194,255,.9);background:rgba(76,194,255,.1)}60%{box-shadow:0 0 8px 2px rgba(76,194,255,.35),0 0 0 1px rgba(76,194,255,.5);background:rgba(76,194,255,.05)}to{box-shadow:none;background:var(--bg-2)}}.live-card{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}.live-refresh-anim .live-card{animation:live-card-refresh 1.2s ease-out forwards}.live-card-fault{border-color:rgba(248,113,113,.45)}.live-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-bottom:1px solid var(--border)}.live-card-time{margin-left:auto;font-size:10.5px;color:var(--fg-dim);white-space:nowrap;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.live-card-body{padding:10px 12px;display:flex;flex-direction:column;gap:10px}.live-cat-label{display:flex;align-items:center;gap:6px;margin-bottom:6px}.live-signals-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));grid-gap:5px;gap:5px}.live-signal-box{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:6px 8px;min-width:0;cursor:default;transition:border-color 80ms}.live-signal-box:hover{border-color:var(--accent)}.live-sig-name{font-size:9.5px;color:var(--fg-dim);letter-spacing:.2px;margin-bottom:3px}.live-sig-name,.live-sig-val{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.live-sig-val{font-size:15px;font-weight:600;color:var(--fg);line-height:1.2}.live-sig-time{font-size:9px;color:var(--fg-dim);margin-top:3px;opacity:.65;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.live-sig-Measurement .live-sig-val{color:var(--cyan)}.live-sig-Thermal .live-sig-val{color:var(--orange)}.live-sig-Fault .live-sig-val{color:var(--red)}.live-sig-Fault{border-color:rgba(248,113,113,.2);background:rgba(248,113,113,.04)}.live-sig-Status .live-sig-val{color:var(--yellow)}.live-sig-Session .live-sig-val{color:var(--green)}.live-sig-IMD .live-sig-val{color:var(--purple)}.live-sig-Rectifier .live-sig-val{color:#818cf8}.live-sig-QCB .live-sig-val{color:#a3e635}.live-sig-Infrastructure .live-sig-val{color:#2dd4bf}.live-sig-Dispenser .live-sig-val{color:#d946ef}.fault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:10px;gap:10px}.fault-card{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.fault-card-active{border-color:rgba(248,113,113,.5)}.fault-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-bottom:1px solid var(--border)}.badge.fault-ok{background:rgba(74,222,128,.12);color:var(--green)}.fault-signals{padding:6px 0}.fault-signal-row{display:grid;grid-template-columns:1.4fr 1fr 1.6fr;grid-gap:8px;gap:8px;padding:3px 12px;font-size:11.5px;border-bottom:1px solid #15191f}.fault-signal-row:last-child{border-bottom:none}.fault-signal-row.fault-nonzero{background:rgba(248,113,113,.06)}.fault-sig-name{color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fault-nonzero .fault-sig-name{color:var(--red)}.fault-sig-val{color:var(--fg);font-weight:600;white-space:nowrap}.fault-nonzero .fault-sig-val{color:var(--red)}.fault-sig-time{color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-evse-view{flex:1 1 auto;overflow-y:auto;background:var(--bg);padding:12px;font-size:12px;display:flex;flex-direction:column;gap:12px}.session-evse-block{background:var(--bg-2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.session-evse-header{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-3);border-bottom:1px solid var(--border)}.session-table-header-6,.session-table-row-6{grid-template-columns:56px 72px minmax(0,1fr) 72px 72px 100px 82px minmax(0,1fr) minmax(0,1fr)}.dispenser-group>.evse-body{padding-left:22px}.dispenser-group .evse-group{background:var(--bg-3)}.live-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:6px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:6px;margin-bottom:10px}.live-toolbar-divider{width:1px;height:16px;background:var(--border);flex-shrink:0;margin:0 8px}.live-snapshot-label{font-size:11px;color:var(--fg-dim);white-space:nowrap;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.live-refreshing{color:var(--accent)}.live-type-inline{display:flex;align-items:center;gap:4px;flex-wrap:wrap;flex:1 1}.live-status-filter-row{display:flex;gap:4px;flex-wrap:wrap}.live-stat-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:600;border:1px solid transparent;white-space:nowrap}.live-stat-chip-btn{cursor:pointer;transition:opacity .1s,filter .1s}.live-stat-chip-btn:hover{filter:brightness(1.2)}.live-stat-all{background:var(--bg-3);color:var(--fg-dim);border-color:var(--border)}.live-stat-charging{background:rgba(74,222,128,.12);color:var(--green);border-color:rgba(74,222,128,.25)}.live-stat-fault{background:rgba(248,113,113,.12);color:var(--red);border-color:rgba(248,113,113,.25)}.live-stat-stale{background:rgba(250,204,21,.12);color:var(--yellow);border-color:rgba(250,204,21,.25)}.live-stat-idle{background:rgba(139,148,163,.1);color:var(--fg-dim);border-color:rgba(139,148,163,.18)}.live-stat-active{outline:2px solid currentColor;outline-offset:1px}.live-ar-btn{flex-shrink:0;background:var(--bg-3);color:var(--fg-dim);border:1px solid var(--border);border-radius:4px;padding:3px 10px;font:inherit;font-size:11px;cursor:pointer;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}.live-ar-btn:hover{color:var(--fg)}.live-ar-btn.active{color:var(--accent);border-color:rgba(76,194,255,.35)}.live-type-strip-label{font-size:10px;text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-right:4px;flex-shrink:0}.live-type-btn,.live-type-strip-label{color:var(--fg-dim);white-space:nowrap}.live-type-btn{display:inline-flex;align-items:center;gap:5px;background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:3px 10px;font:inherit;font-size:11px;cursor:pointer;text-transform:capitalize;transition:background 80ms,color 80ms,border-color 80ms}.live-type-btn:hover{color:var(--fg);background:#1f2630}.live-type-btn.active{background:rgba(129,140,248,.14);border-color:rgba(129,140,248,.45);color:#818cf8;font-weight:600}.live-type-count{background:var(--bg);border-radius:999px;padding:1px 6px;font-size:10px;color:var(--fg-dim);line-height:1.4}.live-type-btn.active .live-type-count{color:#818cf8}.live-status-pill{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.2px;text-transform:uppercase;flex-shrink:0}.live-status-charging{background:rgba(74,222,128,.14);color:var(--green)}.live-status-fault{background:rgba(248,113,113,.14);color:var(--red)}.live-status-stale{background:rgba(250,204,21,.14);color:var(--yellow)}.live-status-idle{background:rgba(139,148,163,.1);color:var(--fg-dim)}.live-card-status-charging{border-color:rgba(74,222,128,.3)}.live-card-status-fault{border-color:rgba(248,113,113,.5)}.live-card-status-stale{border-color:rgba(250,204,21,.3);opacity:.72}.live-card-time-stale{color:var(--yellow)!important}.live-card-time-warn{color:var(--orange)}.live-fault-bar{display:flex;flex-wrap:wrap;gap:8px;padding:5px 10px;background:rgba(248,113,113,.08);border-bottom:1px solid rgba(248,113,113,.2)}.live-fault-item{display:inline-flex;align-items:center;gap:4px;font-size:10.5px}.live-fault-name{color:var(--red);font-weight:600;text-transform:uppercase;letter-spacing:.2px}.live-fault-val{color:var(--red);font-weight:700}.live-key-metrics{display:flex;gap:6px;padding:8px 10px;background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap}.live-metric-box{flex:1 1 68px;min-width:60px;max-width:110px;background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:5px 8px}.live-metric-label{font-size:9px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px}.live-metric-label,.live-metric-val{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.live-metric-val{font-size:17px;font-weight:700;line-height:1.15;color:var(--fg)}.live-metric-box.live-sig-Measurement .live-metric-val{color:var(--cyan)}.live-metric-box.live-sig-Session .live-metric-val{color:var(--green)}.live-metric-box.live-sig-Thermal .live-metric-val{color:var(--orange)}.live-metric-box.live-sig-Fault .live-metric-val{color:var(--red)}.live-metric-box.live-sig-Status .live-metric-val{color:var(--yellow)}.hist-metric-box{max-width:120px}.hist-metric-box .live-metric-val{font-size:14px}.hist-metric-range{font-size:9px;color:var(--fg-dim);margin-top:2px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-metric-change{display:flex;align-items:baseline;gap:3px;flex-wrap:wrap;margin:1px 0}.hist-mc-from{font-size:10px;color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}.hist-mc-arrow{font-size:10px;color:var(--fg-dim)}.hist-mc-to{font-size:15px;font-weight:700;color:var(--fg);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}.live-metric-box.live-sig-Measurement .hist-mc-to{color:var(--cyan)}.live-metric-box.live-sig-Session .hist-mc-to{color:var(--green)}.live-metric-box.live-sig-Thermal .hist-mc-to{color:var(--orange)}.live-metric-box.live-sig-Fault .hist-mc-to{color:var(--red)}.hist-no-events{font-size:11px;color:var(--fg-dim);padding:6px 2px;font-style:italic}.hist-sig-stable{opacity:.45}.hist-sig-stable:hover{opacity:.9}.hist-sig-changed{border-color:rgba(99,102,241,.25)}.hist-sig-val-last{font-size:13px}.hist-sig-from{font-size:9px;color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-sig-active-fault{border-color:rgba(248,113,113,.55)!important;background:rgba(248,113,113,.07)!important}.hist-sig-active-fault .live-sig-val{color:var(--red)!important}.hist-chart-btn{margin-left:auto;padding:2px 8px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--accent);font-size:10px;cursor:pointer;white-space:nowrap;transition:background .1s,border-color .1s}.hist-chart-btn:hover{background:rgba(99,102,241,.12);border-color:var(--accent)}.hist-chart-modal{display:flex;flex-direction:column;gap:20px;padding:4px 0}.hist-chart-section-label{display:flex;align-items:center;gap:8px;margin-bottom:6px}.hist-chart-sig-name{font-size:11px;font-weight:600;color:var(--fg);text-transform:capitalize;letter-spacing:.2px}.hist-type-section{margin-bottom:24px}.hist-type-header{display:flex;align-items:center;gap:8px;padding:6px 0 8px;border-bottom:1px solid var(--border);margin-bottom:12px}.hist-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:14px;gap:14px}.hist-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}.hist-card.hist-card-fault{border-color:var(--red)}.hist-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hist-card-title{font-weight:600;font-size:14px;color:var(--fg)}.hist-card-window{display:flex;align-items:center;gap:4px;font-size:11px;margin-left:auto}.hist-card-window,.hist-window-arrow{color:var(--fg-dim)}.hist-fault-bar{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;background:rgba(248,113,113,.08);border-radius:4px;border-left:3px solid var(--red)}.hist-fault-item{display:flex;gap:4px;font-size:11px}.hist-fault-name{color:var(--fg-dim)}.hist-fault-range{color:var(--red);font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-key-signals{display:flex;flex-direction:column;gap:4px}.hist-metric-row{display:flex;align-items:baseline;gap:6px;font-size:12px}.hist-metric-name{color:var(--fg-dim);min-width:80px}.hist-metric-values{display:flex;align-items:baseline;gap:4px;flex:1 1;flex-wrap:wrap}.hist-val-first{color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-val-last{color:var(--fg);font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-trend-icon{font-size:13px}.hist-trend-up{color:var(--green)}.hist-trend-down{color:var(--red)}.hist-trend-flat{color:var(--fg-dim)}.hist-minmax{font-size:10px;color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-metric-count{font-size:10px;color:var(--fg-dim);margin-left:auto}.hist-cat-tabs{display:flex;flex-wrap:wrap;gap:4px;border-top:1px solid var(--border);padding-top:8px}.hist-cat-tab{padding:2px 8px;border-radius:4px;background:transparent;border:1px solid var(--border);color:var(--fg-dim);font-size:11px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .1s}.hist-cat-tab:hover{background:var(--hover);color:var(--fg)}.hist-cat-tab.active{background:rgba(99,102,241,.15);border-color:#6366f1;color:var(--fg)}.hist-cat-tab.fault-tab.active{background:rgba(248,113,113,.12);border-color:var(--red);color:var(--red)}.hist-cat-count{font-size:10px;color:var(--fg-dim)}.hist-sig-table{display:flex;flex-direction:column;gap:2px;margin-top:4px}.hist-sig-header{font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.hist-sig-header,.hist-sig-row{display:grid;grid-template-columns:1fr 54px 16px 54px 42px 42px 22px 54px;grid-gap:4px;gap:4px;padding:3px 4px}.hist-sig-row{font-size:11px;border-radius:3px}.hist-sig-row:hover{background:var(--hover)}.hist-sig-row.hist-sig-fault{background:rgba(248,113,113,.06)}.hist-sig-name{color:var(--fg)}.hist-sig-cell,.hist-sig-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-sig-cell{color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-sig-trend{text-align:center}.hist-sig-stat{color:var(--fg-dim);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hist-sig-count{color:var(--fg-dim);text-align:right}.hist-sig-sparkline{display:flex;align-items:center}.hist-sparkline{color:var(--fg-dim);display:block}.hist-metric-row .hist-sparkline{color:var(--cyan);opacity:.8}.error-banner,.hist-sig-row.hist-sig-fault .hist-sparkline{color:var(--red)}.error-banner{padding:8px 14px;background:rgba(248,113,113,.12);border-bottom:1px solid var(--border);font-size:12px}.alerts-view{padding:14px 18px 60px}.alerts-wip-banner{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:14px;border-radius:6px;background:rgba(251,146,60,.1);color:var(--orange);border:1px solid rgba(251,146,60,.3);font-size:12px}.alerts-wip-banner .wip-tag{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:11px;padding:1px 6px;border-radius:4px;background:rgba(251,146,60,.18);border:1px solid rgba(251,146,60,.35)}.alerts-wip-banner .wip-text{color:var(--fg-dim)}.info-banner{padding:8px 12px;margin-bottom:12px;border-radius:6px;background:rgba(76,194,255,.1);color:var(--accent);border:1px solid rgba(76,194,255,.25);font-size:12px}.alerts-subnav{display:flex;align-items:center;gap:6px;margin-bottom:14px}.alerts-subnav button{background:var(--bg-3);color:var(--fg-dim);border:1px solid var(--border);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:6px}.alerts-subnav button:hover{color:var(--fg)}.alerts-subnav button.active{background:rgba(76,194,255,.15);color:var(--accent);border-color:rgba(76,194,255,.4)}.alerts-subnav .firing-pip{background:rgba(248,113,113,.18);color:var(--red);padding:1px 7px;border-radius:999px;font-size:11px}.alerts-empty{padding:40px;text-align:center;color:var(--fg)}.alerts-empty .dim{max-width:520px;margin:8px auto 0}.dim{color:var(--fg-dim)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.hint{font-size:11px;display:block;margin-top:4px}.alerts-rules{display:flex;flex-direction:column;gap:10px}.alert-card{display:flex;gap:14px;justify-content:space-between;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px}.alert-card.is-firing{border-color:rgba(248,113,113,.5);background:rgba(248,113,113,.06)}.alert-card-main{min-width:0;flex:1 1}.alert-card-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.alert-card-topic{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--cyan);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alert-card-cond{font-size:13px;margin:3px 0}.alert-card-meta{font-size:11px}.alert-card-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:150px}.alert-card-value{font-size:20px;font-weight:600}.alert-card-value .dim{font-size:11px;font-weight:400}.alert-card-actions{display:flex;align-items:center;gap:6px;margin-top:4px}.alert-badge{font-size:11px;padding:1px 8px;border-radius:999px;white-space:nowrap}.alert-badge.firing{background:rgba(248,113,113,.18);color:var(--red)}.alert-badge.ok{background:rgba(74,222,128,.16);color:var(--green)}.alert-badge.nodata{background:rgba(250,204,21,.16);color:var(--yellow)}.alert-badge.muted{background:var(--bg-3);color:var(--fg-dim)}.sev-badge{font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:1px 7px;border-radius:4px}.sev-badge.critical{background:rgba(248,113,113,.18);color:var(--red)}.sev-badge.warning{background:rgba(251,146,60,.18);color:var(--orange)}.sev-badge.info{background:rgba(76,194,255,.16);color:var(--accent)}.ghost{background:transparent;color:var(--fg-dim);border:1px solid var(--border);padding:4px 10px;border-radius:6px;cursor:pointer;font-size:12px}.ghost:hover{color:var(--fg);border-color:var(--fg-dim)}.ghost.danger:hover{color:var(--red);border-color:var(--red)}.switch{position:relative;display:inline-block;width:34px;height:18px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;inset:0;background:var(--bg-3);border:1px solid var(--border);border-radius:999px;transition:.15s;cursor:pointer}.switch .slider:before{content:"";position:absolute;height:12px;width:12px;left:2px;top:2px;background:var(--fg-dim);border-radius:50%;transition:.15s}.switch input:checked+.slider{background:rgba(76,194,255,.3);border-color:var(--accent)}.switch input:checked+.slider:before{transform:translateX(16px);background:var(--accent)}.card-block{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:16px}.card-block h4{margin:0 0 10px;font-size:13px}.conn-form-row{display:flex;gap:12px;margin-bottom:10px}.filter-group.grow{flex:1 1}.conn-table{width:100%;border-collapse:collapse;font-size:13px}.conn-table th{text-align:left;color:var(--fg-dim);font-weight:500;font-size:11px;padding:6px 10px}.conn-table td,.conn-table th{border-bottom:1px solid var(--border)}.conn-table td{padding:8px 10px}.conn-actions{display:flex;gap:6px;justify-content:flex-end}.conn-kind{font-size:10px;text-transform:uppercase;padding:1px 6px;border-radius:4px}.conn-kind.slack{background:rgba(192,132,252,.18);color:var(--purple)}.conn-kind.teams{background:rgba(76,194,255,.16);color:var(--accent)}.conn-kind.email{background:rgba(34,211,238,.16);color:var(--cyan)}.hist-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.slideover-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:50;display:flex;justify-content:flex-end}.slideover{width:720px;max-width:96vw;height:100%;background:var(--bg);border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:-8px 0 24px rgba(0,0,0,.4)}.slideover-foot,.slideover-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.slideover-head h3{margin:0;font-size:15px}.slideover-foot{border-bottom:none;border-top:1px solid var(--border);gap:8px;justify-content:flex-end}.slideover-body{overflow-y:auto;padding:4px 18px 18px;flex:1 1}.builder-step{padding:14px 0;border-bottom:1px solid var(--border)}.builder-step.preview{border-bottom:none}.step-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;margin-bottom:10px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:rgba(76,194,255,.15);color:var(--accent);font-size:11px}.builder-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.builder-grid.three{grid-template-columns:1fr 1fr 1fr}.builder-step .filter-group{margin-bottom:10px;display:flex;flex-direction:column;gap:4px}.builder-step label{font-size:11px;color:var(--fg-dim)}.builder-step input,.builder-step select,.builder-step textarea{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:13px;width:100%}.builder-step textarea{resize:vertical}.builder-step textarea,.topic-select{font-family:ui-monospace,Menlo,monospace}.picked-topic,.topic-select{font-size:11px}.picked-topic{color:var(--cyan);margin-top:4px;word-break:break-all}.dur-input{display:flex;gap:4px}.dur-input input{flex:1 1}.dur-input select{width:56px;flex-shrink:0}.conn-checks{gap:6px}.conn-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;padding:6px 8px;border:1px solid var(--border);border-radius:6px}.conn-check.on{border-color:rgba(76,194,255,.4);background:rgba(76,194,255,.06)}.inline-check{display:flex;align-items:center;gap:8px;font-size:13px;margin:8px 0;cursor:pointer}.preview-card{border-radius:8px;padding:12px;border:1px solid var(--border)}.preview-card.breach{border-color:rgba(248,113,113,.5);background:rgba(248,113,113,.07)}.preview-card.calm{border-color:rgba(74,222,128,.4);background:rgba(74,222,128,.05)}.preview-val{display:flex;flex-direction:column}.preview-val strong{font-size:24px}.preview-verdict{font-size:13px;margin:6px 0;font-weight:600}.preview-card.breach .preview-verdict{color:var(--red)}.preview-card.calm .preview-verdict{color:var(--green)}.slideover-body.simple{padding:24px 26px 28px}.advanced-block .filter-group,.slideover-body.simple>.filter-group{display:flex;flex-direction:column;align-items:stretch;text-align:left;gap:9px;margin-bottom:28px;width:100%}.slideover-body.simple>.filter-group>label{font-size:11px;font-weight:600;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.04em;text-align:left}.slideover-body.simple input:not([type=checkbox]),.slideover-body.simple select,.slideover-body.simple textarea{background:var(--bg-3);color:var(--fg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;width:100%;box-sizing:border-box}.slideover-body.simple input:not([type=checkbox]):focus,.slideover-body.simple select:focus,.slideover-body.simple textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(76,194,255,.15)}.conn-checks{display:flex;flex-direction:column;gap:10px}.channel-card{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg-2);cursor:pointer;transition:border-color .12s,background .12s}.channel-card:hover{border-color:var(--fg-dim)}.channel-card.on{border-color:var(--accent);background:rgba(76,194,255,.08)}.channel-card .conn-kind{flex:0 0 auto}.channel-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1}.channel-name{font-size:13px;font-weight:600;color:var(--fg)}.channel-sub{font-size:11px;color:var(--fg-dim);font-family:ui-monospace,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-tick{flex:0 0 auto;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:transparent}.channel-tick.on{background:var(--accent);border-color:var(--accent);color:#04121c}.slideover-body.simple textarea{resize:vertical;font-family:ui-monospace,Menlo,monospace;line-height:1.5}.topic-search{position:relative;display:flex;align-items:center}.topic-search .topic-search-icon{position:absolute;left:11px;color:var(--fg-dim);font-size:15px;pointer-events:none}.slideover-body.simple .topic-search input{padding-left:32px;padding-right:32px}.topic-search-clear{position:absolute;right:8px;background:transparent;border:none;cursor:pointer;color:var(--fg-dim);font-size:12px;padding:4px}.topic-search-clear:hover{color:var(--fg)}.topic-list{margin-top:8px;max-height:240px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;background:var(--bg-2)}.topic-empty{padding:18px 14px;text-align:center;color:var(--fg-dim);font-size:12px}.topic-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:none;border-bottom:1px solid var(--border);padding:9px 12px;cursor:pointer;color:var(--fg)}.topic-item:last-child{border-bottom:none}.topic-item:hover{background:var(--bg-3)}.topic-item.on{background:rgba(76,194,255,.12)}.topic-item-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1}.topic-item-name{font-size:13px;font-weight:600;color:var(--fg);font-family:ui-monospace,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-item-name mark{background:rgba(250,204,21,.35);color:var(--fg);border-radius:2px;padding:0 1px}.topic-item-path{font-size:10.5px;color:var(--fg-dim);direction:rtl;text-align:left}.topic-item-path,.topic-item-val{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-item-val{flex:0 0 auto;font-size:12px;font-weight:600;color:var(--cyan);font-family:ui-monospace,Menlo,monospace;background:rgba(34,211,238,.12);border-radius:5px;padding:2px 7px;max-width:110px}.topic-item-val.txt{color:var(--fg-dim);background:var(--bg-3)}.topic-item-check{flex:0 0 auto;color:var(--accent);font-weight:700}.slideover-body.simple .hint,.slideover-body.simple .picked-topic{text-align:left}.cond-type{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.cond-chip{background:var(--bg-3);color:var(--fg-dim);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:12px;cursor:pointer;transition:.12s}.cond-chip:hover{color:var(--fg);border-color:var(--fg-dim)}.cond-chip.on{background:rgba(76,194,255,.15);color:var(--accent);border-color:var(--accent)}.thresh-row{display:flex;align-items:center;gap:8px}.thresh-row select{flex:0 0 140px}.thresh-row input{flex:1 1;min-width:0}.thresh-and{color:var(--fg-dim);font-size:12px;flex-shrink:0}.preview-inline{margin-top:8px;font-size:12px;padding:8px 12px;border-radius:8px;border:1px solid transparent;text-align:left}.preview-inline strong{font-size:15px;margin:0 3px}.preview-inline.breach{background:rgba(248,113,113,.1);color:var(--red);border-color:rgba(248,113,113,.3)}.preview-inline.calm{background:rgba(74,222,128,.08);color:var(--green);border-color:rgba(74,222,128,.3)}.advanced-toggle{background:transparent;border:none;color:var(--fg-dim);cursor:pointer;font-size:12px;padding:8px 0;margin-top:2px;text-align:left;width:100%}.advanced-toggle:hover{color:var(--accent)}.advanced-block{border-top:1px solid var(--border);padding-top:18px;margin-top:6px}.advanced-block label{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.04em}.advanced-block .builder-grid{margin-bottom:14px}.advanced-block .builder-grid .filter-group{margin-bottom:0}.advanced-block .inline-check{text-align:left}.login-wrap{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;overflow:hidden;background:radial-gradient(900px 500px at 50% -10%,rgba(76,194,255,.1),transparent 60%),radial-gradient(700px 500px at 110% 110%,rgba(34,211,238,.07),transparent 55%),var(--bg)}.login-glow{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(560px 380px at 50% 42%,#000 0,transparent 75%);mask-image:radial-gradient(560px 380px at 50% 42%,#000 0,transparent 75%);opacity:.25;pointer-events:none}.login-card{position:relative;z-index:1;width:100%;max-width:460px;background:linear-gradient(180deg,rgba(26,31,39,.92),rgba(17,20,26,.92));border:1px solid var(--border);border-radius:16px;padding:44px 44px 36px;display:flex;flex-direction:column;gap:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 28px 70px -24px rgba(0,0,0,.75);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;color:#04141c;background:linear-gradient(135deg,var(--accent),var(--cyan));box-shadow:0 6px 18px -6px rgba(76,194,255,.7)}.login-logo svg{width:26px;height:26px}.login-brand-text{display:flex;flex-direction:column;line-height:1.15}.login-brand-name{font-size:20px;font-weight:700;letter-spacing:.5px;color:var(--fg)}.login-brand-sub{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--fg-dim)}.login-title{margin:8px 0 0;font-size:22px;font-weight:700;color:var(--fg)}.login-sub{margin:0 0 10px;font-size:13px;color:var(--fg-dim)}.login-label{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--fg-dim)}.login-input{width:100%;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:8px;padding:13px 14px;font:inherit;font-size:14px;text-transform:none;letter-spacing:normal;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.login-input::placeholder{color:var(--fg-dim);opacity:.55}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(76,194,255,.16)}.login-pw{position:relative}.login-pw .login-input{padding-right:58px}.login-pw-toggle{position:absolute;top:50%;right:8px;transform:translateY(-50%);background:transparent;border:none;color:var(--fg-dim);font:inherit;font-size:11px;text-transform:uppercase;letter-spacing:.4px;cursor:pointer;padding:4px 6px}.login-pw-toggle:hover{color:var(--accent)}.login-error{color:var(--red);font-size:12px;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.3);border-radius:7px;padding:8px 10px}.login-btn{margin-top:8px;background:linear-gradient(135deg,var(--accent),var(--cyan));color:#04141c;border:none;border-radius:9px;padding:14px 12px;font:inherit;font-size:14px;font-weight:700;letter-spacing:.3px;cursor:pointer;transition:filter .15s ease,transform .05s ease}.login-btn:hover:not(:disabled){filter:brightness(1.07)}.login-btn:active:not(:disabled){transform:translateY(1px)}.login-btn:disabled{opacity:.6;cursor:default}.login-foot{margin:12px 0 0;text-align:center;font-size:11px;color:var(--fg-dim);opacity:.8}.logout-btn{background:var(--bg-3);color:var(--fg-dim);border:1px solid var(--border);border-radius:4px;padding:4px 12px;font:inherit;font-size:inherit;cursor:pointer;white-space:nowrap}.logout-btn:hover:not(:disabled){color:var(--fg);border-color:var(--accent)}.logout-btn:disabled{opacity:.6;cursor:default}