:root{--brand-green: #00a660;--brand-green-dark: #26402f;--brand-yellow: #fdca0b;--brand-yellow-light: #ffde3d;--bg: #f4f7f5;--surface: #ffffff;--text: #212426;--muted: #6b7280;--border: #e5e8ec;--danger: #dc2626;--warn: #d97706;--ok: #00a660;--radius: 14px;--radius-lg: 18px;--shadow: 0 4px 24px rgba(0, 0, 0, .06);--shadow-hover: 0 8px 32px rgba(0, 0, 0, .1);--ease: cubic-bezier(.22, 1, .36, 1);--dur: .2s;--dur-fast: .15s;font-family:Geologica,system-ui,sans-serif;font-weight:300;color:var(--text);background:var(--bg);line-height:1.5}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100dvh}button,input,select{font:inherit}a{color:var(--brand-green)}:focus-visible{outline:3px solid var(--brand-yellow-light);outline-offset:2px}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100dvh}.sidebar{background:linear-gradient(180deg,#0f1412,#121a16);color:#e8ece9;padding:1.25rem .9rem;display:flex;flex-direction:column;gap:1.25rem;border-right:1px solid rgba(255,255,255,.06);position:sticky;top:0;height:100dvh;overflow-y:auto}.brand{display:flex;align-items:center;gap:.75rem;padding:0 .35rem}.brand-dot{width:36px;height:36px;border-radius:50%;background:var(--brand-yellow);color:var(--text);display:grid;place-items:center;font-weight:900;font-size:.9rem;box-shadow:0 4px 12px #fdca0b59}.brand-title{display:block;font-weight:900;font-size:1rem;line-height:1.2}.brand-sub{display:block;font-size:.7rem;color:#9ca3af;font-weight:500}.nav-primary,.nav-soon{display:flex;flex-direction:column;gap:.2rem}.nav-soon-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;padding:.5rem .75rem .25rem;font-weight:700}.nav-link{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-radius:12px;color:#c5cdc8;text-decoration:none;font-weight:500;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur-fast) var(--ease);border:none;background:none;width:100%;text-align:left;cursor:default}.nav-link:not(.nav-link-disabled):hover{background:#ffffff0f;color:#fff}.nav-link:not(.nav-link-disabled):active{transform:scale(.98)}.nav-link.active{background:#00a66038;color:#7dffc0}.nav-link-disabled{opacity:.45;cursor:not-allowed}.nav-icon{width:1.1rem;text-align:center;opacity:.85}.sidebar-user{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.65rem}.user-chip{display:flex;align-items:center;gap:.65rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:#00a66059;color:#7dffc0;display:grid;place-items:center;font-weight:700}.user-meta strong{display:block;font-size:.875rem}.user-meta small{color:#9ca3af;font-size:.75rem;text-transform:capitalize}.content-col{min-width:0;display:flex;flex-direction:column}.main{padding:1.25rem 1.5rem 2.5rem;flex:1}.page-enter{animation:pageIn .35s var(--ease) both}.bottom-nav{display:none}.page-header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.page-header h1{margin:0;font-weight:900;font-size:clamp(1.5rem,3vw,1.85rem)}.eyebrow{margin:0 0 .2rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.section-block{margin-bottom:1.5rem}.section-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.85rem}.section-head h2{margin:0;font-size:1rem;font-weight:700}.text-link{font-size:.875rem;font-weight:500;text-decoration:none}.text-link:hover{text-decoration:underline}.city-pill{padding:.4rem .85rem;border-radius:999px;background:#00a6601f;color:var(--brand-green);font-weight:700;font-size:.875rem}.header-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.2rem;transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}.card-desc{margin:.25rem 0 0;font-size:.875rem;color:var(--muted)}.sovereign-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.35rem .65rem;border-radius:999px;background:#00a6601f;color:var(--brand-green)}.source-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.source-tile{padding:.85rem;border-radius:12px;background:var(--bg);border:1px solid var(--border);transition:transform var(--dur-fast) var(--ease),border-color var(--dur)}.source-tile:hover{transform:translateY(-2px);border-color:#00a66040}.source-tile-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.35rem}.source-tile small{color:var(--muted);font-size:.75rem}.circuit-warn{display:block;margin-top:.35rem;font-size:.7rem;color:var(--warn)}.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .45rem;border-radius:999px}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-ok{background:#00a66026;color:var(--ok)}.badge-warn{background:#d9770626;color:var(--warn)}.badge-muted{background:#f3f4f6;color:var(--muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:.25rem;box-shadow:var(--shadow);transition:transform var(--dur) var(--ease),box-shadow var(--dur);text-align:left}.kpi-card-click{cursor:pointer;border:none;font:inherit;color:inherit;width:100%}.kpi-card-click:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}.kpi-card-click:active{transform:translateY(-1px) scale(.99)}.kpi-label{font-size:.75rem;color:var(--muted);font-weight:500}.kpi-value{font-size:1.5rem;font-weight:900;line-height:1.1}.kpi-delta{font-size:.75rem;font-weight:700}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--danger)}.kpi-delta.flat{color:var(--muted)}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.module-card{position:relative;padding:1rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem;text-decoration:none;color:inherit;transition:transform var(--dur) var(--ease),box-shadow var(--dur),border-color var(--dur)}.module-card strong{font-weight:700;font-size:.95rem}.module-card span:not(.module-icon):not(.module-badge){font-size:.8rem;color:var(--muted)}.module-card-live{border-color:#00a66059}.module-card-live:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}.module-card:not(.module-card-live){opacity:.72}.module-icon{font-size:1.25rem;margin-bottom:.25rem}.module-badge{position:absolute;top:.75rem;right:.75rem;font-size:.6rem;font-weight:700;text-transform:uppercase;padding:.2rem .4rem;border-radius:6px;background:#f3f4f6;color:var(--muted)}.module-badge.live{background:#00a66026;color:var(--ok)}.select,.search-input{padding:.55rem .75rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);min-height:44px;transition:border-color var(--dur),box-shadow var(--dur)}.select:hover,.search-input:hover{border-color:#cfd5dc}.select:focus,.search-input:focus{border-color:var(--brand-green);box-shadow:0 0 0 3px #00a66026;outline:none}.search-input{min-width:min(100%,220px)}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:transform var(--dur-fast) var(--ease),filter var(--dur),background var(--dur);position:relative;overflow:hidden}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-md{padding:.65rem 1.1rem;min-height:44px;font-size:.9rem}.btn-sm{padding:.4rem .75rem;min-height:36px;font-size:.8rem;border-radius:10px}.btn-block{width:100%}.btn-primary{background:var(--brand-green);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#eef1f0}.btn-ghost{background:transparent;color:#9ca3af;border:1px solid rgba(255,255,255,.12)}.btn-ghost:hover:not(:disabled){background:#ffffff0f;color:#fff}.btn-loading .btn-inner{opacity:.5}.btn-loading:after{content:"";position:absolute;width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.ops-group{margin-bottom:.75rem;padding:0;overflow:hidden}.ops-group summary{cursor:pointer;font-weight:700;padding:.85rem 1.1rem;list-style:none;display:flex;align-items:center;gap:.5rem;-webkit-user-select:none;user-select:none;transition:background var(--dur)}.ops-group summary:hover{background:#f8faf9}.ops-group summary::-webkit-details-marker{display:none}.ops-group[open] .ops-chevron{transform:rotate(90deg)}.ops-chevron{transition:transform var(--dur) var(--ease);color:var(--muted)}.ops-count{margin-left:auto;font-size:.75rem;font-weight:500;color:var(--muted);background:var(--bg);padding:.15rem .5rem;border-radius:999px}.ops-group .table-wrap{padding:0 .5rem .75rem}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table.ops{width:100%;border-collapse:collapse;font-size:.875rem}table.ops th,table.ops td{padding:.6rem .55rem;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}table.ops th{font-weight:700;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;position:sticky;top:0;background:var(--surface);z-index:1}table.ops tr.metric-row{cursor:pointer;transition:background var(--dur-fast) var(--ease)}table.ops tr.metric-row:hover{background:#f0faf5}table.ops tr.metric-row:active{background:#e6f5ed}.col-star{width:44px}.col-metric{white-space:normal;min-width:10rem;max-width:14rem}.cell-value{display:block;font-weight:500}.delta{display:block;font-size:.68rem;font-weight:600;color:var(--muted)}.delta-up{color:var(--ok)}.delta-down{color:var(--danger)}.star-btn{background:none;border:none;cursor:pointer;font-size:1.15rem;padding:.35rem;min-width:44px;min-height:44px;border-radius:10px;color:#d1d5db;transition:transform var(--dur-fast) var(--ease),color var(--dur),background var(--dur)}.star-btn:hover{background:#fdca0b26;color:var(--brand-yellow)}.star-btn:active{transform:scale(.88)}.star-btn.starred{color:var(--brand-yellow);animation:starPop .35s var(--ease)}.metric-label-wrap{display:inline-flex;align-items:flex-start;gap:.35rem}.metric-tip{position:relative;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.metric-tip-icon{width:16px;height:16px;border-radius:50%;background:#00a6601f;color:var(--brand-green);font-size:.65rem;font-weight:800;font-style:italic;line-height:1;display:inline-flex;align-items:center;justify-content:center}.metric-tip-bubble{display:none;position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);width:max-content;max-width:min(280px,70vw);padding:.45rem .65rem;border-radius:8px;background:#1e2333;color:#c7d4ff;border:1px solid var(--brand-green);font-size:.75rem;font-weight:400;line-height:1.45;z-index:5;box-shadow:0 4px 16px #00000026;pointer-events:none}.metric-tip:hover .metric-tip-bubble,.metric-tip:focus .metric-tip-bubble,.metric-tip:focus-within .metric-tip-bubble{display:block}.ops-empty-row{margin:.5rem .75rem 1rem;padding:.75rem 1rem;color:var(--muted);font-size:.875rem;background:var(--bg);border-radius:10px}.city-select-label{display:flex;flex-direction:column;gap:.25rem}.city-select-text{font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.city-scope-hint{font-size:.75rem;color:var(--muted);align-self:flex-end}.skeleton{background:linear-gradient(90deg,#eef1f0 25%,#f8faf9,#eef1f0 75%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:8px}.table-skeleton{display:flex;flex-direction:column;gap:.65rem;padding:1rem}.table-skeleton-row{display:flex;gap:.65rem}.empty-state{text-align:center;padding:2.5rem 1.5rem;background:var(--surface);border-radius:var(--radius-lg);border:1px dashed var(--border)}.empty-icon{font-size:2rem;opacity:.35;display:block;margin-bottom:.75rem}.empty-state h3{margin:0 0 .35rem;font-weight:700}.empty-state p{margin:0 0 1rem;color:var(--muted);font-size:.9rem}.toast-stack{position:fixed;bottom:1.25rem;right:1.25rem;z-index:100;display:flex;flex-direction:column;gap:.5rem;max-width:min(360px,calc(100vw - 2rem))}.toast{padding:.75rem 1rem;border-radius:12px;background:#1a211e;color:#fff;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-hover);animation:toastIn .3s var(--ease) both}.toast-success{border-left:4px solid var(--ok)}.toast-error{border-left:4px solid var(--danger)}.login-page{min-height:100dvh;display:grid;place-items:center;padding:1rem;background:linear-gradient(160deg,#00a660,#26402f 55%,#0f1412)}.login-card{width:min(100%,420px);background:var(--surface);border-radius:22px;padding:1.75rem;box-shadow:0 24px 64px #0003;animation:rise .5s var(--ease) both}.login-brand{display:flex;gap:.85rem;align-items:center;margin-bottom:1.5rem}.login-brand h1{margin:0;font-weight:900;font-size:1.35rem}.login-brand p{margin:.15rem 0 0;color:var(--muted);font-size:.875rem}.login-card label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.35rem}.login-card input{width:100%;padding:.7rem .8rem;border-radius:12px;border:1px solid var(--border);margin-bottom:1rem;transition:border-color var(--dur),box-shadow var(--dur)}.login-card input:focus{border-color:var(--brand-green);box-shadow:0 0 0 3px #00a66026;outline:none}.form-error{color:var(--danger);font-size:.875rem;margin:-.5rem 0 .75rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f14128c;display:grid;place-items:center;padding:1rem;z-index:50;animation:fade .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border-radius:var(--radius-lg);width:min(100%,580px);max-height:90dvh;overflow:auto;padding:1.25rem;animation:rise .28s var(--ease);box-shadow:0 24px 64px #0003}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.modal-head h2{margin:0;font-weight:900;font-size:1.15rem}.modal-close{background:var(--bg);border:none;width:36px;height:36px;border-radius:10px;font-size:1.35rem;cursor:pointer;line-height:1;transition:background var(--dur),transform var(--dur-fast)}.modal-close:hover{background:#e5e8ec}.modal-close:active{transform:scale(.92)}.modal-filters{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.modal-filters label span{display:block;font-size:.75rem;font-weight:600;color:var(--muted);margin-bottom:.3rem}.modal-filters .select{width:100%}.modal-foot{display:flex;justify-content:flex-end;margin-top:1rem}.chart-area{min-height:200px;position:relative}.chart-svg{width:100%;height:200px;display:block}.chart-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--muted);margin-top:.35rem}.chart-placeholder{height:200px;display:grid;place-items:center;color:var(--muted);background:var(--bg);border-radius:12px}.chart-loading{opacity:.6}.sync-panel{margin-top:0}.sync-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;margin-top:1rem}.audit-list{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.45rem}.audit-item{display:flex;justify-content:space-between;gap:1rem;font-size:.8rem;padding:.55rem .65rem;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.audit-item.audit-success{border-left:3px solid var(--ok)}.audit-item.audit-error{border-left:3px solid var(--danger)}.audit-meta{color:var(--muted);text-align:right}.dash-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.dash-kpi-card{display:flex;flex-direction:column;gap:.35rem}.dash-kpi-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.dash-kpi-card .kpi-label{font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.dash-kpi-card .kpi-value{font-size:1.35rem;font-weight:800}.dash-status{color:var(--muted);font-weight:500}.sparkline{flex-shrink:0;opacity:.85}.charts-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;align-items:flex-end}.charts-city-chips{display:flex;flex-direction:column;gap:.35rem}.chip-row{display:flex;flex-wrap:wrap;gap:.35rem}.city-chip{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--bg);font-size:.8rem;font-weight:600;cursor:pointer;transition:background var(--dur-fast),border-color var(--dur-fast)}.city-chip.on{background:#00a66026;border-color:var(--brand-green);color:var(--brand-green)}.charts-panel .chart-area{min-height:200px}.charts-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem;font-size:.8rem}.legend-item{display:inline-flex;align-items:center;gap:.35rem}.legend-dot{width:10px;height:10px;border-radius:50%}.heatmap-table td strong{color:var(--brand-green)}.campaign-list{display:flex;flex-direction:column;gap:.75rem}.campaign-card h2{font-weight:700}.resource-table .resource-notes{display:block;margin-top:.25rem;color:var(--muted);font-size:.75rem;line-height:1.35}.resource-type{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--muted)}.resource-alert-list{margin:.5rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}.resource-alert-list li{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes starPop{0%{transform:scale(.6)}60%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.analytics-col{background:#0b0d10}.analytics-main{--bg: #0b0d10;--surface: #151820;--text: #e8eaed;--muted: #9aa0a6;--border: #2a2f3a;--brand-green: #00e676;--ok: #00e676;--danger: #ff5252;--warn: #ffb74d;color:var(--text)}.analytics-tabs{display:flex;flex-wrap:wrap;gap:0;border-bottom:1px solid var(--border);margin:-.25rem -.5rem 1.25rem;padding:0 .5rem}.analytics-tab{padding:.75rem 1rem;font-size:.8rem;font-weight:600;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--dur),border-color var(--dur)}.analytics-tab:hover{color:var(--text)}.analytics-tab.active{color:var(--brand-green);border-bottom-color:var(--brand-green)}.analytics-page-header .eyebrow{color:#6b7280}.analytics-meta{margin:.35rem 0 0;font-size:.85rem;color:var(--muted)}.analytics-main .card{background:var(--surface);border-color:var(--border);box-shadow:none}.analytics-main .page-header h1{color:var(--text)}.analytics-main .select,.analytics-main .search-input{background:#1a1f28;border-color:var(--border);color:var(--text)}.analytics-main .select:focus,.analytics-main .search-input:focus{border-color:var(--brand-green);outline:none}.analytics-main .city-select-text{color:var(--muted)}.analytics-main .ops-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.analytics-main .ops-group summary{color:var(--text)}.analytics-main .ops-group summary:hover{background:#ffffff08}.analytics-main .ops-count{background:#1a1f28;color:var(--muted)}.analytics-main table.ops th,.analytics-main table.ops td{border-color:var(--border)}.analytics-main table.ops th{background:#1a1f28;color:var(--muted)}.analytics-main table.ops th.col-star,.analytics-main table.ops td.col-star{position:sticky;left:0;z-index:4;background:var(--surface)}.analytics-main table.ops th.col-metric,.analytics-main table.ops td.col-metric{position:sticky;left:44px;z-index:3;background:var(--surface);box-shadow:6px 0 12px #00000040}.analytics-main table.ops tr.metric-row:hover{background:#00e6760f}.analytics-main table.ops tr.metric-row:active{background:#00e6761a}.analytics-main .cell-value{color:var(--text);font-weight:600}.analytics-main .star-btn{color:#4b5563}.analytics-main .star-btn:hover{background:#fdca0b1f}.analytics-main .ops-empty-row{background:#1a1f28;color:var(--muted)}.analytics-main .metric-tip-icon{background:#00e67626;color:var(--brand-green)}.analytics-main .empty-state{background:var(--surface);border-color:var(--border);color:var(--muted)}.analytics-main .skeleton{background:linear-gradient(90deg,#1a1f28 25%,#252b36,#1a1f28 75%);background-size:200% 100%}.analytics-main .kpi-card,.analytics-main .dash-kpi-card{background:#1a1f28;border:1px solid var(--border)}.analytics-main .kpi-label{color:var(--muted)}.analytics-main .kpi-value{color:var(--text)}.analytics-main .city-chip{background:#1a1f28;border:1px solid var(--border);color:var(--muted)}.analytics-main .city-chip.on{background:#00e67626;border-color:var(--brand-green);color:var(--brand-green)}.analytics-modal-backdrop{background:#000000b8}.analytics-modal{background:#151820;border:1px solid #2a2f3a;color:var(--text)}.analytics-modal .modal-head h2{color:var(--text)}.analytics-modal .modal-close{background:#1a1f28;color:var(--muted)}.analytics-modal .modal-close:hover{background:#252b36;color:var(--text)}.analytics-modal .select{background:#1a1f28;border-color:#2a2f3a;color:var(--text)}.chart-modal-hint{margin:.35rem 0 0;font-size:.8rem;color:#9aa0a6;font-weight:400}.chart-area-js{height:280px;min-height:280px}.dash-toolbar{padding:1rem 1.1rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.85rem}.dash-toolbar-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.dash-toolbar-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);min-width:3.5rem}.dash-toggle-group{display:flex;flex-wrap:wrap;gap:.35rem}.dash-toggle{padding:.4rem .75rem;border-radius:8px;border:1px solid var(--border);background:#1a1f28;color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:background var(--dur),color var(--dur),border-color var(--dur)}.dash-toggle.on{background:#00e67626;border-color:var(--brand-green);color:var(--brand-green)}.dash-segment-pill{margin-left:auto;padding:.35rem .65rem;border-radius:8px;background:#00e6761f;color:var(--brand-green);font-size:.75rem;font-weight:700}.dash-period-select{min-width:9rem;font-size:.8rem}.dash-chip-action{padding:.35rem .6rem;border:none;background:transparent;color:var(--muted);font-size:.75rem;font-weight:600;cursor:pointer}.dash-chip-action:hover{color:var(--brand-green)}.dash-city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem}.dash-city-card{padding:0;display:flex;flex-direction:column;min-height:100%}.dash-city-card-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid var(--border)}.dash-city-card-head h3{margin:0;font-size:1rem;font-weight:800}.dash-city-metrics{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:.75rem;flex:1}.dash-metric-box{padding:.55rem .65rem;border-radius:10px;border:1px solid var(--border);background:#1a1f28}.dash-metric-accent{border-color:#00e67659;background:#00e67614}.dash-metric-ephemeral{border-color:#8b5cf673;background:#8b5cf61a}.dash-metric-tone-ok .dash-metric-value{color:var(--ok)}.dash-metric-tone-warn .dash-metric-value{color:var(--warn)}.dash-metric-tone-bad .dash-metric-value{color:var(--danger)}.dash-metric-label{display:block;font-size:.62rem;font-weight:800;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:.2rem}.dash-metric-value{display:block;font-size:1.15rem;font-weight:800;line-height:1.2}.dash-metric-sub{display:block;font-size:.68rem;color:var(--muted);margin-top:.15rem}.dash-city-empty{padding:1rem;color:var(--muted);font-size:.85rem;margin:0}.dash-city-card-foot{padding:.65rem 1rem;border-top:1px solid var(--border)}.dash-city-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;padding:.25rem .55rem;border-radius:999px;border:1px solid var(--border)}.dash-city-status-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.dash-city-status-ok{color:var(--ok);border-color:#00e67659;background:#00e67614}.dash-city-status-warn{color:var(--warn);border-color:#ffb74d59;background:#ffb74d14}.dash-city-status-danger{color:var(--danger);border-color:#ff525259;background:#ff525214}.dash-city-status-muted{color:var(--muted)}.dash-summary{padding:0;overflow:hidden}.dash-summary-title{margin:0;padding:.85rem 1rem;font-size:.75rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}.dash-summary-table{font-size:.78rem}.dash-summary-table th{font-size:.62rem}.cell-tone-ok{color:var(--ok);font-weight:600}.cell-tone-warn{color:var(--warn);font-weight:600}.cell-tone-bad{color:var(--danger);font-weight:600}.charts-toolbar{padding:1rem 1.1rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.85rem}.charts-metric-toggles{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-start}.charts-metric-chips{display:flex;flex-wrap:wrap;gap:.35rem;flex:1}.charts-metric-chip{padding:.35rem .65rem;border-radius:8px;border:1px solid var(--border);background:#1a1f28;color:var(--muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:background var(--dur),border-color var(--dur),color var(--dur)}.charts-metric-chip.on{border-color:var(--chip-color, var(--brand-green));background:color-mix(in srgb,var(--chip-color, var(--brand-green)) 18%,transparent);color:var(--chip-color, var(--brand-green))}.charts-grid{display:flex;flex-direction:column;gap:1.25rem}.charts-metric-card{padding:0;overflow:hidden}.charts-metric-head{padding:.85rem 1rem .5rem;border-bottom:1px solid var(--border)}.charts-metric-head h3{margin:0;font-size:.95rem;font-weight:800}.charts-thresholds{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.charts-threshold{font-size:.68rem;font-weight:600;padding:.2rem .5rem;border-radius:6px;border:1px dashed;background:#00000026}.charts-metric-canvas{height:280px;padding:.5rem .75rem 1rem}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;padding:.65rem .75rem;gap:.5rem}.nav-soon,.sidebar-user{display:none}.nav-primary{flex-direction:row;flex:1}.brand-sub{display:none}.bottom-nav{display:flex;position:sticky;bottom:0;z-index:40;background:var(--surface);border-top:1px solid var(--border);padding:.35rem .5rem calc(.35rem + env(safe-area-inset-bottom));box-shadow:0 -4px 20px #0000000f}.bottom-link{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.45rem;text-decoration:none;color:var(--muted);font-size:.65rem;font-weight:600;border-radius:10px;transition:color var(--dur),background var(--dur)}.bottom-link .nav-icon{font-size:1.1rem}.bottom-link.active{color:var(--brand-green);background:#00a6601a}.bottom-link:active{transform:scale(.96)}.main{padding:1rem 1rem 1.25rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.modal-filters{grid-template-columns:1fr}.header-actions{width:100%}.search-input{flex:1}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
