/* Dashboard CSS v3 */
:root {
  --bg:#0f1117;--bg-raised:#181b24;--bg-surface:#1e2230;--bg-hover:#252a38;
  --border:#2a2f3e;--border-focus:#4a7cff;
  --text:#e0e4ec;--text-dim:#8b92a5;--text-muted:#5a6178;
  --accent:#4a7cff;--danger:#e53935;--warning:#ffb300;--success:#43a047;--info:#00bcd4;
  --font:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono','Consolas',monospace;
  --topbar-h:44px;--radius:6px;--radius-sm:4px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg);overflow:hidden}
.hidden{display:none !important}

#login-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999}
.login-box{width:360px;background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;padding:40px 32px 32px}
.login-header{text-align:center;margin-bottom:28px}.login-icon{font-size:28px;color:var(--accent);margin-bottom:12px}
.login-header h1{font-size:20px;font-weight:700;margin-bottom:4px}.login-header p{font-size:13px;color:var(--text-dim)}
.login-form label{display:block;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.5px;margin:16px 0 6px}
.login-form input{width:100%;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;outline:none}
.login-form input:focus{border-color:var(--border-focus)}.login-form input::placeholder{color:var(--text-muted)}
#login-btn{width:100%;margin-top:24px;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}
.login-error{margin-top:12px;color:var(--danger);font-size:12px;text-align:center;min-height:18px}

#topbar{height:var(--topbar-h);background:var(--bg-raised);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:10px}
.topbar-icon{color:var(--accent);font-size:16px}.topbar-title{font-weight:700;font-size:14px}
.topbar-sep{color:var(--text-muted);font-size:12px}.topbar-stat{font-size:11px;color:var(--text-dim);font-family:var(--mono)}
.topbar-user{font-size:12px;color:var(--text-dim)}.topbar-link{font-size:12px;color:var(--accent);text-decoration:none;font-weight:500}
.topbar-btn{padding:5px 12px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:11px;cursor:pointer}

#banner{display:flex;gap:8px;padding:8px 16px;background:var(--bg);overflow-x:auto;flex-shrink:0}
.card{flex:1;min-width:115px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;border-top:3px solid var(--border)}
.card-danger{border-top-color:var(--danger)}.card-warning{border-top-color:var(--warning)}
.card-info{border-top-color:var(--info)}.card-accent{border-top-color:var(--accent)}.card-muted{border-top-color:var(--text-muted)}
.card-perm{border-top-color:#9C27B0}
.card-value{font-size:26px;font-weight:700;font-family:var(--mono);line-height:1}
.card-label{font-size:10px;font-weight:600;color:var(--text-dim);margin-top:3px;text-transform:uppercase;letter-spacing:0.3px}
.card-sub{font-size:9px;color:var(--text-muted);margin-top:1px}

#app{height:100vh;display:flex;flex-direction:column}
#main{flex:1;display:flex;overflow:hidden}
#left-panel{flex:1;display:flex;flex-direction:column;min-width:0}
#right-panel{width:380px;min-width:380px;background:var(--bg-raised);border-left:1px solid var(--border);overflow-y:auto;padding:14px}
#right-panel::-webkit-scrollbar{width:5px}#right-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

#filter-bar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-raised);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}
.layer-toggles{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.layer-tog{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--text-dim);cursor:pointer;white-space:nowrap;padding:2px 6px;border:1px solid var(--border);border-radius:3px;background:var(--bg-surface)}
.layer-tog.active{border-color:var(--accent);background:var(--accent);color:#fff}
.layer-tog input{display:none}
.filter-sep{width:1px;height:20px;background:var(--border);margin:0 4px}
.filter-select{padding:4px 6px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:11px;font-family:var(--font);outline:none;max-width:120px}
.filter-check{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-dim);cursor:pointer;white-space:nowrap}
.filter-check input{accent-color:var(--accent);width:13px;height:13px}
.filter-btn{padding:3px 8px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:10px;cursor:pointer}
.filter-count{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-left:auto;white-space:nowrap}

#map{flex:1;background:#0d0f14}
.leaflet-container{background:#0d0f14 !important;font-family:var(--font) !important}
.leaflet-control-layers{display:none !important}
.leaflet-control-zoom{border:1px solid var(--border) !important;border-radius:var(--radius) !important;overflow:hidden}
.leaflet-control-zoom a{background:var(--bg-raised) !important;color:var(--text) !important;border-bottom:1px solid var(--border) !important;width:32px !important;height:32px !important;line-height:32px !important}
.leaflet-control-attribution{background:rgba(15,17,23,0.85) !important;color:var(--text-muted) !important;font-size:9px !important}
.leaflet-draw-toolbar a{background-color:var(--bg-raised) !important;border-color:var(--border) !important}
.leaflet-draw-actions a{background:var(--bg-surface) !important;color:var(--text) !important;border:1px solid var(--border) !important}

#selection-bar{height:38px;display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--bg-raised);border-top:1px solid var(--border);flex-shrink:0}
#sel-count{font-family:var(--mono);font-size:11px;color:var(--text-dim)}
.sel-btn{padding:4px 10px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:11px;cursor:pointer;font-family:var(--font)}
.sel-btn:hover{border-color:var(--text-dim);color:var(--text)}
.sel-btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}

.ctx-hint{color:var(--text-muted);font-size:12px;padding:8px 0;line-height:1.6}
.ctx-back{display:block;width:100%;text-align:left;padding:6px 0;background:none;border:none;color:var(--accent);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;margin-bottom:8px}
.ctx-section{margin-bottom:12px}
.ctx-section-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:var(--text-muted);margin-bottom:4px;padding-top:6px;border-top:1px solid var(--border)}
.ctx-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,0.03);gap:8px}
.ctx-row .ctx-key{color:var(--text-dim);flex-shrink:0;min-width:90px}
.ctx-row .ctx-val{font-weight:500;text-align:right;max-width:55%;word-break:break-word}
.ctx-header .ctx-id{font-size:18px;font-weight:700;letter-spacing:-0.3px}
.ctx-header .ctx-sub{font-size:12px;color:var(--text-dim);margin-top:2px;margin-bottom:8px}
.flag-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.3px;margin-right:4px}
.flag-asbestos{background:var(--danger);color:#fff}.flag-critical{background:#ff6f00;color:#fff}
.flag-high{background:var(--warning);color:#1a1a1a}.flag-demolished{background:#424242;color:#fff}

.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}
.summary-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}
.summary-card .sc-val{font-size:16px;font-weight:700;font-family:var(--mono)}
.summary-card .sc-label{font-size:10px;color:var(--text-dim);margin-top:2px}
.insight{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:6px;font-size:12px;line-height:1.5}
.insight .insight-label{font-size:10px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.3px;margin-bottom:2px}
.obs-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:6px}
.obs-card .obs-meta{font-size:10px;color:var(--text-muted);font-family:var(--mono);margin-bottom:4px}
.obs-card .obs-text{font-size:12px;line-height:1.5}
.ms-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:6px}
.ms-table th{text-align:left;padding:4px 6px;background:var(--bg-surface);color:var(--text-dim);font-weight:600;border-bottom:1px solid var(--border);font-size:10px;text-transform:uppercase;letter-spacing:0.3px}
.ms-table td{padding:3px 6px;border-bottom:1px solid rgba(255,255,255,0.03)}
.ms-table td:last-child{text-align:right;font-family:var(--mono);font-weight:600}
.captured-section{margin-top:10px;padding:8px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm)}
.captured-title{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}
