@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--clr-primary:#2d6a4f;--clr-primary-light:#40916c;--clr-primary-dark:#1b4332;--clr-accent:#0077b6;--clr-accent-light:#00b4d8;--clr-gold:#e09f3e;--clr-gold-light:#ffc857;--clr-danger:#e63946;--clr-warning:#f4a261;--clr-success:#2d6a4f;--clr-info:#0077b6;--clr-bg:#080e0b;--clr-surface:#0d1610;--clr-surface-2:#122018;--clr-card:#0f1c14;--clr-border:#ffffff12;--clr-text:#e4e4e7;--clr-text-secondary:#9ca3af;--clr-text-muted:#6b7280;--text-primary:#e4e4e7;--text-secondary:#9ca3af;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.2s;--duration-slow:.4s;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 30px #00000080;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--clr-bg)}body{font-family:var(--font-sans);background:var(--clr-bg);color:var(--clr-text);min-height:100vh;line-height:1.6}a{color:var(--clr-accent-light);transition:color var(--duration) var(--ease);text-decoration:none}a:hover{color:var(--clr-gold)}img{max-width:100%;display:block}.container{max-width:1280px;padding:0 var(--space-lg);margin:0 auto}.page{padding-top:var(--space-lg);padding-bottom:var(--space-3xl)}.nav{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--clr-border);padding:var(--space-md) 0;background:#0b0f19d9;position:sticky;top:0}.nav-inner{max-width:1280px;padding:0 var(--space-lg);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.nav-brand{align-items:center;gap:var(--space-sm);color:var(--clr-text);letter-spacing:-.02em;font-size:1.15rem;font-weight:700;display:flex}.nav-brand-dot{background:var(--clr-primary-light);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.nav-links{align-items:center;gap:var(--space-xs);list-style:none;display:flex}.nav-link{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--clr-text-secondary);transition:all var(--duration) var(--ease);cursor:pointer;font-size:.875rem;font-weight:500}.nav-link:hover{color:var(--clr-text);background:#ffffff0d}.nav-link.active{color:var(--clr-primary-light);background:#2d6a4f1f}.nav-mobile-toggle{color:var(--clr-text);cursor:pointer;padding:var(--space-sm);background:0 0;border:none;display:none}.card{background:var(--clr-card);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--duration) var(--ease)}.card:hover{border-color:#ffffff1f}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--clr-text-secondary);align-items:center;gap:var(--space-sm);font-size:.8rem;font-weight:600;display:flex}.card-value{color:var(--clr-text);font-size:1.75rem;font-weight:700;line-height:1.2}.card-subtitle{color:var(--clr-text-muted);margin-top:var(--space-xs);font-size:.8rem}.city-selector{gap:var(--space-sm);flex-wrap:wrap;display:flex}.city-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--duration) var(--ease);font-size:.85rem;font-weight:500}.city-btn:hover{border-color:var(--clr-primary-light);color:var(--clr-text)}.city-btn.active{background:var(--clr-primary-dark);border-color:var(--clr-primary-light);color:var(--clr-text)}.map-wrapper{border-radius:var(--radius-lg);border:1px solid var(--clr-border);background:var(--clr-surface);overflow:hidden}.map-container{width:100%;height:500px}.grid-2{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}.grid-5{gap:var(--space-md);grid-template-columns:repeat(5,1fr);display:grid}.section-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.section-title{color:var(--clr-text);align-items:center;gap:var(--space-sm);font-size:1.2rem;font-weight:600;display:flex}.section-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:100px;padding:2px 8px;font-size:.7rem;font-weight:600}.badge-live{color:var(--clr-danger);background:#e6394626}.badge-info{color:var(--clr-accent-light);background:#0077b626}.badge-success{color:var(--clr-primary-light);background:#2d6a4f26}.weather-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.weather-temp{color:var(--clr-text);font-size:2.5rem;font-weight:300;line-height:1}.weather-temp span{color:var(--clr-text-secondary);font-size:1.25rem}.weather-detail{align-items:center;gap:var(--space-sm);color:var(--clr-text-secondary);padding:var(--space-xs) 0;font-size:.85rem;display:flex}.news-list{gap:var(--space-md);flex-direction:column;display:flex}.news-item{gap:var(--space-md);padding:var(--space-md);background:var(--clr-card);border:1px solid var(--clr-border);border-radius:var(--radius-md);transition:all var(--duration) var(--ease);cursor:pointer;display:flex}.news-item:hover{border-color:#ffffff1f;transform:translateY(-1px)}.news-thumb{border-radius:var(--radius-sm);object-fit:cover;background:var(--clr-surface-2);flex-shrink:0;width:100px;height:72px}.news-content{flex:1;min-width:0}.news-title{color:var(--clr-text);margin-bottom:var(--space-xs);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.news-meta{align-items:center;gap:var(--space-sm);color:var(--clr-text-muted);font-size:.75rem;display:flex}.news-source{color:var(--clr-accent-light);font-weight:500}.aqi-value{font-size:3rem;font-weight:700;line-height:1}.aqi-good{color:#4ade80}.aqi-moderate{color:#fbbf24}.aqi-unhealthy-sensitive{color:#fb923c}.aqi-unhealthy{color:#f87171}.aqi-very-unhealthy{color:#c084fc}.aqi-hazardous{color:#be123c}.aqi-label{margin-top:var(--space-sm);border-radius:100px;padding:4px 12px;font-size:.85rem;font-weight:600;display:inline-block}.quake-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--clr-border);display:flex}.quake-item:last-child{border-bottom:none}.quake-mag{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1rem;font-weight:700;display:flex}.quake-mag-low{color:#4ade80;background:#4ade801f}.quake-mag-mid{color:#fbbf24;background:#fbbf241f}.quake-mag-high{color:#f87171;background:#f871711f}.quake-info{flex:1}.quake-place{color:var(--clr-text);font-size:.85rem;font-weight:500}.quake-time{color:var(--clr-text-muted);font-size:.75rem}.layer-controls{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.layer-toggle{border-radius:var(--radius-sm);border:1px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--duration) var(--ease);align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:500;display:flex}.layer-toggle:hover{border-color:#ffffff26}.layer-toggle.active{border-color:var(--clr-primary-light);color:var(--clr-primary-light);background:#2d6a4f1a}.layer-toggle-dot{border-radius:50%;width:8px;height:8px}.flood-gauge{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--clr-border);display:flex}.flood-gauge:last-child{border-bottom:none}.flood-level-bar{background:var(--clr-surface-2);width:100%;height:6px;margin-top:var(--space-xs);border-radius:3px;overflow:hidden}.flood-level-fill{height:100%;transition:width var(--duration-slow) var(--ease);border-radius:3px}.status-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.status-dot-live{background:var(--clr-danger);animation:1.5s infinite pulse-dot}.status-dot-ok{background:#4ade80}.status-dot-warn{background:var(--clr-warning)}.skeleton{background:linear-gradient(90deg, var(--clr-surface) 25%, var(--clr-surface-2) 50%, var(--clr-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--clr-text-muted)}.empty-state-icon{margin-bottom:var(--space-md);opacity:.4;font-size:2rem}.hero{padding:var(--space-3xl) 0 var(--space-2xl);text-align:center}.hero-title{letter-spacing:-.03em;margin-bottom:var(--space-md);font-size:2.5rem;font-weight:700;line-height:1.15}.hero-title-highlight{background:linear-gradient(135deg, var(--clr-primary-light), var(--clr-accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--clr-text-secondary);max-width:600px;margin:0 auto var(--space-xl);font-size:1.05rem;line-height:1.6}.tabs{gap:var(--space-xs);border-bottom:1px solid var(--clr-border);margin-bottom:var(--space-lg);display:flex;overflow-x:auto}.tab{padding:var(--space-sm) var(--space-md);color:var(--clr-text-muted);cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap;font-size:.85rem;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000}.tab:hover{color:var(--clr-text-secondary)}.tab.active{color:var(--clr-primary-light);border-bottom-color:var(--clr-primary-light)}.map-popup{font-family:var(--font-sans);font-size:.85rem;line-height:1.5}.map-popup h3{margin-bottom:4px;font-size:.95rem;font-weight:600}.map-popup p{color:#555;margin:2px 0}@media (max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-5{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.container{padding:0 var(--space-md)}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:.95rem}.grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:1fr}.map-container{height:350px}.nav-links{display:none}.nav-links.open{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-md);border-bottom:1px solid var(--clr-border);background:#0b0f19f2;flex-direction:column;display:flex;position:absolute;top:100%;left:0;right:0}.nav-mobile-toggle{display:block}.city-selector{gap:var(--space-xs)}.city-btn{padding:6px 10px;font-size:.8rem}.news-item{flex-direction:column}.news-thumb{width:100%;height:140px}}@media (max-width:480px){.hero-title{font-size:1.5rem}.card{padding:var(--space-md)}.weather-temp{font-size:2rem}}.leaflet-container{background:var(--clr-surface)!important;font-family:var(--font-sans)!important}.leaflet-control-zoom{overflow:hidden;border:1px solid var(--clr-border)!important;border-radius:var(--radius-sm)!important}.leaflet-control-zoom a{background:var(--clr-surface)!important;color:var(--clr-text)!important;border-color:var(--clr-border)!important}.leaflet-control-zoom a:hover{background:var(--clr-surface-2)!important}
