/* ============================================================
   DARKSTAR — CAD DISPATCH CONSOLE THEME
   Drop-in CSS replacement. All class names, IDs, animations,
   and structural rules preserved.
   ============================================================ */

:root{
  --bg:#07090c;
  --panel:#0c1014;
  --border:#1a2030;
  --grid:#111820;
  --accent:#53b7ff;
  --green:#3dbc72;
  --yellow:#d4a843;
  --red:#d44040;
  --muted:#6b7a8d;
  --text:#b8c4d0;
  --bright:#dce4ec;
  --mono:'JetBrains Mono',monospace;
  --sans:'Inter',sans-serif;
  --hdr-grad:linear-gradient(to bottom,#131b24,#0d1319);
  --radius:2px
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--sans);font-size:13px}
body{display:flex;flex-direction:column}
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 4px,rgba(0,0,0,0.025) 4px,rgba(0,0,0,0.025) 5px);pointer-events:none;z-index:9000}

/* TOP BAR */
#topbar{flex:0 0 auto;display:flex;align-items:stretch;background:var(--hdr-grad);border-bottom:1px solid var(--border);height:42px}
#tb-left{display:flex;align-items:center;gap:10px;padding:0 16px;border-right:1px solid var(--border);min-width:180px}
.wordmark{font-family:var(--sans);font-size:15px;font-weight:700;color:var(--accent);letter-spacing:3px;text-transform:uppercase}
.tb-sub{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}
#tb-center{flex:1;display:flex;align-items:center;justify-content:center;gap:20px;font-family:var(--mono);font-size:11px}
.tb-stat{color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.tb-stat span{color:var(--bright);font-weight:700;font-variant-numeric:tabular-nums}
.tb-sep{color:var(--border)}
#tb-right{display:flex;align-items:center;gap:12px;padding:0 16px;border-left:1px solid var(--border)}
#tb-clock{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--accent);letter-spacing:2px;font-variant-numeric:tabular-nums}
.tb-meta{font-family:var(--mono);font-size:9px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}

/* TAB BAR */
#tabbar{flex:0 0 auto;display:flex;background:var(--panel);border-bottom:1px solid var(--border)}
.tabn{padding:9px 20px;font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s,background .15s;user-select:none;text-transform:uppercase}
.tabn:hover{color:var(--text);background:rgba(83,183,255,0.04)}
.tabn.active{color:var(--accent);border-bottom-color:var(--accent);background:#0a1018}

/* CONTENT */
#content-area{flex:1 1 auto;overflow-y:auto;overflow-x:hidden}
.pane{display:none;padding:10px}
.pane.active{display:block}

/* BOTTOM STRIP */
#bottomstrip{flex:0 0 auto;display:flex;align-items:center;gap:0;background:var(--panel);border-top:1px solid var(--border);height:24px;padding:0 12px;font-family:var(--mono);font-size:9px;color:var(--muted);overflow:hidden;font-variant-numeric:tabular-nums}
.bs-item{padding:0 12px;border-right:1px solid var(--border)}
.bs-item:last-child{border-right:none}
.bs-item span{color:var(--text)}
.bbar{display:inline-block;width:60px;height:5px;background:var(--border);vertical-align:middle;margin:0 4px;border-radius:var(--radius)}
.bbar-fill{display:block;height:100%;background:var(--accent);transition:width .5s;border-radius:var(--radius)}

/* SECTION HEADERS */
.sec-hdr{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;padding:0 0 5px 0;margin-top:12px;border-bottom:1px solid var(--grid)}
.sec-hdr:first-child{margin-top:0}

/* ===== LIVE TAB ===== */
.sdr-strip{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}
.sdr-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;display:flex;align-items:center;gap:12px}
.sdr-ind{width:7px;height:7px;background:var(--muted);flex-shrink:0;border-radius:1px}
.sdr-ind.up{background:var(--green)}
.sdr-name{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--bright);text-transform:uppercase}
.sdr-serial{font-family:var(--mono);font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}
.sdr-systems{font-size:10px;color:var(--muted);margin-top:2px}
.sdr-badge{font-family:var(--mono);font-size:10px;font-weight:700;margin-left:auto;padding:2px 8px;background:var(--bg);border-radius:var(--radius);font-variant-numeric:tabular-nums}
.sdr-badge.up{color:var(--green);border:1px solid var(--green)}
.sdr-badge.dn{color:var(--red);border:1px solid var(--red)}

