.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem 0}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:0 1.25rem 1.5rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.sidebar-mark{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-muted));opacity:.9}.sidebar-city{font-family:var(--font-display);font-weight:600;font-size:1.05rem;line-height:1.2}.sidebar-product{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 .65rem;flex:1}.sidebar-link{display:block;padding:.55rem .75rem;border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;text-decoration:none}.sidebar-link:hover{background:var(--surface-2);text-decoration:none}.sidebar-link.active{background:var(--surface-2);font-weight:600;color:var(--accent);border-left:3px solid var(--accent);padding-left:calc(.75rem - 3px)}.sidebar-foot{font-size:.7rem;color:var(--text-muted);padding:1rem 1.25rem 0;margin:0}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.app-header{min-height:var(--header-h);display:flex;flex-wrap:wrap;align-items:flex-start;gap:.75rem 1.25rem;padding:.65rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.header-left{flex:1 1 200px;min-width:0}.header-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin:0;line-height:1.3}.header-filters{display:flex;flex-wrap:wrap;gap:.5rem .75rem;align-items:flex-end}.filter-field{display:flex;flex-direction:column;gap:.2rem}.filter-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.filter-field input,.filter-field select{padding:.35rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text)}.header-right{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.search-wrap{position:relative}.search-input{width:min(220px,42vw);padding:.4rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text)}.search-results{position:absolute;top:100%;right:0;margin:4px 0 0;padding:.35rem 0;list-style:none;min-width:280px;max-height:280px;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--card-shadow);z-index:30}.search-results a{display:block;padding:.45rem .75rem;color:var(--text);text-decoration:none;font-size:.8125rem}.search-results a:hover{background:var(--surface-2);text-decoration:none}.sr-type{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);padding:.4rem .75rem;font-size:.8125rem;background:var(--surface);color:var(--text)}.btn.ghost{background:transparent}.btn.ghost:hover{background:var(--surface-2)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.06)}.app-content{padding:1.25rem 1.5rem 2.5rem;flex:1}.page{max-width:1400px;margin:0 auto}.page-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.page-lead{margin:0;max-width:52ch;color:var(--text-muted);font-size:.9rem;line-height:1.5}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;box-shadow:var(--card-shadow)}.kpi-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.kpi-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.kpi-badge{font-size:.65rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;background:color-mix(in srgb,var(--warning) 22%,transparent);color:var(--warning)}.kpi-value-row{display:flex;align-items:baseline;gap:.5rem;margin-top:.35rem}.kpi-value{font-family:var(--font-display);font-size:1.35rem;font-weight:600}.kpi-sub{margin:.35rem 0 0;font-size:.78rem;color:var(--text-muted);line-height:1.4}.kpi-trend{font-size:.75rem;font-weight:600}.kpi-trend.trend-up{color:var(--success)}.kpi-trend.trend-down{color:var(--danger)}.kpi-trend.trend-flat{color:var(--text-muted)}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr));gap:1.25rem;margin-bottom:1.25rem}.chart-section{margin-bottom:1.25rem}.bottom-grid{margin-top:.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--card-shadow)}.card-title{font-family:var(--font-display);font-size:1.05rem;margin:0 0 .25rem}.card-sub{margin:0 0 .75rem;font-size:.8rem;color:var(--text-muted)}.chart-card .chart-area{height:260px}.chart-card .chart-area.tall{height:300px}.dept-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem}.dept-tile{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-decoration:none;color:inherit;box-shadow:var(--card-shadow);transition:border-color .15s ease,transform .15s ease}.dept-tile:hover{border-color:var(--accent-muted);text-decoration:none;transform:translateY(-1px)}.dept-tile-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.65rem}.dept-tile-title{font-size:.95rem;margin:0;font-weight:600}.dept-tile-alert{min-width:1.35rem;height:1.35rem;border-radius:999px;background:color-mix(in srgb,var(--danger) 25%,transparent);color:var(--danger);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.dept-tile-metrics{list-style:none;margin:0;padding:0;font-size:.8125rem}.dept-tile-metrics li{display:flex;justify-content:space-between;gap:.5rem;padding:.25rem 0;border-bottom:1px solid var(--border)}.dept-tile-metrics li:last-child{border-bottom:none}.dt-label{color:var(--text-muted)}.dt-val{font-weight:600}.dept-tile-cta{margin-top:.75rem;font-size:.78rem;color:var(--accent);font-weight:600}.alert-list,.activity-list{list-style:none;margin:0;padding:0;max-height:360px;overflow:auto}.alert-row,.activity-row{padding:.75rem 0;border-bottom:1px solid var(--border);font-size:.875rem}.alert-row:last-child,.activity-row:last-child{border-bottom:none}.alert-row.muted,.activity-row.muted{color:var(--text-muted)}.alert-dept,.act-dept{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.2rem}.alert-row p,.activity-row p{margin:.35rem 0 0;color:var(--text-muted);font-size:.8125rem}.alert-row.sev-warning{border-left:3px solid var(--warning);padding-left:.65rem}.alert-row.sev-critical{border-left:3px solid var(--danger);padding-left:.65rem}.activity-row time{font-size:.72rem;color:var(--text-muted)}.mini-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:1.25rem}.mini-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.65rem .85rem}.mk-label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.mk-val{font-weight:600;font-size:.95rem}.map-placeholder{border:1px dashed var(--border);border-radius:var(--radius);min-height:220px;position:relative;background:var(--surface-2);overflow:hidden}.map-ph-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:24px 24px;opacity:.35}.map-ph-label{position:relative;z-index:1;padding:1rem 1rem 0;font-weight:600;font-size:.9rem}.map-ph-note{position:relative;z-index:1;margin:.5rem 1rem 1rem;font-size:.78rem;color:var(--text-muted);max-width:36ch}.loading-state{display:flex;align-items:center;gap:.75rem;padding:3rem 1rem;justify-content:center;color:var(--text-muted)}.loading-spinner{width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:3rem 1.5rem;text-align:center}.empty-title{font-weight:600;margin:0 0 .5rem}.empty-detail{margin:0;color:var(--text-muted);font-size:.9rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(160deg,var(--surface-2) 0%,var(--bg) 45%,var(--surface) 100%)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 2rem 1.75rem;box-shadow:var(--card-shadow)}.login-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 .35rem}.login-title{font-family:var(--font-display);font-size:1.5rem;margin:0 0 .5rem}.login-sub{margin:0 0 1.5rem;font-size:.875rem;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem}.login-field input{padding:.55rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text)}.login-err{color:var(--danger);font-size:.8rem;margin:0}.login-btn{margin-top:.25rem;width:100%;padding:.65rem}@media (max-width: 960px){.app-shell{flex-direction:column}.sidebar{width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;padding:.75rem 1rem;border-right:none;border-bottom:1px solid var(--border)}.sidebar-brand{border:none;margin:0;padding:0 1rem 0 0}.sidebar-nav{flex-direction:row;flex-wrap:wrap;flex:1;padding:0}.sidebar-link{padding:.35rem .5rem;font-size:.8rem}.sidebar-foot{width:100%;padding:.5rem 0 0}}@media print{.print-hide,.sidebar,.app-header{display:none!important}.app-content{padding:0}.card,.kpi-card{break-inside:avoid;box-shadow:none}}:root{--font-sans: "DM Sans", system-ui, sans-serif;--font-display: "Source Serif 4", Georgia, serif;--bg: #f4f6f8;--surface: #ffffff;--surface-2: #eef1f4;--border: #d8dee6;--text: #1a2332;--text-muted: #5c6b7f;--accent: #1e4d6b;--accent-muted: #3a7a9e;--success: #1f7a4a;--warning: #b45309;--danger: #b42318;--card-shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 4px 12px rgba(15, 23, 42, .04);--sidebar-w: 260px;--header-h: 56px;--radius: 10px;--radius-sm: 6px}[data-theme=dark]{--bg: #0f1419;--surface: #1a222c;--surface-2: #232d3a;--border: #2f3c4d;--text: #e8edf3;--text-muted: #94a3b8;--accent: #6eb5d8;--accent-muted: #4a8fb8;--success: #4ade80;--warning: #fbbf24;--danger: #f87171;--card-shadow: 0 1px 2px rgba(0, 0, 0, .35), 0 8px 24px rgba(0, 0, 0, .25)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit;font-size:.875rem}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}table.data{width:100%;border-collapse:collapse;font-size:.8125rem}table.data th,table.data td{text-align:left;padding:.65rem .85rem;border-bottom:1px solid var(--border)}table.data th{font-weight:600;color:var(--text-muted);background:var(--surface-2)}table.data tr:last-child td{border-bottom:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
