.city-view{width:100%;max-width:1400px;margin:0 auto}.city-view-single-page{flex-direction:column;width:100%;max-width:100%;min-height:100vh;margin:0;display:flex}.city-view-hero-header{flex-shrink:0}.city-view-hero-header .city-header-overlay{box-shadow:none;position:relative}.city-view-sticky-header{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);background:#fffffff2;flex-shrink:0;position:sticky;top:0;box-shadow:0 1px 3px #0000000d}.city-view-place-selector-row{border-top:1px solid var(--border-primary);background:#fff9;padding:8px 12px 12px}.city-view-place-selector-fallback{align-items:center;display:flex}.city-view-place-selector-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.city-view-place-selector-refresh{color:var(--text-secondary);font-size:.75rem;font-weight:500}.city-view-scroll-body{flex-direction:column;flex:1;display:flex}.city-view-section-title{color:var(--text-primary);margin:0 0 12px;font-size:1.125rem;font-weight:600}.city-view-map-section{flex-shrink:0;width:100%;height:50vh;min-height:50vh;position:relative;overflow:hidden}.city-view-map-section .city-map-view{width:150%;height:100%;position:absolute;top:0;bottom:0;left:-50%}.city-view-map-selector-overlay{z-index:12;pointer-events:none;padding:10px 12px 12px;position:absolute;top:0;left:0;right:50px}.city-view-map-selector-overlay>*{pointer-events:auto}.city-view-map-selector-fallback{color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-primary);background:#ffffffd9;border-radius:8px;padding:6px 12px;font-size:.875rem;font-weight:500;display:inline-block}[data-theme=dark] .city-view-map-selector-fallback,.dark .city-view-map-selector-fallback{border-color:var(--border-primary);background:#1e1e1ed9}.city-view-map-date-overlay{z-index:10;position:absolute;top:12px;left:12px;right:auto}@media (max-width:640px){.city-view-place-selector-row{padding:8px 8px 10px}.city-view-map-selector-overlay{padding:8px}.city-view-map-date-overlay{top:8px;left:8px}}.city-view-dashboard-section{background:var(--bg-primary,#fff);border-top:1px solid var(--border-primary);flex-shrink:0;padding:16px 12px 0}.city-view-dashboard-section .city-view-section-title{padding:0}.city-view-dashboard-last-refresh{color:var(--text-secondary,#666);font-weight:400}.city-view-alerts-section{background:var(--bg-primary,#fff);border-top:1px solid var(--border-primary);flex-shrink:0;width:100%;min-height:200px;padding:16px 12px 12px}@media (max-width:640px){.city-view-dashboard-section{padding:12px 8px 0}.city-view-alerts-section{padding:12px 8px 8px}}.city-view-alerts-section .city-view-section-title{margin-bottom:12px;padding:0}.city-view-alerts-placeholder{padding:24px 0 0}.city-view-alerts-placeholder-title{color:var(--text-primary);margin:0 0 12px;font-size:1.125rem;font-weight:600}.city-view-alerts-placeholder-loading{color:var(--text-secondary);align-items:center;gap:12px;display:flex}@keyframes city-view-admin-drawer-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.city-view-admin-drawer-overlay{z-index:10010;pointer-events:none;justify-content:flex-end;display:flex;position:fixed;inset:0}.city-view-admin-drawer-overlay>*{pointer-events:auto}.city-view-admin-drawer-backdrop{cursor:pointer;width:100%;height:100%;font:inherit;color:inherit;background:#0006;border:none;padding:0;animation:.25s ease-out forwards city-view-admin-drawer-backdrop-fade;position:absolute;inset:0}@keyframes city-view-admin-drawer-backdrop-fade{0%{opacity:0}to{opacity:1}}.city-view-admin-drawer-panel{background:var(--bg-primary,#fff);z-index:1;flex-direction:column;width:100%;max-width:100%;height:100%;animation:.3s ease-out forwards city-view-admin-drawer-slide-in;display:flex;position:relative;box-shadow:-4px 0 24px #00000026}.city-view-admin-drawer-header{border-bottom:1px solid var(--border-primary);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.city-view-admin-drawer-title{color:var(--text-primary);margin:0;font-size:1.125rem;font-weight:600}.city-view-admin-drawer-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;display:flex}.city-view-admin-drawer-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.city-view-admin-drawer-content{flex:1;padding:16px;overflow-y:auto}.city-header-admin-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.city-header-admin-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.dashboard-scope-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}[data-theme=dark] .city-view-sticky-header,.dark .city-view-sticky-header{background:#111827f2}[data-theme=dark] .city-view-place-selector-row,.dark .city-view-place-selector-row{background:#111827b3}[data-theme=dark] .city-view-dashboard-section,[data-theme=dark] .city-view-alerts-section,.dark .city-view-dashboard-section,.dark .city-view-alerts-section,[data-theme=dark] .city-view-admin-drawer-panel,.dark .city-view-admin-drawer-panel{background:var(--bg-primary,#111827)}.city-view.tab-view-active,.city-view.map-view-active{width:100%;max-width:100%;height:100vh;margin:0;padding:0;position:relative;overflow:hidden}.city-view .tab-content-wrapper{flex-direction:column;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.city-view .tab-content-wrapper-map-background{z-index:1;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.city-view .tab-content-wrapper-map-background .city-map-view{width:100%;height:100%;position:relative}.city-view .tab-content-wrapper .city-header-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);z-index:1000;width:100%;box-shadow:none;background:#ffffffa6;justify-content:space-between;align-items:center;height:56px;padding:12px 24px;transition:none;display:flex;position:fixed;top:0;left:0;right:0}.city-view .tab-content-wrapper .tabs-container-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);z-index:999;width:100%;box-shadow:none;background:#ffffffa6;align-items:center;gap:8px;height:48px;padding:0 24px;transition:none;display:flex;position:fixed;top:56px;left:0;right:0}.city-view .tab-content-wrapper .tab-content{box-sizing:border-box;z-index:2;-webkit-overflow-scrolling:touch;background:var(--bg-primary,#fff);overscroll-behavior:contain;flex:1;width:100%;max-width:100%;height:calc(100vh - 104px);margin-top:104px;position:relative;overflow:hidden auto;padding:0!important}@media (min-width:1024px){.city-view .tab-content-wrapper .tab-content{padding:12px!important}}@media (min-width:1280px){.city-view .tab-content-wrapper .tab-content{padding:16px!important}}[data-theme=dark] .city-view .tab-content-wrapper .tab-content,.dark .city-view .tab-content-wrapper .tab-content{background:var(--bg-primary,#111827)}@media (max-width:768px){.city-view.map-view-active{width:100vw;max-width:100vw;margin:0;padding:0}}.city-view-loading,.city-view-error{text-align:center;padding:48px}.city-view-error{color:#dc2626}.retry-button{background:var(--brand-primary);color:#fff;cursor:pointer;border:none;border-radius:4px;margin-top:16px;padding:8px 16px;font-weight:500}.city-header{border-bottom:1px solid var(--border-primary);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.city-header-left{align-items:center;gap:12px;padding-left:16px;display:flex}.city-header-hamburger{width:40px;height:40px;padding:var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:4px;transition:background .2s;display:flex}.city-header-hamburger:hover{background:var(--bg-tertiary)}.city-header-hamburger span{background:var(--text-primary);width:20px;height:2px;transition:all .3s;display:block}.city-emoji-icon{font-size:28px;line-height:1}.city-name{color:var(--text-primary);margin:0;font-size:20px;font-weight:600}.city-header-right{align-items:center;gap:12px;padding-right:20px;display:flex}.city-header-follow-btn{color:var(--brand-primary,#ad35fa);border:1px solid var(--brand-primary,#ad35fa);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.875rem;font-weight:500;transition:background-color .15s,color .15s;display:inline-flex}.city-header-follow-btn:hover,.city-header-follow-btn.following{background:var(--brand-primary,#ad35fa);color:#fff}.city-header-follow-btn.following:hover{background:var(--brand-primary-hover,#9333ea);color:#fff}.city-header-follow-btn:disabled{opacity:.8;cursor:not-allowed}.city-header-follow-count{color:var(--text-secondary);white-space:nowrap;font-size:.75rem;font-weight:500}.city-header-follow-btn.following .city-header-follow-count{color:#ffffffe6}.save-city-btn{cursor:pointer;color:var(--text-secondary,#6b7280);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.save-city-btn:hover{background-color:var(--bg-secondary,#f3f4f6)}.save-city-btn:active{transform:scale(.95)}.save-city-btn.saved{color:#9333ea}.save-city-btn:disabled{opacity:.6;cursor:not-allowed}.tabs-container{border-bottom:1px solid var(--border-primary);gap:8px;margin-bottom:24px;display:flex}.tab-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}.tab-content{display:none}.tab-content.active{display:block}.tab-content#map-tab.active.map-tab-fullscreen{width:100%;height:100%;margin:0;padding:0;display:block;position:absolute;inset:0;overflow:hidden}@media (max-width:768px){.tab-content#map-tab.active.map-tab-fullscreen{width:100vw;margin:0;padding:0;left:0;right:0}}.tab-content#map-tab.active.map-tab-fullscreen .city-map-view{width:100%;height:100%;position:relative}.city-header-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);z-index:1000;box-shadow:none;background:#ffffffa6;justify-content:space-between;align-items:center;height:56px;padding:12px 24px;transition:transform .3s ease-in-out,opacity .3s ease-in-out;display:flex;position:absolute;top:0;left:0;right:0;transform:none}.city-header-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(-100%)}.city-header-overlay.visible{opacity:1}[data-theme=dark] .city-header-overlay,.dark .city-header-overlay,[data-theme=dark] .tab-content-wrapper .city-header-overlay,.dark .tab-content-wrapper .city-header-overlay,[data-theme=dark] .tab-content-wrapper .tabs-container-overlay,.dark .tab-content-wrapper .tabs-container-overlay{border-bottom-color:var(--border-primary,#374151);background:#1f2937a6}.city-header-overlay .city-header-left{align-items:center;gap:12px;padding-left:32px;display:flex}.city-header-overlay .city-header-hamburger{width:40px;height:40px;padding:var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:4px;transition:background .2s;display:flex}.city-header-overlay .city-header-hamburger:hover{background:var(--bg-tertiary)}.city-header-overlay .city-header-hamburger span{background:var(--text-primary);width:20px;height:2px;transition:all .3s;display:block}.city-header-overlay .city-emoji-icon{font-size:28px;line-height:1}.city-header-overlay .city-name{color:var(--text-primary);margin:0;font-size:20px;font-weight:600}.city-header-overlay .city-header-right{align-items:center;gap:12px;padding-right:20px;display:flex}.tabs-container-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);z-index:999;box-shadow:none;background:#ffffffa6;align-items:center;gap:8px;height:48px;padding:0 24px;transition:transform .3s ease-in-out,opacity .3s ease-in-out;display:flex;position:absolute;top:56px;left:0;right:0;transform:none}.tabs-container-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(-100%)}.tabs-container-overlay.visible{opacity:1}[data-theme=dark] .tabs-container-overlay,.dark .tabs-container-overlay{border-bottom-color:var(--border-primary,#374151);background:#1f2937a6}.tabs-container-overlay .tab-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.tabs-container-overlay .tab-btn:hover{color:var(--text-primary)}.tabs-container-overlay .tab-btn.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}.map-district-navigation-overlay{z-index:998;min-width:300px;max-width:400px;transition:transform .3s ease-in-out,opacity .3s ease-in-out;position:absolute;top:110px;left:24px;transform:none}.map-district-navigation-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(-100%)}.map-district-navigation-overlay.visible{opacity:1}.map-date-range-overlay{z-index:998;transition:transform .3s ease-in-out,opacity .3s ease-in-out;position:absolute;top:170px;left:24px;transform:none}.map-date-range-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(-100%)}.map-date-range-overlay.visible{opacity:1}@media (max-width:768px){.map-district-navigation-overlay{min-width:calc(100% - 32px);max-width:calc(100% - 32px);top:110px;left:16px}.map-date-range-overlay{top:170px;left:16px}}.dashboard-section{box-sizing:border-box;width:100%;max-width:100%;padding:0}@media (min-width:768px){.dashboard-section{padding:0}}@media (max-width:640px){.dashboard-section{width:100%;max-width:100%;padding:0}.metrics-cards-container,.metrics-category-section{width:100%}}.dashboard-section h2{color:var(--text-primary);margin:0 0 20px;font-size:22px;font-weight:600}.block-dashboard-panel{background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-primary,#e5e7eb);border-radius:8px;margin-top:16px;padding:16px}.block-dashboard-empty{color:var(--text-secondary);flex-direction:column;align-items:flex-start;gap:12px;padding:24px;display:flex}.block-dashboard-empty--dark{color:#ffffffe6;text-align:center;background:#1a1a1a;border-radius:8px;justify-content:center;align-items:center;min-height:160px;padding:48px 24px}.block-dashboard-empty--dark .block-dashboard-empty-message{margin:0 0 12px;font-size:15px}.block-dashboard-empty--dark .dashboard-header-customize-btn{color:#fff;background:#ffffff26;border-color:#ffffff4d}.block-dashboard-empty--dark .dashboard-header-customize-btn:hover:not(:disabled){background:#ffffff40}.block-metrics-list,.block-anomalies-list{margin-bottom:16px}.block-metrics-list h3,.block-anomalies-list h3{color:var(--text-primary);margin:0 0 8px;font-size:14px;font-weight:600}.block-metrics-list ul,.block-anomalies-list ul{margin:0;padding:0;list-style:none}.block-metrics-list li,.block-anomalies-list li{border-bottom:1px solid var(--border-primary,#e5e7eb);align-items:center;gap:12px;padding:6px 0;font-size:14px;display:flex}.block-metric-period,.block-anomaly-period{min-width:100px;color:var(--text-secondary)}.block-metric-value{font-weight:500}.block-metric-id{color:var(--text-secondary);font-size:12px}.block-anomaly-message{flex:1}.dashboard-header{margin-bottom:16px;padding:0}.dashboard-header-single-row{border-bottom:1px solid var(--border-primary,#e5e7eb);background-color:var(--bg-secondary,#f9fafb);box-sizing:border-box;border-radius:0;flex-wrap:wrap;align-items:center;gap:16px;width:100%;margin-bottom:0;padding:10px 16px;display:flex}.dashboard-header-left{flex:0 auto;min-width:0}.dashboard-header-compare{flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.dashboard-header-customize-btn{color:var(--brand-primary,#ad35fa);border:1px solid var(--brand-primary,#ad35fa);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;margin-left:auto;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s}.dashboard-header-customize-btn:hover{background:var(--brand-primary-light,#ad35fa1a)}[data-theme=dark] .dashboard-header-single-row,.dark .dashboard-header-single-row{border-color:var(--border-primary);background-color:var(--bg-secondary)}.dashboard-district-navigation{width:100%;max-width:100%}.dashboard-header-selector{margin-bottom:20px}.dashboard-comparison-selector{border-bottom:1px solid var(--border-primary,#e5e7eb);background-color:var(--bg-secondary,#f9fafb);-webkit-overflow-scrolling:touch;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:6px;padding:7px 20px;display:flex;overflow-x:auto}.comparison-selector-content{flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.comparison-selector-label{color:var(--text-primary,#111827);white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:500}.comparison-selector-dropdown{color:var(--text-primary,#111827);background-color:var(--bg-primary,#fff);border:1px solid var(--border-color,#d1d5db);cursor:pointer;appearance:none;white-space:nowrap;text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:10px;border-radius:6px;flex-shrink:0;min-width:120px;max-width:180px;padding:5px 28px 5px 10px;font-size:13px;font-weight:500;transition:all .15s;overflow:hidden}.comparison-selector-dropdown:hover{border-color:var(--primary-color,#ad35fa);background-color:var(--bg-hover,#f9fafb)}.comparison-selector-dropdown:focus{border-color:var(--primary-color,#ad35fa);outline:none;box-shadow:0 0 0 3px #ad35fa1a}[data-theme=dark] .comparison-selector-dropdown,.dark .comparison-selector-dropdown{background-color:var(--bg-primary,#111827);border-color:var(--border-primary,#374151);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23d1d5db' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}[data-theme=dark] .comparison-selector-dropdown:hover,.dark .comparison-selector-dropdown:hover{border-color:var(--primary-color,#ad35fa);background-color:var(--bg-secondary,#1f2937)}@media (max-width:640px){.dashboard-header-single-row{gap:8px 12px;padding:8px}.dashboard-header-left{flex:auto;min-width:0}.dashboard-header-customize-btn{flex-shrink:0;order:2;margin-left:0;padding:6px 10px;font-size:12px}.dashboard-header-compare{flex-basis:100%;order:3;gap:4px;width:100%;margin-top:2px}.dashboard-section .metrics-table-container{margin-top:0}.metrics-table-container>.metrics-category-section:first-child{margin-top:0;padding-top:0}.metrics-category-section:first-child .metrics-table-header{margin-bottom:0}.metrics-table-body>.metrics-subcategory-header:first-child{margin-top:0;padding-top:0}.comparison-selector-label{font-size:12px}.comparison-selector-dropdown{background-position:right 5px center;background-size:9px;min-width:110px;max-width:150px;padding:4px 24px 4px 8px;font-size:12px}}.dashboard-title{color:var(--text-primary);margin:0;font-size:22px;font-weight:600}.official-selector{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.official-selector-label{color:var(--text-primary);margin-left:8px;font-size:16px;font-weight:500}.official-selector-header{align-items:center;display:flex}.official-selector-dropdown{color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:6px;min-width:280px;padding:8px 36px 8px 14px;font-size:16px;font-weight:500;transition:all .2s;box-shadow:0 1px 3px #0000001a}.official-selector-dropdown:hover{border-color:var(--brand-primary);box-shadow:0 2px 4px #0000001f}.official-selector-dropdown:focus{border-color:var(--brand-primary);outline:none;box-shadow:0 0 0 2px #ad35fa26,0 2px 4px #0000001f}[data-theme=dark] .official-selector-dropdown,.dark .official-selector-dropdown{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23aaa' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}@media (max-width:640px){.official-selector{flex-direction:column;align-items:flex-start;gap:8px}.official-selector-dropdown{width:100%;min-width:100%;padding:7px 32px 7px 12px;font-size:14px}.official-selector-label{margin-top:4px;margin-left:0;font-size:14px}.dashboard-title{font-size:18px}}.metrics-cards-container{box-sizing:border-box;flex-direction:column;gap:24px;width:100%;max-width:100%;display:flex}.metrics-category-section{margin-bottom:8px}.metrics-category-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-primary);margin:0 0 12px;padding:0 0 8px 16px;font-size:14px;font-weight:600}.metrics-cards-grid{flex-direction:column;gap:16px;width:100%;display:flex}.metrics-cards-grid>*{width:100%}.metric-card-dashboard{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:0;transition:all .2s;overflow:hidden}.metric-card-dashboard:hover{border-color:var(--brand-primary);box-shadow:0 2px 8px #00000014}[data-theme=dark] .metric-card-dashboard:hover,.dark .metric-card-dashboard:hover{box-shadow:0 2px 8px #0000004d}.metric-card-header-row{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);grid-template-columns:2fr 1fr 1fr 1.2fr;gap:12px;padding:12px 16px;font-size:11px;font-weight:600;display:grid}.metric-card-row,.metric-card-row-loading{grid-template-columns:2fr 1fr 1fr 1.2fr;align-items:center;gap:12px;padding:14px 16px;display:grid}@media (max-width:768px){.metric-card-header-row,.metric-card-row,.metric-card-row-loading{grid-template-columns:1.5fr .9fr .9fr 1fr;gap:8px;padding:12px}.metric-card-header-label{font-size:10px}.metric-card-name,.metric-value-number,.metric-delta-value,.metric-percent-value{font-size:13px}.metric-change-container{gap:1px}}@media (max-width:640px){.city-view .tab-content-wrapper .tab-content{padding:0!important}.dashboard-section{width:100%;max-width:100%;margin:0;padding:0 8px}.metrics-cards-container,.metrics-category-section{width:100%;max-width:100%;margin:0}.metric-card-header-row,.metric-card-row,.metric-card-row-loading{grid-template-columns:1.2fr .8fr .8fr .9fr;gap:6px;width:100%;max-width:100%;margin:0;padding:10px 12px}.metrics-cards-grid,.metric-card-dashboard{width:100%;max-width:100%;margin:0}.metric-card-header-label{font-size:9px}.metric-card-name,.metric-value-number,.metric-delta-value,.metric-percent-value{font-size:12px}.metric-change-container{gap:1px}.metric-date-range-label{font-size:9px}}.metric-card-row-loading{justify-items:center;min-height:60px}.metric-card-cell{align-items:center;font-size:14px;display:flex}.metric-name-cell{color:var(--text-primary);font-weight:600}.metric-value-cell,.metric-change-cell{font-variant-numeric:tabular-nums;justify-content:flex-end}.metric-change-container{flex-direction:column;align-items:flex-end;gap:2px;line-height:1.2;display:flex}.metric-change-row{align-items:center;display:flex}.metric-card-header-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:11px;font-weight:600}.metric-card-header-label:not(.metric-name-cell .metric-card-header-label),.metric-change-cell .metric-card-header-label{text-align:right}.metric-header-value-container{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.metric-name-container{flex-direction:column;gap:4px;display:flex}.metric-card-name{color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.4}.metric-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.metric-card-title{color:var(--text-primary);flex:1;margin:0;font-size:14px;font-weight:600;line-height:1.3}.metric-delta-badge{white-space:nowrap;border-radius:12px;flex-shrink:0;padding:3px 8px;font-size:12px;font-weight:600;line-height:1}.metric-delta-badge.positive{color:#2e7d32;background:#2e7d321f}.metric-delta-badge.negative{color:#c62828;background:#c628281f}.metric-delta-badge.neutral{background:var(--bg-secondary);color:var(--text-secondary)}[data-theme=dark] .metric-delta-badge.positive,.dark .metric-delta-badge.positive{color:#81c784;background:#4caf5033}[data-theme=dark] .metric-delta-badge.negative,.dark .metric-delta-badge.negative{color:#ef5350;background:#ef535033}.metric-card-date-range{color:var(--text-secondary);margin-top:-4px;font-size:11px}.metric-card-sparkline{justify-content:center;align-items:center;width:100%;min-height:120px;margin:4px 0;display:flex}.metric-card-values{border-top:1px solid var(--border-primary);justify-content:space-between;gap:12px;padding-top:8px;display:flex}.metric-value-item{flex-direction:column;gap:2px;display:flex}.metric-value-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:500}.metric-value-container{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.metric-date-range-label{color:var(--text-tertiary);text-align:right;white-space:nowrap;opacity:.8;font-size:10px;font-weight:400;line-height:1.2}[data-theme=dark] .metric-date-range-label,.dark .metric-date-range-label{opacity:.7}.metric-value-number{font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:14px;font-weight:500}.metric-value-number.current{color:var(--text-primary);font-weight:600}.metric-value-number.prior{color:var(--text-secondary)}.metric-delta-value{font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:13px;font-weight:500}.metric-delta-value.positive{color:#2e7d32}.metric-delta-value.negative{color:#c62828}[data-theme=dark] .metric-delta-value.positive,.dark .metric-delta-value.positive{color:#81c784}[data-theme=dark] .metric-delta-value.negative,.dark .metric-delta-value.negative{color:#ef5350}.metric-percent-value{font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:13px;font-weight:600}.metric-percent-value.good{color:#2e7d32}.metric-percent-value.bad{color:#c62828}[data-theme=dark] .metric-percent-value.good,.dark .metric-percent-value.good{color:#81c784}[data-theme=dark] .metric-percent-value.bad,.dark .metric-percent-value.bad{color:#ef5350}.metric-percent-value.positive{color:#2e7d32}.metric-percent-value.negative{color:#c62828}[data-theme=dark] .metric-percent-value.positive,.dark .metric-percent-value.positive{color:#81c784}[data-theme=dark] .metric-percent-value.negative,.dark .metric-percent-value.negative{color:#ef5350}.ytd-placeholder{text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border-radius:8px;padding:48px}.ytd-placeholder p{margin:8px 0}.no-data-message{background:var(--bg-secondary);border:1px solid var(--border-primary);text-align:center;border-radius:8px;margin-bottom:20px;padding:24px}.no-data-message p{color:var(--text-secondary);margin:8px 0}.no-data-message p:first-child{color:var(--text-primary);font-size:16px}.text-secondary{color:var(--text-secondary);font-size:14px}.metrics-table-container{flex-direction:column;gap:16px;width:100%;display:flex}.metrics-table-header{background:var(--bg-secondary);border:1px solid var(--border-primary);border-bottom:none;border-left:none;border-right:none;border-radius:0;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:16px;padding:8px 16px;display:grid}.metric-col{flex-direction:column;gap:2px;min-width:0;display:flex}.metrics-table-header .metric-col{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.metric-col-name{justify-content:center}.metric-col-value,.metric-col-change{text-align:right;align-items:flex-end}.metrics-table-body{border:1px solid var(--border-primary);border-left:none;border-right:none;border-radius:0;flex-direction:column;display:flex;overflow:hidden}.metrics-table-row{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);min-height:44px;color:inherit;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:16px;padding:9px 16px;text-decoration:none;transition:background .15s;display:grid;position:relative}@media (hover:hover){.metric-col-hoverable{position:relative}.metric-col-tooltip{z-index:100;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.metric-col-hoverable:hover .metric-col-tooltip{opacity:1;visibility:visible}.metric-col-tooltip-inner{background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-primary);white-space:nowrap;border-radius:6px;padding:8px 12px;font-size:11px;line-height:1.4;box-shadow:0 4px 12px #0000001f}}@media (hover:none){.metric-col-tooltip{display:none}}a.metrics-table-row{display:grid}button.metrics-table-row{text-align:left;font-family:inherit;font-size:inherit;color:inherit;display:grid}.metrics-table-row:last-child{border-bottom:none}.metrics-table-row:hover{background:var(--bg-secondary)}.metrics-table-row .metric-col-name{justify-content:flex-start;padding-top:4px;padding-left:8px}.metrics-table-row .metric-col-value{padding-top:4px}.metrics-table-row .metric-col-change{padding-top:9px;padding-right:8px}.metric-metadata{color:var(--text-tertiary,#9ca3af);margin-top:1px;margin-bottom:6px;font-size:10px;line-height:1.2}.metric-through-stale{color:var(--text-tertiary,#9ca3af);opacity:.85;font-style:italic}.metric-date-label{color:var(--text-tertiary);opacity:.8;margin-bottom:1px;font-size:10px;font-weight:400;line-height:1.4}.metric-date-cutoff{color:var(--text-tertiary,#6b7280);border-bottom:1px dashed var(--text-tertiary,#9ca3af);font-weight:500}.metric-value{font-variant-numeric:tabular-nums;color:var(--text-primary);font-size:15px;font-weight:600}.change-indicator{justify-content:flex-end;align-items:center;gap:6px;display:flex}.change-arrow{font-size:16px;font-weight:600}.change-values{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.change-absolute{font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.change-percent{font-variant-numeric:tabular-nums;opacity:.9;font-size:11px;font-weight:500}.change-indicator.good{color:#2e7d32}.change-indicator.bad{color:#c62828}.change-indicator.neutral{color:var(--text-secondary)}[data-theme=dark] .change-indicator.good,.dark .change-indicator.good{color:#81c784}[data-theme=dark] .change-indicator.bad,.dark .change-indicator.bad{color:#ef5350}.change-na{color:var(--text-tertiary);font-size:14px}@media (max-width:768px){.metrics-table-header,.metrics-table-row{grid-template-columns:1.5fr .9fr .9fr 1fr;gap:10px;padding:12px}.metrics-table-header .metric-col{font-size:10px}.metric-name{font-size:13px}.metric-metadata{font-size:10px}.metric-value{font-size:14px}.change-absolute{font-size:12px}.change-percent{font-size:10px}}@media (max-width:640px){.metrics-table-container{width:100%;max-width:100%;margin:0;padding:0;overflow-x:visible}.metrics-table-header{box-sizing:border-box;grid-template-columns:2fr 1fr 1fr 1fr;gap:8px;width:100%;max-width:100%;padding:12px 6px}.metrics-table-row{box-sizing:border-box;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);grid-template-columns:2fr 1fr 1fr 1fr;align-items:center;gap:8px;width:100%;max-width:100%;min-height:auto;padding:12px 6px}.metrics-table-body{border:1px solid var(--border-primary);background:var(--bg-primary);border-left:none;border-right:none;width:100%;max-width:100%;margin:0;padding:0}.metrics-table{border-radius:0;width:100%;max-width:100%;margin:0}.metric-date-label{margin-bottom:2px;font-size:9px;line-height:1.4}.metrics-table-row .metric-col-value{padding-top:4px}.metric-name{margin:0;font-size:13px;font-weight:500;line-height:1.4}.metrics-table-row .metric-col-name{justify-content:flex-start;padding-top:0;padding-left:4px}.metrics-table-row .metric-col-change{padding-top:0;padding-right:4px}.metric-value{font-size:14px;font-weight:600;line-height:1.3}.change-arrow{font-size:16px;line-height:1}.change-absolute{font-size:12px;font-weight:600;line-height:1.3}.change-percent{font-size:10px;line-height:1.3}.metric-col{gap:1px}.metric-col-value,.metric-col-change{text-align:right;align-items:flex-end}.change-indicator{gap:4px}.change-values{gap:0}}.metrics-subcategory-header{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);align-items:center;padding:4px 16px;display:flex}.metrics-subcategory-title{color:var(--text-tertiary,#9ca3af);text-transform:capitalize;letter-spacing:.2px;padding-left:0;font-size:10px;font-weight:400}[data-theme=dark] .metrics-subcategory-header,.dark .metrics-subcategory-header{background:var(--bg-primary)}[data-theme=dark] .metrics-subcategory-title,.dark .metrics-subcategory-title{color:var(--text-tertiary,#6b7280)}@media (max-width:640px){.metrics-subcategory-header{width:100%;margin:0;padding:8px 6px}.metrics-subcategory-title{padding-left:0;font-size:10px;font-weight:400;line-height:1.4}}.admin-section{padding:0}.admin-section h2{color:var(--text-primary);margin:0 0 16px;font-size:20px;font-weight:600}.admin-section h3{color:var(--text-primary);margin:0 0 12px;font-size:16px;font-weight:600}.anomalies-section{flex-direction:column;height:100%;min-height:0;padding:0;display:flex}.city-view .tab-content-wrapper.anomalies-tab .tab-content{padding-bottom:0;overflow-y:hidden}.newsletters-section{flex-direction:column;height:100%;min-height:0;padding:0;display:flex}.city-view .tab-content-wrapper.newsletters-tab .tab-content{padding-bottom:0;overflow-y:auto}.statistics-section{margin-bottom:32px}.statistics-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:12px}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px}.stat-value{color:var(--text-primary);font-size:20px;font-weight:600}.city-data-table{margin-bottom:24px}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;background:var(--bg-secondary);width:200px;color:var(--text-primary);padding:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--border-primary);color:var(--text-primary);padding:12px}.data-table td a{color:var(--brand-primary);text-decoration:none}.data-table td a:hover{text-decoration:underline}.status-badge{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:12px;font-weight:500;display:inline-block}.status-badge.active{color:#065f46;background:#d1fae5}.status-badge.inactive{color:#991b1b;background:#fee2e2}.status-badge.status-complete{color:#065f46;background:#d1fae5}.status-badge.status-partial{color:#92400e;background:#fef3c7}.status-badge.status-not_started,.status-badge.status-unknown{color:#991b1b;background:#fee2e2}.status-badge.status-success{color:#065f46;background:#d1fae5}.status-badge.status-error{color:#991b1b;background:#fee2e2}.data-refresh-section{margin-bottom:24px}.error-text{color:#dc2626;font-family:monospace;font-size:12px}.city-structure-info{margin-bottom:24px}.structure-sections{grid-template-columns:1fr 1fr;gap:24px;display:grid}.structure-section h3{color:var(--text-primary);margin:0 0 12px;font-size:16px;font-weight:600}.structure-section ul{margin:0;padding:0;list-style:none}.structure-section li{border-bottom:1px solid var(--border-primary);color:var(--text-primary);padding:8px 0}.structure-section p{color:var(--text-secondary);font-style:italic}.city-metrics-list{margin-top:16px}.metrics-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.metric-card{border:1px solid var(--border-primary);cursor:pointer;background:var(--bg-primary);border-radius:8px;padding:16px;transition:all .2s}.metric-card:hover{border-color:var(--brand-primary);transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.metric-card h4{color:var(--text-primary);margin:0 0 4px;font-size:16px;font-weight:500}.metric-key{color:var(--text-secondary);margin:4px 0;font-family:monospace;font-size:12px}.metric-category{color:var(--text-secondary);margin:4px 0;font-size:14px}.metric-status{color:var(--text-secondary);margin-top:8px;font-size:12px}.metrics-list{flex-direction:column;gap:8px;margin-top:16px;display:flex}.metric-item{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;align-items:center;padding:12px 16px;transition:all .2s;display:flex}.metric-item:hover{border-color:var(--brand-primary);background:var(--bg-secondary)}.metric-name{color:var(--text-primary);font-size:15px;font-weight:500;line-height:1.5}.metrics-table-container{margin-top:16px;overflow-x:auto}.metrics-table{border-collapse:collapse;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;width:100%;overflow:hidden}.metrics-table thead{background:var(--bg-secondary)}.metrics-table th{text-align:left;color:var(--text-primary);border-bottom:2px solid var(--border-primary);padding:10px 12px;font-size:14px;font-weight:600}.metrics-table th.ytd-column{text-align:right}.metrics-table td{border-bottom:1px solid var(--border-primary);color:var(--text-primary);padding:10px 12px;font-size:14px}.metrics-table tbody tr:last-child td{border-bottom:none}.metrics-table .category-header-row{background:var(--bg-tertiary)}.metrics-table .category-header{color:var(--text-primary);border-bottom:2px solid var(--border-primary);padding:10px 16px;font-size:15px;font-weight:600}.metrics-table .metric-row{transition:background-color .2s}.metrics-table .metric-row:hover{background:var(--bg-secondary)}.metrics-table .metric-name-cell{min-width:120px}.metrics-table .metric-name{font-weight:500}.metrics-table .data-through-date{color:var(--text-secondary);font-size:11px}.metrics-table .ytd-cell{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;width:60px}.metrics-table .delta-cell{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;width:50px}.metrics-table th.delta-column{text-align:right}@media (max-width:768px){.metrics-table-container{width:100%;max-width:100%;overflow-x:visible}.metrics-table{box-sizing:border-box;width:100%;min-width:100%;max-width:100%}.metrics-table th,.metrics-table td{padding:6px 8px;font-size:12px}.metrics-table .metric-name-cell{min-width:80px}.metrics-table .metric-name{font-size:12px;line-height:1.3}.metrics-table .data-through-date{font-size:10px}.metrics-table .ytd-cell,.metrics-table .delta-cell{width:auto;padding:6px 4px;font-size:12px}.city-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-primary);background:#fffffff2;flex-direction:row;align-items:center;gap:12px;height:56px;margin-bottom:0;padding:12px 16px;box-shadow:0 2px 8px #0000001a}[data-theme=dark] .city-header,.dark .city-header{border-bottom-color:var(--border-primary,#374151);background:#1f2937f2}.city-header-left{flex:1;min-width:0;padding-left:16px}.city-header-hamburger{width:36px;height:36px;padding:var(--space-xs)}.city-header-hamburger span{width:18px}.city-name{text-overflow:ellipsis;white-space:nowrap;font-size:20px;overflow:hidden}.city-header-right{flex-shrink:0;gap:16px;padding-right:16px}.structure-sections,.metrics-grid{grid-template-columns:1fr}.statistics-grid{grid-template-columns:repeat(2,1fr)}.city-header-overlay{padding:12px 0}.city-header-overlay .city-header-left{padding-left:52px;padding-right:0}.city-header-overlay .city-header-hamburger{width:36px;height:36px;padding:var(--space-xs)}.city-header-overlay .city-header-hamburger span{width:18px}.city-header-overlay .city-header-right{gap:16px;padding-left:0;padding-right:16px}.tabs-container-overlay{padding:0}.tabs-container-overlay .tab-btn:first-child{margin-left:16px}.tabs-container-overlay .tab-btn:last-child{margin-right:16px}.tab-content#map-tab.active.map-tab-fullscreen{margin:0;padding:0}.tab-content-wrapper .tab-content{height:calc(100dvh - 104px);margin-top:104px;padding:0!important}.tab-content-wrapper .city-header-overlay,.tab-content-wrapper .tabs-container-overlay{width:100vw;left:0;right:0}}@media (max-width:480px){.city-header-overlay .city-header-left{padding-left:48px}}
