@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap";
:root{--accent:#4e8af7;--accent-hover:#7561d4;--accent-10:#4e8af71a;--accent-05:#4e8af70d;--accent-green:#2b5945;--accent-green-10:#2b59451a;--secondary:#7561d4;--color-error:#ff4136;--risk-critical:#ff4136;--risk-high:#f2c4bf;--risk-moderate:#8c7847;--risk-low:#a6f2cc;--bg-page:#0c0c0c;--bg-surface:#0d0e10;--bg-card:#202426;--bg-card-hover:#20262f;--bg-elevated:#1e2124;--bg-input:#0d0e10;--bg-sidebar:#1e2124;--bg-topbar:#1e2124;--bg-modal-overlay:#00000080;--bg-table-hover:#4e8af70d;--bg-dropdown:#202426;--text-primary:#efefef;--text-secondary:#b9b9b9;--text-muted:#8a8a8a;--text-disabled:#767676;--text-on-accent:#fff;--text-heading:#fff;--text-link:#4e8af7;--border-default:#595959;--border-subtle:#ababab1a;--border-input:#595959;--border-focus:#4e8af7;--border-width:.833333px;--shadow-dropdown:#0003 0px 8px 16px 0px;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0003;--shadow-lg:0 8px 24px #0003;--radius-none:0px;--radius-sm:2px;--radius-md:4px;--radius-lg:4px;--radius-xl:4px;--radius-pill:50px;--radius-full:60px;--font-sans:"Inter", "Alliance No.1", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-display:"Inter", "Alliance No.2", "Alliance No.1", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono:"JetBrains Mono", "Apercu Mono Pro", monospace;--text-xs:.555556rem;--text-sm:.888889rem;--text-base:1rem;--text-md:1rem;--text-lg:1.11111rem;--text-xl:1.88889rem;--text-2xl:1.88889rem;--text-3xl:2.22222rem;--text-4xl:2.77778rem;--leading-tight:1;--leading-snug:1.1765;--leading-normal:1.3889;--leading-relaxed:1.6;--space-1:3px;--space-2:10px;--space-3:15px;--space-4:20px;--space-5:24px;--space-6:30px;--space-8:60px;--space-10:80px;--space-12:100px;--space-16:100px;--sidebar-width:220px;--sidebar-collapsed:56px;--topbar-height:48px;--transition-fast:.15s;--transition-default:.25s ease-in-out;--transition-medium:.3s ease;--transition-slow:.35s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-page)}a{color:var(--text-link);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-page)}::-webkit-scrollbar-thumb{background:var(--border-default)}::-webkit-scrollbar-thumb:hover{background:var(--text-disabled)}.app-shell{background:var(--bg-page);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:var(--border-width) solid var(--border-default);transition:width var(--transition-default);z-index:20;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{height:var(--topbar-height);padding:0 var(--space-4);border-bottom:var(--border-width) solid var(--border-default);align-items:center;gap:var(--space-3);display:flex}.sidebar-logo{align-items:center;gap:var(--space-2);font-weight:700;font-size:var(--text-md);color:var(--accent);white-space:nowrap;letter-spacing:-.02em;display:flex}.sidebar-logo-icon{flex-shrink:0;width:24px;height:24px}.sidebar-nav{padding:var(--space-3) 0;gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);text-align:left;width:100%;transition:color var(--transition-fast), background var(--transition-fast);white-space:nowrap;background:0 0;border:none;font-weight:500;display:flex;position:relative}.sidebar-link:hover{color:var(--text-primary);background:var(--accent-05)}.sidebar-link.active{color:var(--accent);background:var(--accent-10)}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;height:24px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{flex-shrink:0;width:20px;height:20px}.sidebar-link-text{text-overflow:ellipsis;overflow:hidden}.sidebar-badge{background:var(--risk-critical);color:var(--text-on-accent);font-size:var(--text-xs);border-radius:var(--radius-full);text-align:center;min-width:18px;margin-left:auto;padding:1px 6px;font-weight:600;line-height:1.4}.sidebar-footer{padding:var(--space-4);border-top:var(--border-width) solid var(--border-default)}.sidebar-footer-text{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.05em;overflow:hidden}.topbar{height:var(--topbar-height);background:var(--bg-topbar);border-bottom:var(--border-width) solid var(--border-default);padding:0 var(--space-5);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.topbar-left,.topbar-right{align-items:center;gap:var(--space-3);display:flex}.topbar-toggle{color:var(--text-secondary);padding:var(--space-1);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;display:flex}.topbar-toggle:hover{color:var(--text-primary)}.topbar-city{font-size:var(--text-md);color:var(--text-heading);letter-spacing:-.01em;font-weight:600}.topbar-divider{background:var(--border-default);width:1px;height:20px}.main-area{flex-direction:column;flex:1;min-width:0;display:flex}.main-content{padding:var(--space-6);flex:1;overflow-y:auto}.card{background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-5);transition:background var(--transition-medium), border-color var(--transition-medium)}.card:hover{background:var(--bg-card-hover);border-color:var(--text-disabled)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);color:var(--text-heading);letter-spacing:-.01em;font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:600;font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:var(--border-width) solid var(--border-default);white-space:nowrap;background:var(--bg-card);z-index:1;position:sticky;top:0}.data-table td{padding:var(--space-3) var(--space-4);color:var(--text-secondary);border-bottom:var(--border-width) solid var(--border-subtle);white-space:nowrap}.data-table tr:hover td{background:var(--bg-table-hover);color:var(--text-primary)}.data-table .td-primary{color:var(--text-primary);font-weight:500}.data-table .td-mono{font-family:var(--font-mono);font-size:var(--text-xs)}.badge{border-radius:var(--radius-sm);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:600;line-height:var(--leading-relaxed);border:var(--border-width) solid;align-items:center;padding:2px 8px;display:inline-flex}.badge-critical{color:#ff4136;background:0 0;border-color:#ff4136}.badge-high{color:#f2c4bf;background:#f2c5c01a;border-color:#f2c4bf}.badge-moderate{color:#8c7847;background:#8c78471a;border-color:#8c7847}.badge-low{color:#a6f2cc;background:#a6f2cc1a;border-color:#a6f2cc}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);border-radius:var(--radius-none);border:var(--border-width) solid transparent;transition:background-color var(--transition-medium), border-color var(--transition-medium), color var(--transition-medium);white-space:nowrap;font-weight:400;line-height:1.4286;display:inline-flex}.btn-primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{color:var(--text-primary);border-color:var(--border-default);background:0 0}.btn-secondary:hover{background:var(--accent-05);border-color:var(--text-muted)}.btn-ghost{color:var(--text-secondary);padding:var(--space-2);background:0 0;border:none}.btn-ghost:hover{color:var(--text-primary);background:var(--accent-05)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-icon{padding:var(--space-2);width:32px;height:32px}.input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-input);border:var(--border-width) solid var(--border-input);border-radius:var(--radius-pill);transition:border-color var(--transition-fast);font-family:var(--font-sans);outline:none}.input:focus{border-color:var(--border-focus)}.input::placeholder{color:var(--text-disabled)}.select{appearance:none;padding-right:var(--space-8);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23767676' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat}.kpi-card{background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-5);gap:var(--space-2);flex-direction:column;display:flex}.kpi-value{font-family:var(--font-mono);font-size:var(--text-xl);color:var(--text-heading);letter-spacing:-.02em;font-weight:700;line-height:var(--leading-tight)}.kpi-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:400;font-family:var(--font-display)}.kpi-sublabel{font-size:var(--text-xs);color:var(--text-disabled);margin-top:var(--space-1)}.score-circle{border:var(--border-width) solid;background:0 0;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;display:flex}.score-circle-value{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;line-height:1}.score-circle-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:400;font-family:var(--font-display);margin-top:2px}.score-circle-lg{border-width:3px;width:120px;height:120px}.score-circle-lg .score-circle-value{font-size:var(--text-2xl)}.score-bar{background:var(--bg-surface);border-radius:3px;width:100%;height:6px;overflow:hidden}.score-bar-fill{height:100%;transition:width var(--transition-medium);border-radius:3px}.alert-card{background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);border-left:3px solid var(--border-default);gap:var(--space-2);transition:background var(--transition-fast);flex-direction:column;display:flex}.alert-card:hover{background:var(--bg-card-hover)}.alert-card.critical{border-left-color:#ff4136}.alert-card.high{border-left-color:#f2c4bf}.alert-card.moderate{border-left-color:#8c7847}.alert-card.low{border-left-color:#a6f2cc}.alert-card-header{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.alert-card-meta{align-items:center;gap:var(--space-2);display:flex}.alert-card-title{font-size:var(--text-sm);color:var(--text-heading);font-weight:600}.alert-card-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.alert-card-time{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.callout{background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4);gap:var(--space-3);align-items:flex-start;display:flex}.callout-icon{flex-shrink:0;width:20px;height:20px;margin-top:2px}.callout-content{flex:1;min-width:0}.callout-title{font-size:var(--text-sm);color:var(--text-heading);margin-bottom:var(--space-1);font-weight:600}.callout-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.callout-warning{border-left:3px solid #8c7847}.callout-warning .callout-icon{color:#8c7847}.callout-danger{border-left:3px solid #ff4136}.callout-danger .callout-icon{color:#ff4136}.callout-success{border-left:3px solid #a6f2cc}.callout-success .callout-icon{color:#a6f2cc}.callout-info{border-left:3px solid #4e8af7}.callout-info .callout-icon{color:#4e8af7}.spinner{border:3px solid var(--border-default);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}.spinner-lg{border-width:4px;width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.spinner-container{padding:var(--space-16);justify-content:center;align-items:center;width:100%;display:flex}.empty-state{padding:var(--space-16) var(--space-6);text-align:center;justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.empty-state-icon{width:48px;height:48px;color:var(--text-disabled)}.empty-state-title{font-size:var(--text-md);color:var(--text-secondary);font-weight:600}.empty-state-text{font-size:var(--text-sm);color:var(--text-muted);max-width:360px}.tab-bar{gap:var(--space-1);border-bottom:var(--border-width) solid var(--border-default);padding-bottom:0;display:flex}.tab{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-disabled);transition:color var(--transition-default), border-color var(--transition-default);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:400}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.dropdown{margin-top:var(--space-1);background:var(--bg-dropdown);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown);z-index:50;min-width:200px;animation:.15s dropdownIn;position:absolute;top:100%;right:0;overflow:hidden}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);text-align:left;cursor:pointer;width:100%;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;display:flex}.dropdown-item:hover{background:var(--accent-05);color:var(--text-primary)}.dropdown-item.active{color:var(--accent);background:var(--accent-10)}.modal-overlay{background:var(--bg-modal-overlay);z-index:100;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-elevated);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown);padding:var(--space-8);width:90%;max-width:640px;max-height:85vh;animation:.25s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{font-size:var(--text-lg);color:var(--text-heading);margin-bottom:var(--space-2);letter-spacing:-.02em;font-weight:700}.modal-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-6)}.stat-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-grid-3{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.filter-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;flex-wrap:wrap;display:flex}.filter-bar .input,.filter-bar .select{width:auto;min-width:160px}.section-heading{font-size:var(--text-md);color:var(--text-heading);letter-spacing:-.01em;font-weight:600}.section-subheading{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.view{gap:var(--space-6);flex-direction:column;display:flex}.view-header{align-items:center;gap:var(--space-4);display:flex}.view-header-info{flex:1}.quick-link{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--accent);transition:color var(--transition-default);cursor:pointer;background:0 0;border:none;padding:0;font-weight:400;display:inline-flex}.quick-link:hover{color:var(--accent-hover)}.toggle-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-pill);cursor:pointer;transition:background-color var(--transition-medium), border-color var(--transition-medium), color var(--transition-medium);font-weight:400}.toggle-btn.active{color:var(--accent);background:var(--accent-10);border-color:var(--accent)}.city-card{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-card);border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-medium), border-color var(--transition-medium);text-align:left;width:100%;display:flex}.city-card:hover{background:var(--bg-card-hover);border-color:var(--accent)}.city-card-info{flex:1;min-width:0}.city-card-name{font-size:var(--text-md);color:var(--text-heading);font-weight:600}.city-card-pop{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.city-card-score{align-items:flex-end;gap:var(--space-1);flex-direction:column;display:flex}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mr-auto{margin-right:auto}.text-accent{color:var(--accent)}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--text-sm)}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.w-full{width:100%}.grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.overflow-x-auto{overflow-x:auto}.table-wrapper{border:var(--border-width) solid var(--border-default);border-radius:var(--radius-md);overflow-x:auto}.table-wrapper .data-table th:first-child,.table-wrapper .data-table td:first-child{padding-left:var(--space-5)}.table-wrapper .data-table th:last-child,.table-wrapper .data-table td:last-child{padding-right:var(--space-5)}.pagination{padding:var(--space-3) 0;justify-content:space-between;align-items:center;display:flex}.pagination-info{font-size:var(--text-sm);color:var(--text-muted)}.detail-panel{background:var(--bg-surface);border-top:var(--border-width) solid var(--border-default);border-bottom:var(--border-width) solid var(--border-default);padding:var(--space-5);animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.detail-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.detail-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1);font-family:var(--font-display)}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}