.sys-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px}
.sys-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}
.sys-card-hdr{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.dot{width:7px;height:7px;flex-shrink:0;border-radius:1px}
.dot.green{background:var(--green)}
.dot.yellow{background:var(--yellow)}
.dot.red{background:var(--red)}
.dot.grey{background:#384050}
@keyframes pulse-g{0%{box-shadow:0 0 0 0 rgba(61,188,114,.5)}70%{box-shadow:0 0 0 5px rgba(61,188,114,0)}100%{box-shadow:0 0 0 0 rgba(61,188,114,0)}}
@keyframes pulse-y{0%{box-shadow:0 0 0 0 rgba(212,168,67,.5)}70%{box-shadow:0 0 0 5px rgba(212,168,67,0)}100%{box-shadow:0 0 0 0 rgba(212,168,67,0)}}
.dot.green.pulse{animation:pulse-g 2s infinite}
.dot.yellow.pulse{animation:pulse-y 2s infinite}
.sys-name{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--bright)}
.sys-sdr{font-family:var(--mono);font-size:10px;color:var(--muted);margin-left:auto;font-variant-numeric:tabular-nums}
.sys-row{display:flex;justify-content:space-between;font-size:11px;padding:1px 0}
.sys-lbl{color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:0.3px}
.sys-val{font-family:var(--mono);color:var(--text);font-variant-numeric:tabular-nums}
.sys-val.green{color:var(--green)}
.sys-val.yellow{color:var(--yellow)}
.sys-val.red{color:var(--red)}
.sys-status{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.sys-status.ACTIVE{color:var(--green)}
.sys-status.DEGRADED{color:var(--yellow)}
.sys-status.WEAK{color:var(--yellow)}
.sys-status.NOLOCK{color:var(--red)}
.sys-status.RECEIVING{color:var(--yellow, #f0ad4e);animation:pulse-yellow 1.5s infinite}
@keyframes pulse-yellow{0%,100%{opacity:1}50%{opacity:.5}}

/* LIVE TICKER */
.live-dot{display:inline-block;width:7px;height:7px;border-radius:1px;background:var(--red);margin-left:6px;animation:pulse-red 1.5s infinite}
.ticker-hdr{display:grid;grid-template-columns:70px 72px 120px 50px 1fr 1fr 60px;gap:6px;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);border-bottom:1px solid var(--border);background:var(--hdr-grad);text-transform:uppercase}
.ticker-row{display:grid;grid-template-columns:70px 72px 120px 50px 1fr 1fr 60px;gap:6px;padding:4px 8px;border-bottom:1px solid var(--grid);font-size:11px}
.ticker-row:hover{background:rgba(83,183,255,0.04)}
.ticker-row.ticker-new{animation:flash-in 2s ease}
.tg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:6px 0}
.tg-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:10px;transition:all 0.3s ease;opacity:0.4}
.tg-card.active{opacity:1;border-color:var(--green);box-shadow:0 0 10px rgba(61,188,114,0.12)}
.tg-card.active.home-node{border-color:var(--accent);box-shadow:0 0 10px rgba(83,183,255,0.12)}
.tg-card.active.corrine-node{border-color:#d47030;box-shadow:0 0 10px rgba(212,112,48,0.12)}
.tg-card.emergency{border-color:var(--red)!important;box-shadow:0 0 14px rgba(212,64,64,0.3)!important;animation:emerg-pulse 1.5s infinite}
@keyframes emerg-pulse{0%{box-shadow:0 0 14px rgba(212,64,64,0.3)}50%{box-shadow:0 0 22px rgba(212,64,64,0.55)}100%{box-shadow:0 0 14px rgba(212,64,64,0.3)}}
.tg-card-tag{font-size:12px;font-weight:700;color:var(--yellow);letter-spacing:0.5px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tg-card-dept{font-size:9px;color:var(--muted);letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}
.tg-card-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;font-variant-numeric:tabular-nums}
.tg-card-node{font-size:9px;font-weight:700;padding:1px 5px;border:1px solid;letter-spacing:0.5px;border-radius:var(--radius);text-transform:uppercase}
.tg-card-node.home{color:var(--accent);border-color:var(--accent)}
.tg-card-node.corrine{color:#d47030;border-color:#d47030}
.tg-card-time{color:var(--muted);font-variant-numeric:tabular-nums}
.tg-card-dur{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}
.tg-card-status{font-size:9px;font-weight:700;letter-spacing:1px;margin-top:4px;text-transform:uppercase}
#monitor-tg-grid{column-count:3;column-gap:16px}
.mon-dept-hdr{break-inside:avoid;break-after:avoid}
.mon-tg-row{break-inside:avoid}
.mon-dept-group{break-inside:avoid;margin-bottom:10px}
.mon-dept-group.collapsed .mon-tg-rows{display:none}
.mon-collapse-btn{background:transparent;border:0;cursor:pointer;padding:0 6px;color:var(--muted);font-size:10px;min-width:24px;min-height:24px}
.mon-dept-group.collapsed .mon-collapse-btn{color:var(--accent)}
.mon-tg-label{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.mon-tg-friendly{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mon-tg-raw{font-size:10px;color:var(--muted);font-family:var(--mono);opacity:0.6}
.svc-law{color:#53b7ff}.svc-law::before{content:"\25aa ";font-size:10px}
.svc-fire{color:#e14e4e}.svc-fire::before{content:"\25b2 ";font-size:10px}
.svc-ems{color:#3dbc72}.svc-ems::before{content:"\271a ";font-size:10px}
.svc-dps{color:#f4b942}.svc-dps::before{content:"\25c6 ";font-size:10px}
.svc-tribal{color:#a07855}.svc-tribal::before{content:"\25cf ";font-size:10px}
.svc-fed{color:#808080}.svc-fed::before{content:"\25a0 ";font-size:10px}
.svc-mutual{color:#b071e8}.svc-mutual::before{content:"\25c8 ";font-size:10px}
.svc-other{color:#888}
.tg-card-status.speaking{color:var(--green)}
.tg-card-status.idle{color:var(--muted)}
.tg-card-tx{font-size:10px;color:var(--text);margin-top:4px;font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-height:16px}
@keyframes flash-in{0%{background:rgba(83,183,255,0.2)}100%{background:transparent}}
.t-time{font-family:var(--mono);color:var(--muted);font-variant-numeric:tabular-nums}
.t-src{font-family:var(--mono);font-size:9px;font-weight:700;padding:1px 5px;border:1px solid var(--border);letter-spacing:.5px;text-align:center;align-self:center;border-radius:var(--radius);text-transform:uppercase}
.t-src.sdr0{color:var(--muted);border-color:#2a3545}
.t-src.sdr1{color:var(--muted);border-color:#2a3545}
.t-src.home{color:var(--muted);border-color:#2a3545}
.t-src.corrine{color:var(--muted);border-color:#2a3545}
.t-src.scanner{color:var(--muted);border-color:#2a3545}
.t-sys{font-family:var(--mono);color:var(--accent);font-size:10px;font-variant-numeric:tabular-nums}
.t-tg{font-family:var(--mono);color:var(--yellow);font-variant-numeric:tabular-nums}
.t-tag{color:var(--text)}
.t-tx{font-family:var(--mono);font-size:10px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.t-dur{font-family:var(--mono);color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}


/* Department color coding */
.dept-police{color:#6db3e8}
.dept-fire{color:#d4b545}
.dept-county{color:#d48040}
.dept-dps{color:#50b860}
.dept-mutual{color:#a860d0}
.dept-other{color:var(--text)}

/* ===== CALLS TAB ===== */
.calls-controls{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;align-items:center}
.calls-controls select,.calls-controls input{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:4px 8px;font-size:11px;font-family:var(--mono);outline:none}
.calls-controls select:focus,.calls-controls input:focus{border-color:var(--accent)}
.btn{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:4px 12px;font-size:11px;font-family:var(--mono);font-weight:600;cursor:pointer;letter-spacing:.5px;text-transform:uppercase;transition:border-color .15s,color .15s}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{border-color:var(--accent);color:var(--accent)}
.calls-hdr{display:grid;grid-template-columns:70px 72px 130px 55px 120px 100px 1fr 28px 55px 60px;gap:4px;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);background:var(--hdr-grad);border:1px solid var(--border);border-radius:var(--radius);position:sticky;top:0;cursor:pointer;z-index:10;text-transform:uppercase}
.calls-hdr div:hover{color:var(--text)}
.calls-hdr .sort-asc::after{content:' \2191'}
.calls-hdr .sort-desc::after{content:' \2193'}
.call-row-main{display:grid;grid-template-columns:70px 72px 130px 55px 120px 100px 1fr 28px 55px 60px;gap:4px;padding:4px 8px;border-bottom:1px solid var(--grid);font-size:11px;cursor:pointer;align-items:center}
.c-source{font-family:var(--mono);font-size:9px;font-weight:700;padding:1px 5px;border:1px solid var(--border);letter-spacing:.5px;text-align:center;border-radius:var(--radius);text-transform:uppercase}
.c-source.sdr0-x{color:var(--muted);border-color:#2a3545}
.c-source.sdr1{color:var(--muted);border-color:#2a3545}
.c-source.home{color:var(--muted);border-color:#2a3545}
.c-source.corrine{color:var(--muted);border-color:#2a3545}
.c-source.scanner{color:var(--muted);border-color:#2a3545}
.c-tx{font-family:var(--mono);font-size:10px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.call-row-main:hover{background:rgba(83,183,255,0.04)}
.call-row-main.expanded{background:#0e1520;border-left:2px solid var(--accent)}
.c-time{font-family:var(--mono);color:var(--muted);font-variant-numeric:tabular-nums}
.c-sys{font-family:var(--mono);font-size:10px;color:var(--accent);font-variant-numeric:tabular-nums}
.c-tg{font-family:var(--mono);color:var(--yellow);font-variant-numeric:tabular-nums}
.c-tag{color:var(--text)}
.c-dept{color:var(--muted);font-size:10px}
.c-dur{font-family:var(--mono);color:var(--muted);font-variant-numeric:tabular-nums}
.c-freq{font-family:var(--mono);font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}
.c-play-btn{font-size:10px;font-weight:600;color:var(--accent);font-family:var(--mono);letter-spacing:.5px;text-transform:uppercase}
.call-detail{display:none;background:#080c12;border-bottom:1px solid var(--border);padding:10px 14px;min-height:54px}
.detail-meta{display:flex;flex-wrap:wrap;gap:14px;font-family:var(--mono);font-size:10px;color:var(--muted);margin-bottom:8px;font-variant-numeric:tabular-nums}
.detail-meta span{display:flex;gap:4px}
.detail-meta .dv{color:var(--text)}
.emerg-badge{color:var(--red);font-weight:700;font-size:10px;letter-spacing:.5px;text-transform:uppercase}
.call-row-main.emergency{background:rgba(212,64,64,0.07);border-left:3px solid var(--red)}
.call-row-main.emergency:hover{background:rgba(212,64,64,0.12)}
.call-row-main.emergency .c-time{color:var(--red)}
.call-row-main.emergency .c-tag{color:var(--red)}
.ticker-row.emergency{background:rgba(212,64,64,0.07);border-left:3px solid var(--red)}
.ticker-row.emergency .t-time{color:var(--red)}
.ticker-row.emergency .t-tag{color:var(--red)}
@keyframes pulse-red{0%{opacity:1}50%{opacity:.5}100%{opacity:1}}
.emerg-flash{animation:pulse-red 1.5s infinite}
.audio-wrap{display:flex;align-items:center;gap:10px;min-height:36px}
audio{height:28px;width:240px;filter:invert(1) sepia(1) saturate(5) hue-rotate(175deg)}
.audio-label{font-family:var(--mono);font-size:10px;padding:2px 6px;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius);text-transform:uppercase}
.audio-label.norm{border-color:var(--green);color:var(--green)}
.pagination{display:flex;align-items:center;gap:6px;padding:8px 0;font-family:var(--mono);font-size:11px;font-variant-numeric:tabular-nums}
.page-info{color:var(--muted)}

/* ===== HEALTH TAB ===== */
.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:6px;margin-bottom:12px}
.health-grid.recorder-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}
.health-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}
.recorder-card{min-width:0}
.recorder-bars{display:grid;gap:4px 2px;align-items:end;min-height:52px;padding-top:10px}
.recorder-bar{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:0}
.health-card-hdr{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--grid)}
.health-card h3{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--bright);text-transform:uppercase}
.health-card .sdr-tag{font-family:var(--mono);font-size:10px;color:var(--muted);margin-left:auto;font-variant-numeric:tabular-nums}
.hrow{display:flex;justify-content:space-between;padding:2px 0;font-size:11px}
.hlbl{color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:0.3px}
.hval{font-family:var(--mono);color:var(--text);font-variant-numeric:tabular-nums}
.tg-list{margin-top:6px;padding-top:6px;border-top:1px solid var(--grid)}
.tg-item{display:flex;justify-content:space-between;font-size:10px;font-family:var(--mono);padding:1px 0;color:var(--muted);font-variant-numeric:tabular-nums}
.tg-item .tg-name{color:var(--text)}
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.svc-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px}
.svc-name{font-size:10px;font-weight:600;letter-spacing:.5px;color:var(--muted);margin-bottom:5px;text-transform:uppercase}

/* ===== STATS TAB ===== */
.stats-ctrl{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.stats-ctrl label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.3px}
.kpi-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px;margin-bottom:12px}
.kpi{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:10px}
.kpi-val{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.kpi-lbl{font-size:10px;letter-spacing:1px;color:var(--muted);margin-top:3px;text-transform:uppercase}
.bar-chart{margin-top:8px}
.bar-row{display:flex;align-items:center;gap:8px;padding:2px 0;font-size:11px}
.bar-lbl{width:140px;color:var(--text);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.bar-fill{height:12px;background:var(--accent);opacity:.6;min-width:2px;transition:width .3s;border-radius:var(--radius)}
.bar-count{font-family:var(--mono);font-size:10px;color:var(--muted);white-space:nowrap;margin-left:4px;font-variant-numeric:tabular-nums}
.hour-hist{display:flex;align-items:flex-end;gap:2px;height:80px;padding-top:4px}
.hour-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;min-width:0}
.hour-bar{width:100%;background:var(--accent);opacity:.5;min-height:2px;transition:height .3s;border-radius:var(--radius) var(--radius) 0 0}
.hour-lbl{font-family:var(--mono);font-size:8px;color:var(--muted);margin-top:2px;overflow:hidden;width:100%;text-align:center;font-variant-numeric:tabular-nums}
.stats-tbl{width:100%;border-collapse:collapse;font-size:11px}
.stats-tbl th{text-align:left;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);border-bottom:1px solid var(--border);text-transform:uppercase}
.stats-tbl td{padding:4px 8px;border-bottom:1px solid var(--grid);font-family:var(--mono);font-variant-numeric:tabular-nums}
.stats-tbl tr:hover td{background:rgba(83,183,255,0.04)}
.dur-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}
.dur-cell{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;text-align:center}
.dur-val{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.dur-lbl{font-size:10px;color:var(--muted);margin-top:2px;text-transform:uppercase}

/* ===== SYSTEMS TAB ===== */
.sys-ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:8px}
.sys-ref-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px}
.sys-ref-name{font-size:13px;font-weight:700;letter-spacing:.5px;color:var(--bright);margin-bottom:2px;text-transform:uppercase}
.sys-ref-note{font-size:10px;color:var(--muted);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--grid)}
.sys-ref-row{display:flex;gap:8px;font-size:11px;padding:2px 0}
.sys-ref-lbl{color:var(--muted);width:90px;flex-shrink:0;text-transform:uppercase;font-size:10px;letter-spacing:0.3px}
.sys-ref-val{font-family:var(--mono);color:var(--text);font-variant-numeric:tabular-nums}
.cc-list{font-family:var(--mono);font-size:10px;color:var(--accent);font-variant-numeric:tabular-nums}
.tg-ref-list{margin-top:8px;padding-top:8px;border-top:1px solid var(--grid);max-height:160px;overflow-y:auto}
.tg-ref-row{display:grid;grid-template-columns:55px 90px 1fr;gap:4px;font-family:var(--mono);font-size:10px;padding:2px 0;border-bottom:1px solid var(--grid);font-variant-numeric:tabular-nums}
.tg-ref-row .tr-tg{color:var(--yellow)}
.tg-ref-row .tr-tag{color:var(--text)}
.tg-ref-row .tr-dept{color:var(--muted)}
.tg-count-badge{font-family:var(--mono);font-size:10px;padding:2px 6px;border:1px solid var(--border);color:var(--muted);float:right;border-radius:var(--radius);font-variant-numeric:tabular-nums}

/* ===== TRANSCRIPTION ===== */
.transcription-box{font-family:var(--mono);font-size:12px;color:var(--text);background:var(--bg);padding:8px;border-left:2px solid var(--accent);margin-top:8px;white-space:pre-wrap;word-wrap:break-word;border-radius:0 var(--radius) var(--radius) 0}
.transcription-box.pending{color:var(--muted);font-style:italic}
.tx-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px}
.tx-bar-outer{width:100%;height:16px;background:var(--bg);border:1px solid var(--border);margin:8px 0;border-radius:var(--radius)}
.tx-bar-inner{height:100%;background:var(--accent);transition:width 1s ease;border-radius:var(--radius)}
.tx-bar-inner.done{background:var(--green)}
.tx-stats{display:flex;gap:24px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:6px;font-variant-numeric:tabular-nums}
.tx-stats span{color:var(--bright);font-weight:700}
#stats-encrypted .stats-tbl{margin-top:8px}

/* ===== MAP TAB ===== */
#pane-map{padding:0!important}
#map-container{width:100%;height:calc(100vh - 120px);position:relative;display:flex}

details summary{list-style:none}
details summary::-webkit-details-marker{display:none}
details summary::before{content:'\25B8 ';font-size:10px}
details[open] summary::before{content:'\25BE '}
.map-filter-cat{font-size:9px;font-weight:600;letter-spacing:1.5px;color:var(--muted);padding:8px 10px 4px;border-bottom:1px solid var(--grid);text-transform:uppercase}
#map-sidebar{width:200px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto;padding:0}
.map-sb-hdr{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--muted);padding:8px 10px 4px;border-bottom:1px solid var(--grid);text-transform:uppercase}
.map-filter-group{padding:4px 0}
.map-filter-cat{font-size:9px;font-weight:600;letter-spacing:1px;color:var(--muted);padding:6px 10px 2px;text-transform:uppercase}
.map-filter-item{display:flex;align-items:center;gap:6px;padding:2px 10px;font-size:11px;cursor:pointer;user-select:none}
.map-filter-item:hover{background:rgba(83,183,255,0.04)}
.map-filter-item input[type=checkbox]{accent-color:var(--accent);margin:0;cursor:pointer}
.map-filter-item .mf-swatch{width:10px;height:10px;flex-shrink:0;border:1px solid rgba(255,255,255,0.15);border-radius:1px}
.map-filter-item .mf-label{color:var(--text);font-family:var(--mono);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.map-filter-item .mf-count{margin-left:auto;font-family:var(--mono);font-size:9px;color:var(--muted);font-variant-numeric:tabular-nums}
#leaflet-map{flex:1;height:100%;background:var(--bg)}
.beat-label{background:none!important;border:none!important;box-shadow:none!important;color:rgba(74,144,217,0.45)!important;font-size:10px!important;font-weight:600!important;font-family:var(--mono)!important;text-shadow:0 0 3px rgba(0,0,0,0.8)!important;pointer-events:none!important}
.map-count-badge{position:absolute;top:10px;right:10px;z-index:1000;background:rgba(12,16,20,0.92);border:1px solid var(--border);border-radius:var(--radius);padding:5px 12px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--accent);letter-spacing:1px;font-variant-numeric:tabular-nums}
.leaflet-popup-content-wrapper{background:var(--panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:2px!important;box-shadow:0 2px 10px rgba(0,0,0,.6)!important}
.leaflet-popup-tip{background:var(--panel)!important}
.leaflet-popup-content{font-family:var(--mono);font-size:11px;margin:8px 12px!important;line-height:1.5}
.leaflet-popup-content .popup-time{color:var(--accent);font-weight:700;font-variant-numeric:tabular-nums}
.leaflet-popup-content .popup-tag{color:var(--yellow)}
.leaflet-popup-content .popup-dept{color:var(--muted);font-size:10px}
.leaflet-popup-content .popup-tx{color:var(--text);font-size:10px;margin-top:4px;border-top:1px solid var(--grid);padding-top:4px}
.leaflet-popup-close-button{color:var(--muted)!important}
.leaflet-control-layers{background:var(--panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:2px!important}
.leaflet-control-layers label{color:var(--text)!important;font-family:var(--mono);font-size:11px}
.leaflet-control-zoom a{background:var(--panel)!important;color:var(--text)!important;border-color:var(--border)!important}
.district-tooltip{background:var(--panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:2px!important;font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 8px!important}
.leaflet-control-layers-list{max-height:400px;overflow-y:auto}
@keyframes map-pulse-red{0%{opacity:1;stroke-width:2}50%{opacity:.4;stroke-width:5}100%{opacity:1;stroke-width:2}}
.emergency-marker{animation:map-pulse-red 1.5s infinite}
@keyframes map-flash{0%{opacity:1}50%{opacity:0.3}100%{opacity:1}}
.marker-flash{animation:map-flash 0.5s 3}

/* ===== AIRCRAFT ===== */
.aircraft-icon{font-size:22px;color:var(--yellow);text-shadow:0 0 6px rgba(212,168,67,0.7),0 0 14px rgba(212,168,67,0.35);filter:drop-shadow(0 0 3px rgba(212,168,67,0.5))}
.aircraft-icon div{transition:transform 0.3s linear}
.aircraft-label{font-family:var(--mono);font-size:9px;color:var(--yellow);white-space:nowrap;text-shadow:0 0 3px #000,0 0 3px #000,0 0 6px #000}


/* ===== MONITOR TAB ===== */
.mon-dept-hdr{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--muted);padding:8px 0 4px;border-bottom:1px solid var(--grid);margin-top:10px;text-transform:uppercase}
.mon-dept-hdr:first-child{margin-top:0}
.mon-tg-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid var(--grid)}
.mon-tg-row:hover{background:rgba(83,183,255,0.04)}
.mon-tg-row.active-tg{background:rgba(61,188,114,0.05)}
.mon-toggle{position:relative;width:36px;height:20px;cursor:pointer;flex-shrink:0}
.mon-toggle input{opacity:0;width:0;height:0}
.mon-slider{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--border);transition:.2s;border-radius:var(--radius)}
.mon-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background:var(--muted);transition:.2s;border-radius:1px}
.mon-toggle input:checked + .mon-slider{background:var(--green)}
.mon-toggle input:checked + .mon-slider:before{transform:translateX(16px);background:var(--bright)}
.mon-tg-name{font-size:12px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mon-tg-num{font-family:var(--mono);font-size:10px;color:var(--muted);width:50px;flex-shrink:0;font-variant-numeric:tabular-nums}
.mon-tg-node{font-family:var(--mono);font-size:9px;font-weight:700;padding:1px 5px;border:1px solid;letter-spacing:0.5px;border-radius:var(--radius);text-transform:uppercase}
.mon-tg-last{font-family:var(--mono);font-size:10px;color:var(--muted);width:70px;flex-shrink:0;text-align:right;font-variant-numeric:tabular-nums}

/* ===== SCANNER TAB (BCD536HP) ===== */
.sc-live-strip{display:grid;grid-template-columns:1fr 260px;gap:8px;margin-bottom:12px}
.sc-live-main{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px}
.sc-freq-wrap{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--grid)}
.sc-freq-label{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase}
.sc-freq{font-family:var(--mono);font-size:34px;font-weight:700;color:var(--accent);letter-spacing:2px;line-height:1.2;font-variant-numeric:tabular-nums}
.sc-freq-mod{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;text-transform:uppercase}
.sc-info-grid{display:flex;flex-direction:column;gap:2px}
.sc-info-row{display:flex;justify-content:space-between;font-size:11px;padding:2px 0}
.sc-lbl{color:var(--muted);font-size:10px;letter-spacing:.5px;text-transform:uppercase}
.sc-val{font-family:var(--mono);color:var(--text);font-variant-numeric:tabular-nums}
.sc-val-accent{color:var(--accent)}
.sc-val-yellow{color:var(--yellow)}
.sc-live-side{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px;align-items:center}
.sc-status-box{display:flex;align-items:center;gap:8px;padding:5px 14px;width:100%;justify-content:center}
.sc-status-ind{width:9px;height:9px;flex-shrink:0;background:#384050;border-radius:1px}
.sc-status-ind.receiving{background:var(--green);animation:pulse-g 1.5s infinite}
.sc-status-ind.scanning{background:var(--yellow);animation:pulse-y 2s infinite}
.sc-status-ind.offline{background:var(--red)}
.sc-status-text{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.sc-status-text.receiving{color:var(--green)}
.sc-status-text.scanning{color:var(--yellow)}
.sc-status-text.offline{color:var(--red)}
.sc-signal-wrap{text-align:center;width:100%}
.sc-signal-label{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--muted);margin-bottom:4px;text-transform:uppercase}
.sc-signal-bars{display:flex;gap:3px;justify-content:center;align-items:flex-end;height:30px}
.sc-bar{width:14px;background:var(--border);transition:background .2s;border-radius:var(--radius) var(--radius) 0 0}
.sc-bar:nth-child(1){height:10px}
.sc-bar:nth-child(2){height:14px}
.sc-bar:nth-child(3){height:18px}
.sc-bar:nth-child(4){height:24px}
.sc-bar:nth-child(5){height:30px}
.sc-bar.active{background:var(--green)}
.sc-bar.active:nth-child(4){background:var(--yellow)}
.sc-bar.active:nth-child(5){background:var(--red)}
.sc-meta-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px;width:100%}
.sc-meta{text-align:center;background:var(--bg);padding:5px 4px;border-radius:var(--radius)}
.sc-meta-val{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--accent);display:block;font-variant-numeric:tabular-nums}
.sc-meta-lbl{font-size:9px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.sc-model{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:1px;text-align:center;text-transform:uppercase}
.sc-calls-controls{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;align-items:center}
.sc-calls-controls select,.sc-calls-controls input{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:4px 8px;font-size:11px;font-family:var(--mono);outline:none}
.sc-calls-controls select:focus,.sc-calls-controls input:focus{border-color:var(--accent)}
.sc-calls-hdr{display:grid;grid-template-columns:70px 1fr 120px 140px 100px 55px 60px;gap:4px;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);background:var(--hdr-grad);border:1px solid var(--border);border-radius:var(--radius);position:sticky;top:0;z-index:10;text-transform:uppercase}
.sc-call-row{display:grid;grid-template-columns:70px 1fr 120px 140px 100px 55px 60px;gap:4px;padding:4px 8px;border-bottom:1px solid var(--grid);font-size:11px;cursor:pointer;align-items:center}
.sc-call-row:hover{background:rgba(83,183,255,0.04)}
.sc-call-row.expanded{background:#0e1520;border-left:2px solid var(--accent)}
.sc-call-detail{display:none;background:#080c12;border-bottom:1px solid var(--border);padding:10px 14px;min-height:54px}

.empty{padding:28px;text-align:center;color:var(--muted);font-size:12px}

@media(max-width:700px){
  .sdr-strip{grid-template-columns:1fr}
  .sys-grid{grid-template-columns:repeat(2,1fr)}
  .tg-grid{grid-template-columns:repeat(2,1fr)}
  .calls-hdr,.call-row-main{grid-template-columns:60px 55px 1fr 45px 120px 45px 50px}
  .c-source,.c-dept,.c-tx{display:none}
  .svc-grid{grid-template-columns:1fr}
  .dur-grid{grid-template-columns:1fr 1fr}
  #tb-center{display:none}
}


/* LIVE TAB COMPACT OVERRIDES */
#pane-live .sec-hdr{font-size:9px;padding:0 0 3px 0;margin-top:6px}
#pane-live .sdr-strip{gap:3px;margin-bottom:6px}
#pane-live .sdr-card{padding:4px 8px;gap:8px}
#pane-live .sys-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:3px;margin-bottom:6px}
#pane-live .sys-card{padding:4px 7px}
#pane-live .sys-card-hdr{margin-bottom:1px;gap:5px}
#pane-live .sys-name{font-size:10px}
#pane-live .sys-row{font-size:10px;padding:0;line-height:1.4}
#pane-live .sys-lbl{font-size:9px}
#pane-live .tg-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:3px;padding:2px 0}
#pane-live .tg-card{padding:5px 7px}
#pane-live .tg-card-tag{font-size:10px;margin-bottom:1px}
#pane-live .tg-card-dept{font-size:8px;margin-bottom:1px}
#pane-live .tg-card-meta{font-size:9px}
#pane-live .tg-card-tx{font-size:9px;margin-top:2px}
#pane-live #live-scanner-status{padding:5px 10px;margin-bottom:6px}
