@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter+Tight:wght@300;400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Doto:wght@100..900&display=swap";@import"https://fonts.googleapis.com/css2?family=Rubik+80s+Fade:wght@400&display=swap";@import"https://fonts.googleapis.com/css2?family=Allerta+Stencil:wght@400&display=swap";@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap";@import"https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@300;400;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700;800&display=swap";@import"https://d2c87l0yth4zbw.cloudfront.net/fonts/ember/ember.css";.logo{display:flex;align-items:center;gap:.75rem;line-height:1}.logo-image{width:32px;height:32px;border-radius:50%;object-fit:cover}.logo-text{font-weight:200;font-style:normal;font-size:42px;color:#4a9bb8;font-family:Outfit,Expletus Sans,Lato,Roboto,DM Sans,Inter,sans-serif;line-height:1;display:flex;align-items:center;letter-spacing:normal}.unit-toggle{display:flex;align-items:center;margin-right:16px}.unit-toggle-container{display:flex;align-items:center;gap:8px;padding:4px 8px;background-color:#ffffff1a;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.unit-option{font-size:12px;font-weight:500;color:#6b7280;transition:color .2s ease;-webkit-user-select:none;user-select:none;min-width:45px;text-align:center;font-family:DM Sans,Inter,sans-serif}.unit-option.active{color:#1f2937;font-weight:600}.unit-slider{background:none;border:none;cursor:pointer;padding:0;margin:0 4px;outline:none}.slider-track{width:36px;height:18px;background-color:#e5e7eb;border-radius:12px;position:relative;transition:background-color .3s ease;border:1px solid #d1d5db}.slider-track.metric,.slider-track.imperial{background-color:#4a9bb8;border-color:#4a9bb8}.slider-thumb{width:14px;height:14px;background-color:#fff;border-radius:50%;position:absolute;top:1px;transition:transform .3s ease;box-shadow:0 1px 3px #0003}.slider-track.metric .slider-thumb{transform:translate(2px)}.slider-track.imperial .slider-thumb{transform:translate(18px)}.unit-slider:hover .slider-track{box-shadow:0 0 0 2px #86c5da33}.unit-slider:focus .slider-track{box-shadow:0 0 0 2px #86c5da66}@media (max-width: 768px){.unit-toggle{margin-right:12px}.unit-toggle-container{gap:6px;padding:3px 6px}.unit-option{font-size:11px;min-width:40px}.slider-track{width:32px;height:16px}.slider-thumb{width:12px;height:12px}.slider-track.imperial .slider-thumb{transform:translate(16px)}}.top-navbar{position:fixed;top:0;left:0;right:0;height:64px;background-color:#fff;border-bottom:1px solid #e1e5e9;z-index:1000;box-shadow:0 1px 3px #0000000a;transition:background-color .3s ease,border-color .3s ease}.navbar-container{max-width:100%;height:100%;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.navbar-left{display:flex;align-items:center}.navbar-logo{text-decoration:none;display:flex;align-items:center;transition:opacity .2s ease}.navbar-logo:hover{opacity:.8}.navbar-right{display:flex;align-items:center;gap:8px}.nav-item{display:flex;align-items:center;padding:8px 16px;color:#6b7280;text-decoration:none;font-size:14px;font-weight:500;border-radius:6px;transition:all .2s ease;cursor:pointer;border:none;background:none;font-family:DM Sans,Inter,sans-serif;white-space:nowrap}.nav-item:hover{color:#374151;background-color:#f9fafb}.nav-item.active{color:#1a1d29;background-color:#e1f3f9;font-weight:600}.nav-dropdown{position:relative}.dropdown-trigger{gap:6px}.dropdown-arrow{transition:transform .2s ease;color:#9ca3af}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:8px 0;z-index:1001}.dropdown-item{display:block;padding:10px 16px;color:#6b7280;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;border-radius:0;font-family:DM Sans,Inter,sans-serif}.dropdown-item:hover{color:#374151;background-color:#f9fafb}.dropdown-item.active{color:#1a1d29;background-color:var(--accent-color, #e1f4f8);font-weight:600}@media (max-width: 768px){.navbar-container{padding:0 16px}.navbar-right{gap:4px}.nav-item{padding:8px 12px;font-size:13px}.dropdown-menu{min-width:140px}}@media (max-width: 640px){.nav-item{padding:8px 10px;font-size:12px}.nav-item:not(.dropdown-trigger):not(.active){display:none}.nav-item.active{display:flex}}.git-info{display:flex;align-items:center;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:11px;color:#9ca3af;margin-right:16px;padding:4px 8px;background-color:#9ca3af1a;border-radius:4px;border:1px solid rgba(156,163,175,.2);-webkit-user-select:none;user-select:none;gap:8px}.git-service{display:flex;align-items:center;gap:2px}.git-service-label{font-weight:600;color:#6b7280;font-size:10px;margin-right:2px}.git-service-separator{color:#9ca3af;font-weight:300;margin:0 4px}.git-branch{font-weight:500;color:#6b7280}.git-separator{margin:0 4px;color:#9ca3af;font-weight:300}.git-commit{font-weight:400;color:#9ca3af;cursor:help;transition:color .2s ease}.git-commit:hover{color:#6b7280}@media (max-width: 768px){.git-info{font-size:10px;margin-right:12px;padding:3px 6px;gap:6px}.git-service-label{font-size:9px}.git-separator{margin:0 2px}.git-service-separator{margin:0 3px}}@media (max-width: 900px){.git-service:last-child,.git-service-separator{display:none}}@media (max-width: 640px){.git-info{display:none}}.footer{border-top:1px solid var(--border-color);color:var(--light-text-color);padding:1rem 0;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-left p{margin:0;font-size:.9rem}.footer-center{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.footer-link{color:var(--light-text-color);text-decoration:none;transition:color .2s ease}.footer-link:hover{color:var(--primary-color);text-decoration:underline}.footer-separator{color:var(--border-color);font-weight:700}.footer-right{display:flex;align-items:center}@media (max-width: 768px){.footer-content{flex-direction:column;text-align:center;gap:.75rem}.footer-center{order:-1}.footer-right{justify-content:center}}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(100deg,#f9a8d41a,#a5b4fc1a,#7dd3fc1a);background-attachment:fixed;transition:background-color .3s ease}.main-content{margin-top:64px;padding:32px;flex:1;max-width:100%;transition:background-color .3s ease}@media (max-width: 768px){.main-content{padding:24px 16px}}@media (max-width: 640px){.main-content{padding:16px 12px}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px}.loading-logo-container{position:relative;margin-bottom:1.5rem}.loading-logo{width:60px;height:60px;border-radius:50%;object-fit:cover;z-index:2;position:relative;border:2px solid white;box-shadow:0 2px 8px #0000001a}.loading-spinner{position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;border:3px solid rgba(0,119,182,.1);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1.5s linear infinite}.loading-message{color:var(--light-text-color);font-size:1.1rem}.hero-metrics-shadcn{margin-bottom:32px}.metrics-refresh-indicator{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:8px 16px;background:#3b82f60d;border:1px solid rgba(59,130,246,.1);border-radius:8px;font-size:14px;color:#64748b}.refresh-dot{color:#3b82f6;animation:pulse 1.5s ease-in-out infinite}.refresh-text{font-weight:500}.metrics-grid-shadcn{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.hero-metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;cursor:pointer}.hero-metric-card:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.metric-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.metric-header h3{font-size:14px;font-weight:600;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.05em;font-family:Raleway,sans-serif}.metric-trend{font-size:12px;font-weight:600;padding:4px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.metric-value{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;line-height:1}.metric-value .value{font-size:28px;font-weight:700;color:#0f172a;font-family:Inter,sans-serif;letter-spacing:-.025em}.metric-value .unit{font-size:14px;font-weight:500;color:#64748b;margin-top:4px}.metric-description{font-size:14px;color:#64748b;margin:0;line-height:1.4;font-weight:500}.metric-description .station-link{color:#0077b6;text-decoration:none;font-size:inherit;font-weight:inherit;font-family:inherit;transition:color .2s ease}.metric-description .station-link:hover{color:#005a8b;text-decoration:underline}@media (max-width: 1024px){.metrics-grid-shadcn{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}}@media (max-width: 768px){.metrics-grid-shadcn{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.hero-metric-card{padding:20px}.metric-value .value{font-size:26px}.metric-header h3{font-size:13px}}@media (max-width: 640px){.metrics-grid-shadcn{grid-template-columns:1fr;gap:12px}.hero-metric-card{padding:18px}.metric-value .value{font-size:22px}}.metrics-footer{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.metrics-stats{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#6b7280}.metrics-stats .last-updated{color:#6b7280}.metrics-stats .total-metrics{color:#6b7280;font-weight:500}.mini-trend-chart{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;cursor:pointer}.mini-trend-chart:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.trend-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.metric-title{display:flex;align-items:center;gap:8px}.metric-icon{font-size:16px;opacity:.8}.trend-title{font-size:14px;font-weight:600;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.05em;font-family:DM Sans,Raleway,sans-serif}.trend-indicator{display:flex;align-items:center;gap:4px}.trend-arrow{flex-shrink:0}.trend-percentage{font-size:12px;font-weight:600;padding:4px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-family:DM Sans,Inter,sans-serif}.trend-percentage.positive{color:#059669;background:#d1fae5}.trend-percentage.negative{color:#dc2626;background:#fee2e2}.trend-percentage.neutral{color:#6b7280;background:#f3f4f6}.trend-value{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;line-height:1}.current-value{font-size:28px;font-weight:700;color:#4b5563;font-family:Inter,sans-serif;letter-spacing:-.025em}.value-unit{font-size:14px;font-weight:500;color:#64748b;margin-top:4px;font-family:DM Sans,Inter,sans-serif}.trend-description{font-size:14px;color:#64748b;margin:0;line-height:1.4;font-weight:500;font-family:DM Sans,Inter,sans-serif}.trend-description .station-link{color:#0077b6;text-decoration:none;font-size:inherit;font-weight:inherit;font-family:inherit;transition:color .2s ease}.trend-description .station-link:hover{color:#005a8b;text-decoration:underline}@media (max-width: 768px){.mini-trend-chart{padding:20px}.current-value{font-size:26px}.trend-title{font-size:13px}}@media (max-width: 640px){.mini-trend-chart{padding:18px}.current-value{font-size:22px}.trend-title{font-size:12px}}.regional-comparison{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column}.regional-comparison:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.04) 0%,transparent 40%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.regional-comparison:hover:before{opacity:1}.regional-comparison:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.regional-comparison>*{position:relative;z-index:2}.comparison-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.region-summary{display:flex;gap:8px;flex-wrap:wrap}.region-badge{display:flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;transition:all .2s ease}.region-badge:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.region-code{font-size:11px;font-weight:700;font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:.05em;color:#000}.region-stations{font-size:10px;font-weight:500;color:#374151;background:#f8fafc;padding:2px 4px;border-radius:3px}.comparison-cards-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.horizontal-metric-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;transition:all .3s ease;display:flex;flex-direction:column;min-height:240px;height:auto}.horizontal-metric-card:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.metric-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.metric-card-header h4{font-size:13px;font-weight:600;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.05em;font-family:DM Sans,Raleway,sans-serif}.metric-leader{font-size:11px;font-weight:500;color:#64748b;background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:DM Sans,Inter,sans-serif}.horizontal-bars-container{flex:1;display:flex;flex-direction:column;gap:6px;min-height:200px}.horizontal-bar-row{display:flex;align-items:center;width:100%;padding:3px 0;box-sizing:border-box}.region-info{flex:0 0 180px;display:flex;justify-content:space-between;align-items:center;padding-right:12px;box-sizing:border-box}.horizontal-bar-track{flex:0 0 80px;height:16px;background:#e2e8f0;border-radius:8px;position:relative;overflow:hidden;margin-right:12px}.region-stats{flex:0 0 60px;display:flex;align-items:center;justify-content:center;gap:4px}.region-name{font-size:11px;font-weight:500;color:#374151;white-space:nowrap;font-family:DM Sans,Inter,sans-serif}.region-value{font-size:11px;font-weight:700;color:#0f172a;font-family:Inter,sans-serif}.horizontal-bar-fill{height:100%;border-radius:6px;transition:width .8s ease;min-width:2px}.station-count{font-size:10px;font-weight:500;color:#64748b;background:#f1f5f9;padding:1px 4px;border-radius:3px;min-width:20px;text-align:center;display:inline-block;font-family:DM Sans,Inter,sans-serif}.region-trend{font-size:9px;font-weight:600;padding:1px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-family:DM Sans,Inter,sans-serif}.region-trend.positive{color:#059669;background:#d1fae5}.region-trend.negative{color:#dc2626;background:#fee2e2}.comparison-footer{margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9}.comparison-note{font-size:12px;color:#64748b;margin:0;text-align:center;font-style:italic;font-family:DM Sans,Inter,sans-serif}@media (max-width: 1024px){.comparison-cards-grid{grid-template-columns:1fr;gap:12px}.horizontal-metric-card{padding:14px;height:130px}.horizontal-bars-container{max-height:80px}}@media (max-width: 768px){.regional-comparison{padding:20px}.comparison-header{flex-direction:column;gap:12px;align-items:flex-start}.region-summary{gap:6px}.comparison-cards-grid{gap:10px}.horizontal-metric-card{padding:12px;height:120px}.horizontal-bars-container{max-height:70px}.horizontal-bar-row{grid-template-columns:1fr 1.5fr auto;gap:6px}.region-name,.region-value{font-size:10px}}@media (max-width: 640px){.regional-comparison{padding:16px}.comparison-cards-grid{gap:8px}.horizontal-metric-card{padding:10px;height:110px}.metric-card-header h4{font-size:12px}.metric-leader{font-size:10px;padding:1px 4px}.horizontal-bars-container{max-height:60px;gap:4px}.horizontal-bar-row{grid-template-columns:1fr 90px auto;gap:8px}.horizontal-bar-track{height:10px;min-width:40px}.region-name,.region-value{font-size:9px}.station-count{font-size:8px}.region-trend{font-size:8px;padding:1px 3px}.region-badge{padding:3px 6px;gap:4px}.region-code{font-size:10px}.region-stations{font-size:9px}}.custom-dropdown{position:relative;min-width:120px;z-index:9999999}.custom-dropdown.disabled{opacity:.5;cursor:not-allowed}.dropdown-button{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:120px}.dropdown-button:hover{border-color:#d1d5db}.dropdown-button:focus,.dropdown-button.open{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.custom-dropdown.disabled .dropdown-button{cursor:not-allowed;background:#f9fafb}.dropdown-text{font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#0f172a;flex:1;text-align:left}.custom-dropdown.disabled .dropdown-text{color:#9ca3af}.dropdown-arrow{font-size:10px;color:#6b7280;margin-left:8px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff!important;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 8px 25px #00000026;z-index:9999999!important;max-height:300px;overflow-y:auto;overflow-x:hidden!important;margin-top:4px;opacity:1!important;background-color:#fff!important;background-image:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;white-space:nowrap;box-sizing:border-box;isolation:isolate;background-clip:padding-box!important}.dropdown-option{font-family:Inter,sans-serif;padding:8px 12px;font-size:12px;font-weight:300;color:#0f172a!important;background:#fff!important;background-color:#fff!important;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f9fafb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background-image:none!important;box-sizing:border-box}.dropdown-option:hover{background:#eff6ff;color:#1e40af}.dropdown-option.selected{background:#eff6ff;color:#1e40af;font-weight:500}@media (max-width: 768px){.custom-dropdown{min-width:100px}.dropdown-button{min-width:100px;padding:6px 10px}.dropdown-text{font-size:13px}.dropdown-option{padding:6px 10px;font-size:13px}}@media (max-width: 640px){.custom-dropdown{min-width:80px}.dropdown-button{min-width:80px;padding:6px 8px}.dropdown-text{font-size:12px}.dropdown-option{padding:6px 8px;font-size:12px}}.station-filters{display:flex!important;flex-direction:column!important;gap:12px}.filters-primary{display:flex!important;gap:12px;align-items:end;flex-wrap:wrap;width:100%}.filters-secondary{display:flex!important;gap:12px;align-items:end;flex-wrap:wrap;position:relative;z-index:9999999;width:100%}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:120px}.filter-group label{font-size:12px;font-weight:500;color:#374151;margin-bottom:2px}.search-group{flex:1;min-width:200px}.search-input{width:100%;padding:8px 12px 8px 32px;border:1px solid #e2e8f0;border-radius:6px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#0f172a;background:#fff;transition:all .2s ease}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#6b7280;font-size:14px}.region-filter-group{flex:1;min-width:400px}.region-buttons{display:flex;gap:4px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.region-buttons::-webkit-scrollbar{display:none}.region-button{padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;font-family:Inter,sans-serif;font-size:10px;font-weight:500;color:#374151;background:transparent;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;min-width:fit-content}.region-button:hover,.region-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.filter-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#0f172a;background:#fff;cursor:pointer;transition:all .2s ease}.filter-select:hover{border-color:#d1d5db}.sort-controls{display:flex;gap:4px;position:relative;z-index:9999999}.sort-dropdown{flex:1;position:relative;z-index:9999999}.filter-dropdown{min-width:120px;position:relative;z-index:9999999}.sort-direction{padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-family:Inter,sans-serif;background:#fff;cursor:pointer;font-size:14px;font-weight:500;color:#0f172a;transition:all .2s ease;min-width:36px;display:flex;align-items:center;justify-content:center}.sort-direction:hover{border-color:#d1d5db}.sort-direction.desc{background:#eff6ff;color:#1e40af;border-color:#3b82f6}.advanced-toggle{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-family:Inter,sans-serif;background:#fff;cursor:pointer;font-size:12px;font-weight:500;color:#0f172a;transition:all .2s ease}.advanced-toggle:hover{border-color:#d1d5db}.advanced-toggle.active{background:#eff6ff;color:#1e40af;border-color:#3b82f6}.filters-advanced{display:flex;gap:12px;align-items:end;flex-wrap:wrap;padding:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.range-group{min-width:160px}.range-inputs{display:flex;align-items:center;gap:6px}.range-input{width:60px;padding:6px 8px;border:1px solid #e2e8f0;border-radius:4px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#0f172a;background:#fff;text-align:center;transition:all .2s ease}.range-input:hover{border-color:#d1d5db}.range-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.range-separator{font-size:12px;color:#6b7280;font-weight:500}.checkbox-group{min-width:140px}.checkbox-options{display:flex;gap:8px}.checkbox-option{display:flex;align-items:center;gap:4px;font-size:12px;color:#374151;cursor:pointer}.checkbox-option input[type=checkbox]{width:14px;height:14px;accent-color:#3b82f6}.filters-actions{display:flex;justify-content:space-between;align-items:center;padding-top:8px}.results-info{font-size:12px;color:#6b7280}.loading-text{color:#3b82f6;font-weight:500}.results-count{font-weight:500;color:#374151}.reset-filters{padding:6px 12px;border:1px solid #e2e8f0;border-radius:4px;font-family:Inter,sans-serif;background:#fff;color:#0f172a;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-filters:hover{border-color:#d1d5db;background:#f9fafb}.reset-filters:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.filters-primary{flex-direction:column;gap:8px}.filter-group,.search-group{min-width:auto}.filters-advanced{flex-direction:column;gap:8px}.range-group,.checkbox-group{min-width:auto}}@media (max-width: 640px){.sort-controls{flex-direction:column}.checkbox-options{flex-direction:column;gap:4px}.filters-actions{flex-direction:column;gap:8px;align-items:stretch}}.station-status-card{background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;padding:12px;text-decoration:none;transition:all .2s ease;display:flex;flex-direction:column;gap:8px;cursor:pointer;position:relative}.station-status-card:hover{background:#fff;border-color:#e2e8f0;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.station-status-card.selected{background:#eff6ff;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.card-selection{position:absolute;top:8px;right:8px;z-index:10}.selection-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.station-status-header{display:flex;justify-content:space-between;align-items:flex-start;margin-right:20px}.station-info{flex:1}.station-name{font-size:12px;font-weight:600;color:#0f172a;margin:0 0 2px;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.station-id{font-size:10px;color:#64748b;font-weight:500}.status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:2px}.station-metrics{display:flex;flex-direction:column;gap:4px}.metric-item{display:flex;justify-content:space-between;align-items:center}.metric-label{font-size:10px;color:#64748b;font-weight:500}.metric-value{font-size:11px;font-weight:600;color:#0f172a}.station-details{display:flex;flex-direction:column;gap:3px;padding-top:4px;border-top:1px solid #f1f5f9}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:9px;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:10px;font-weight:600;color:#0f172a}.data-types{display:flex;gap:6px;padding-top:4px}.data-type{display:flex;align-items:center;gap:2px;padding:2px 4px;border-radius:4px;font-size:9px;font-weight:500}.data-type.available{background:#dcfce7;color:#166534}.data-type.unavailable{background:#fef2f2;color:#991b1b;opacity:.6}.data-type-icon{width:8px;height:8px;flex-shrink:0}.data-type-label{text-transform:uppercase;letter-spacing:.05em}.station-status-footer{display:flex;justify-content:space-between;align-items:center;padding-top:4px;border-top:1px solid #f1f5f9}.last-update{font-size:10px;color:#64748b;font-weight:500}.view-details{font-size:10px;color:#3b82f6;font-weight:600;transition:color .2s ease}.station-status-card:hover .view-details{color:#1d4ed8}@media (max-width: 768px){.station-status-card{padding:10px}.card-selection{top:6px;right:6px}.selection-checkbox{width:14px;height:14px}.station-status-header{margin-right:18px}}@media (max-width: 640px){.station-status-card{padding:8px}.card-selection{top:4px;right:4px}.station-name{font-size:11px}.station-status-header{margin-right:16px}}.bulk-actions{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:8px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.selection-info{display:flex;align-items:center;gap:8px}.selected-count{font-size:14px;font-weight:600;color:#0c4a6e}.action-badge{padding:3px 8px;border:1px solid #e2e8f0;border-radius:3px;background:transparent;color:#6b7280;font-size:9px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:Inter,monospace;text-transform:none;white-space:nowrap}.action-badge:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.action-badge:disabled{opacity:.5;cursor:not-allowed}.action-badge.compare{color:#3b82f6;border-color:#3b82f6}.action-badge.compare:hover:not(:disabled){background:#eff6ff}.action-badge.clear{color:#6b7280;border-color:#e2e8f0}.action-badge.clear:hover:not(:disabled){border-color:#ef4444;color:#ef4444;background:#fef2f2}@media (max-width: 640px){.bulk-actions{flex-direction:column;gap:8px;align-items:stretch}.action-buttons{justify-content:center}}.station-explorer{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column}.station-explorer:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.04) 0%,transparent 40%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.station-explorer:hover:before{opacity:1}.station-explorer:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.station-explorer>*{position:relative;z-index:2}.explorer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.header-title h3{font-size:16px;font-weight:600;color:#0f172a;margin:0 0 4px;font-family:Raleway,sans-serif}.header-title p{font-size:14px;color:#64748b;margin:0}.header-stats{display:flex;gap:12px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-item .stat-value{font-size:16px;font-weight:700;font-family:Inter,sans-serif;color:#0f172a}.stat-item.active .stat-value{color:#10b981}.stat-item .stat-label{font-size:11px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.station-filters{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f1f5f9;position:relative;z-index:99999999}.bulk-actions{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.explorer-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#64748b}.loading-spinner{width:24px;height:24px;border:2px solid #e2e8f0;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.explorer-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#64748b}.error-icon{font-size:32px;opacity:.6}.retry-button{background:#3b82f6;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.status-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;overflow-y:auto;max-height:400px;position:relative;z-index:1}.explorer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#64748b}.empty-icon{width:32px;height:32px;opacity:.6;color:#6b7280}.explorer-empty h4{font-size:16px;font-weight:600;margin:0;color:#0f172a}.explorer-empty p{font-size:14px;margin:0 0 16px}.quick-filters{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.quick-filter-button{background:transparent;color:#64748b;border:1px solid #e2e8f0;border-radius:6px;padding:8px 16px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.quick-filter-button:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.reset-filters-button{background:#3b82f6;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.reset-filters-button:hover{background:#2563eb}.explorer-footer{margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9}.results-summary{font-size:14px;color:#64748b;margin-bottom:8px}.selection-info{color:#3b82f6;font-weight:500}.load-more-hint p{font-size:12px;color:#64748b;margin:0;font-style:italic}@media (max-width: 768px){.station-explorer{padding:20px}.explorer-header{flex-direction:column;gap:12px;align-items:flex-start}.header-stats{gap:8px}.status-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}}@media (max-width: 640px){.station-explorer{padding:16px}.status-grid{grid-template-columns:1fr 1fr;gap:8px}}.spectral-wave-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column}.spectral-wave-panel:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.04) 0%,transparent 40%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.spectral-wave-panel:hover:before{opacity:1}.spectral-wave-panel:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.spectral-wave-panel>*{position:relative;z-index:2}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.header-controls{display:flex;align-items:center;gap:16px}.header-title h3{font-size:16px;font-weight:600;color:#0f172a;margin:0 0 4px;font-family:DM Sans,Raleway,sans-serif}.header-title p{font-size:14px;color:#64748b;margin:0;font-family:DM Sans,Inter,sans-serif}.auto-refresh{display:flex;align-items:center;gap:6px}.refresh-indicator{color:#10b981;font-size:8px;animation:pulse 2s infinite}.refresh-text{font-size:12px;color:#64748b;font-weight:500;font-family:DM Sans,Inter,sans-serif}.view-switcher{display:flex;gap:4px;background:#f8fafc;border-radius:6px;padding:2px}.view-button{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;background:transparent;color:#64748b;font-family:DM Sans,Inter,sans-serif}.view-button.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0000000d}.view-button:hover:not(.active){color:#374151}.view-icon{width:12px;height:12px;flex-shrink:0}.network-summary{margin-bottom:20px}.summary-stats{display:flex;gap:16px;justify-content:space-between}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1}.stat-value{font-size:18px;font-weight:600;color:#0f172a;font-family:Inter,sans-serif}.stat-label{font-size:11px;color:#64748b;font-weight:500;margin-top:2px;font-family:DM Sans,Inter,sans-serif}.regional-patterns{margin-bottom:20px}.regional-patterns h4{font-size:14px;font-weight:600;color:#0f172a;margin:0 0 12px;font-family:DM Sans,Raleway,sans-serif}.patterns-list{display:flex;flex-direction:column;gap:8px}.pattern-item{padding:8px 12px;border-radius:6px;background:#f8fafc;border:1px solid #f1f5f9}.pattern-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.region-info{display:flex;align-items:center;gap:8px}.region-name{font-size:12px;font-weight:600;color:#0f172a;font-family:DM Sans,Inter,sans-serif}.station-count{font-size:10px;color:#64748b;font-weight:500;font-family:DM Sans,Inter,sans-serif}.dominance-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;border:1px solid;text-transform:uppercase;letter-spacing:.5px}.pattern-details{display:flex;gap:12px}.pattern-detail{display:flex;gap:4px;align-items:center}.detail-label{font-size:10px;color:#64748b;font-weight:500}.detail-value{font-size:10px;color:#374151;font-weight:600}.top-stations{flex:1}.top-stations h4{font-size:14px;font-weight:600;color:#0f172a;margin:0 0 12px;font-family:DM Sans,Raleway,sans-serif}.energy-table{display:flex;flex-direction:column;gap:6px}.energy-row{display:grid;grid-template-columns:24px 1fr auto auto;gap:8px;align-items:center;padding:6px 8px;border-radius:4px;transition:all .2s ease}.energy-row:hover{background:#f8fafc}.rank{font-size:10px;color:#64748b;font-weight:600;text-align:center}.energy-row .station-name{font-size:12px;color:#374151;font-weight:600;line-height:1.3;text-align:left;font-family:DM Sans,Inter,sans-serif}.energy-row .energy-value{font-size:10px;color:#64748b;font-weight:500;text-align:right}.system-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;background:#3b82f61a;text-align:center;min-width:40px}.panel-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#64748b}.empty-icon{font-size:32px;opacity:.6}.panel-empty p{font-size:14px;margin:0}.panel-footer{margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9;text-align:center}.view-all-link{font-size:14px;color:#3b82f6;text-decoration:none;font-weight:600;transition:color .2s ease}.view-all-link:hover{color:#1d4ed8}@media (max-width: 768px){.spectral-wave-panel{padding:20px}.panel-header{flex-direction:column;gap:12px;align-items:flex-start}.summary-stats{gap:12px}.stat-value{font-size:16px}.patterns-list{gap:6px}.pattern-item{padding:6px 10px}}@media (max-width: 640px){.spectral-wave-panel{padding:16px}.summary-stats{flex-direction:column;gap:8px}.stat-item{flex-direction:row;justify-content:space-between;text-align:left}.pattern-details{flex-direction:column;gap:4px}}.spectrum-view{flex:1;display:flex;flex-direction:column;gap:16px}.spectrum-header{text-align:center}.spectrum-header h4{font-size:14px;font-weight:600;color:#0f172a;margin:0 0 4px;font-family:DM Sans,Raleway,sans-serif}.spectrum-header p{font-size:12px;color:#64748b;margin:0 0 8px;font-family:DM Sans,Inter,sans-serif}.energy-formulas{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;font-size:9px;line-height:1.2}.formula-label{color:#374151;font-weight:600;margin-right:4px}.formula{font-family:Inter,monospace;font-weight:500;padding:2px 6px;border-radius:3px;background:#f8fafc;border:1px solid #e2e8f0}.wind-formula{color:#f59e0b;border-color:#fbbf24;background:#fffbeb}.swell-formula{color:#3b82f6;border-color:#60a5fa;background:#eff6ff}.formula-note{color:#6b7280;font-style:italic;font-size:8px}.region-filters{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;margin-top:12px;font-size:9px;line-height:1.2}.filter-label{color:#374151;font-weight:600;margin-right:4px;font-size:9px}.region-filter-btn{font-family:Inter,monospace;font-weight:500;font-size:9px;padding:3px 8px;border-radius:3px;background:transparent;border:1px solid #e2e8f0;color:#6b7280;cursor:pointer;transition:all .2s ease;text-transform:none;white-space:nowrap}.region-filter-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.region-filter-btn.active{border-color:#3b82f6;color:#3b82f6;background:#eff6ff;font-weight:600}.spectrum-chart-container{flex:1;min-height:200px;position:relative}.spectrum-chart{width:100%;height:212px;border-radius:6px;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:1px solid #e0f2fe}.spectrum-legend{display:flex;justify-content:center;gap:16px;padding:8px 0}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#64748b;font-weight:500}.legend-color{width:8px;height:8px;border-radius:50%;border:1px solid}.legend-color.wind{background:#f59e0b;border-color:#f59e0b}.legend-color.swell{background:#3b82f6;border-color:#3b82f6}.station-icon svg{width:14px;height:14px}.dashboard-grid-shadcn{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.grid-section{display:grid;gap:20px}.trend-charts{grid-template-columns:repeat(4,1fr)}.regional-section{grid-template-columns:1fr}.regional-card{min-height:200px}.status-activity{grid-template-columns:1fr 1fr}.dashboard-grid-shadcn{--mouse-x: 50%;--mouse-y: 50%}@media (max-width: 1200px){.trend-charts{grid-template-columns:repeat(2,1fr)}.status-activity{grid-template-columns:1fr;gap:16px}}@media (max-width: 768px){.dashboard-grid-shadcn,.grid-section{gap:16px}.trend-charts{grid-template-columns:1fr}.regional-card{min-height:180px}}@media (max-width: 640px){.dashboard-grid-shadcn,.grid-section{gap:12px}.regional-card{min-height:160px}}.dashboard{max-width:1200px;margin:0 auto}.dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;width:100%}.page-header h1{font-size:14px;font-weight:500;color:#1a1d29;margin:0 0 8px;line-height:1.2}.summary-section{margin-bottom:40px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.summary-card{background-color:var(--card-background, #ffffff);border:1px solid var(--border-color);border-radius:8px;padding:24px;transition:all .2s ease;color:var(--text-color)}.summary-card:hover{border-color:var(--border-color);background-color:var(--card-hover-background, #f9fafb);box-shadow:0 2px 8px #0000000a}.summary-content{text-align:center}.summary-value{font-size:28px;font-weight:600;color:#1a1d29;margin:0 0 8px;line-height:1}.summary-label{font-size:14px;font-weight:500;color:#6b7280;margin:0}.stations-section{margin-bottom:40px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:20px;font-weight:600;color:#1a1d29;margin:0}.view-all-link{font-size:14px;font-weight:500;color:#6b7280;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#374151}.stations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.station-card{background-color:var(--card-background, #ffffff);border:1px solid var(--border-color);border-radius:8px;padding:24px;transition:all .2s ease;color:var(--text-color)}.station-card:hover{border-color:var(--border-color);background-color:var(--card-hover-background, #f9fafb);box-shadow:0 2px 8px #0000000a}.station-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.station-title h3{font-size:16px;font-weight:600;color:#1a1d29;margin:0 0 4px;line-height:1.3}.station-id{font-size:12px;font-weight:500;color:#9ca3af}.current-conditions{margin-bottom:16px;padding:12px 0;border-bottom:1px solid #f3f4f6}.conditions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.condition-item{display:flex;flex-direction:column;align-items:center;text-align:center}.condition-value{font-size:14px;font-weight:600;color:#1a1d29;line-height:1.2}.condition-label{font-size:11px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.station-metrics{margin-bottom:20px}.metric-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.metric-row:last-child{border-bottom:none}.metric-info{display:flex;flex-direction:column;gap:2px;flex:1}.metric-label{font-size:12px;font-weight:600;color:#374151;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.metric-value{font-size:14px;font-weight:600;color:#1a1d29}.metric-sparkline{display:flex;align-items:center;margin-left:12px}.station-actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease;border:1px solid transparent;cursor:pointer}.btn-primary:hover{background-color:var(--secondary-color, #86c5da);border-color:var(--secondary-color, #86c5da);text-decoration:none}@media (max-width: 768px){.dashboard{padding:0 16px}.page-header h1{font-size:13px}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.summary-card{padding:20px}.summary-value{font-size:28px}.stations-grid{grid-template-columns:1fr;gap:12px}.station-card{padding:20px}.section-header{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 640px){.summary-grid{grid-template-columns:1fr 1fr}.station-header{flex-direction:column;align-items:flex-start;gap:8px}}.dashboard-redesign{max-width:1400px;margin:0 auto;padding:0 24px;font-family:DM Sans,Inter,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.header-content h1{font-size:26px!important;font-weight:600!important;color:#4b5563!important;margin:0 0 -8px!important;line-height:1.2!important;font-family:DM Sans,Raleway,sans-serif!important;letter-spacing:normal!important}.header-content p{font-size:16px;color:#64748b;margin:0;line-height:1.5}.header-actions{display:flex;align-items:center;gap:16px}.total-metrics,.last-updated{font-size:14px;color:#64748b;font-weight:500;font-family:DM Sans,Inter,sans-serif}.hero-metrics{margin-bottom:32px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.06) 0%,transparent 40%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.metric-card:hover:before{opacity:1}.metric-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.metric-card.primary{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff)}.metric-card.primary:before{background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.12) 0%,transparent 40%)}.metric-card>*{position:relative;z-index:2}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.metric-header h3{font-size:14px;font-weight:600;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.05em;font-family:DM Sans,Inter,sans-serif}.metric-trend{font-size:12px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em}.metric-trend.positive{color:#059669;background:#d1fae5}.metric-trend.negative{color:#dc2626;background:#fee2e2}.metric-trend.neutral{color:#6b7280;background:#f3f4f6}.metric-value{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.metric-value .value{font-size:28px;font-weight:700;color:#4b5563;line-height:1;font-family:Inter,sans-serif}.metric-value .unit{font-size:16px;font-weight:500;color:#64748b}.metric-description{font-size:14px;color:#64748b;margin:0;line-height:1.4}.main-content-grid{display:grid;grid-template-columns:2fr 1fr;gap:32px;margin-bottom:32px}.overview-section{min-height:400px}.section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;height:100%;position:relative;overflow:hidden;transition:all .3s ease}.section-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(59,130,246,.04) 0%,transparent 40%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.section-card:hover:before{opacity:1}.section-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a}.section-card>*{position:relative;z-index:2}.section-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.section-header h2{font-size:20px;font-weight:600;color:#0f172a;margin:0 0 4px;font-family:DM Sans,Inter,sans-serif}.section-header p{font-size:14px;color:#64748b;margin:0}.section-header .view-all-link{font-size:14px;font-weight:500;color:#3b82f6;text-decoration:none;transition:color .2s ease}.section-header .view-all-link:hover{color:#1d4ed8}.overview-chart{height:300px;display:flex;align-items:stretch;justify-content:center;background:#fff;border-radius:8px;overflow:hidden}.chart-placeholder{text-align:center}.chart-info{display:flex;flex-direction:column;align-items:center;gap:8px}.chart-icon{font-size:48px;opacity:.6}.chart-info p{font-size:16px;font-weight:500;color:#374151;margin:0}.chart-info small{font-size:14px;color:#6b7280}.sidebar-section{min-height:400px}.stations-list{display:flex;flex-direction:column;gap:16px}.station-item{padding:16px;border:1px solid #f1f5f9;border-radius:8px;background:#fafbfc;transition:all .2s ease}.station-item:hover{border-color:#e2e8f0;background:#fff;box-shadow:0 2px 4px #0000000d}.station-info{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.station-name h4{font-size:14px;font-weight:700;color:#4b5563;margin:0 0 2px;line-height:1.2;font-family:DM Sans,Inter,sans-serif}.station-id{font-size:12px;color:#64748b;font-weight:500}.status-indicator{font-size:12px;font-weight:600}.status-indicator.active{color:#059669}.status-indicator.inactive{color:#dc2626}.station-metrics-compact{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.metric-compact{display:flex;justify-content:space-between;align-items:center}.metric-compact .metric-label{font-size:12px;color:#64748b;font-weight:500}.metric-value-sparkline{display:flex;align-items:center;gap:8px}.metric-compact .metric-value{font-size:12px;font-weight:600;color:#4b5563}.station-link{font-size:12px;font-weight:500;color:#3b82f6;text-decoration:none;transition:color .2s ease}.station-link:hover{color:#1d4ed8}@media (max-width: 1024px){.main-content-grid{grid-template-columns:1fr;gap:24px}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}}@media (max-width: 768px){.dashboard-redesign{padding:0 16px}.dashboard-header{flex-direction:column;gap:12px}.header-content h1{font-size:28px}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.metric-card{padding:20px}.metric-value .value{font-size:32px}}.station-list{max-width:1400px;margin:0 auto;padding:0 24px}.page-header{margin-bottom:32px;position:relative;z-index:10;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.station-list .page-header h1{font-size:26px!important;font-weight:600!important;color:#4b5563!important;margin:0 0 8px!important;line-height:1.2!important;font-family:DM Sans,Raleway,sans-serif!important;letter-spacing:normal!important}.page-header p{font-size:16px;color:#6b7280;margin:0;line-height:1.5;font-family:DM Sans,Inter,sans-serif}.region-badges-container{margin-bottom:1.5rem;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 2rem}.region-badges{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start;align-items:center}.region-badge{padding:.4rem .8rem;border:1px solid;border-radius:16px;background:transparent;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:DM Sans,Inter,sans-serif}.region-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.region-badge.active{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.compact-controls-container{margin-bottom:24px}.compact-controls-row{display:flex;align-items:center;gap:24px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-wrap:wrap;min-height:40px}.compact-search-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;transition:all .2s ease;font-family:DM Sans,Inter,sans-serif}.compact-selection-count{font-size:12px;color:#6b7280;font-weight:500;white-space:nowrap;font-family:DM Sans,Inter,sans-serif}.compact-region-section{display:flex;align-items:center;gap:8px;min-width:200px}.compact-region-icon{color:#6b7280}.compact-region-content{display:flex;align-items:center;flex:1;position:relative}.compact-region-selector{position:relative;width:100%}.compact-region-button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;font-family:DM Sans,Inter,sans-serif}.compact-region-button:hover{border-color:#9ca3af}.compact-region-text{font-size:14px;color:#0f172a;font-weight:500;flex:1;text-align:left}.compact-region-arrow{font-size:12px;color:#6b7280;margin-left:8px;transition:transform .2s ease}.compact-region-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.compact-region-option{padding:8px 12px;font-size:14px;color:#0f172a;background:#fff;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f9fafb;font-family:DM Sans,Inter,sans-serif}.compact-region-option:hover{background:#f9fafb}.compact-region-option.selected{background:#e1f3f9;color:#0f172a;font-weight:500}.compact-region-option:last-child{border-bottom:none}.stations-table-container{background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;overflow:hidden;margin-bottom:24px;min-height:400px;transition:all .3s ease}.stations-table-container.transitioning{opacity:.7;transform:translateY(2px)}.stations-table-container:not(.transitioning){opacity:1;transform:translateY(0)}.stations-table{width:100%;border-collapse:separate;border-spacing:0}.stations-table th{background-color:#f9fafb;color:#374151;font-weight:600;padding:18px 16px;text-align:left;border-bottom:1px solid #e1e5e9;font-size:14px;line-height:1.2;font-family:DM Sans,Inter,sans-serif;vertical-align:middle;white-space:nowrap;height:auto}.stations-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.stations-table th.sortable:hover{background-color:#f3f4f6}.sort-icon{display:inline-block;margin-left:6px;vertical-align:middle;color:#374151;transition:color .2s ease;font-size:12px}.stations-table th.sortable:hover .sort-icon{color:#1a1d29}.sort-icon-asc,.sort-icon-desc{color:#000}.sort-icon-neutral{color:#374151}.stations-table td{padding:18px 16px;border-bottom:1px solid #f3f4f6;font-size:11px;color:#1a1d29;vertical-align:middle;font-family:DM Sans,Inter,sans-serif;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:auto;line-height:1.2}.station-name{display:inline}.coordinates{white-space:nowrap;min-width:140px}.status-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px}.pagination-container{margin:24px 0;display:flex;flex-direction:column;gap:16px;align-items:center}.pagination-info{display:flex;justify-content:space-between;align-items:center;width:100%;font-size:14px;color:#64748b;font-family:DM Sans,Inter,sans-serif}.items-per-page{display:flex;align-items:center;gap:8px}.items-per-page label{display:flex;align-items:center;gap:8px;font-size:14px;color:#64748b}.items-per-page-select{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;background:#fff}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn{padding:8px 12px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;min-width:40px;font-family:DM Sans,Inter,sans-serif}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background:#0077b6;color:#fff;border-color:#0077b6}.pagination-numbers{display:flex;align-items:center;gap:4px}.pagination-ellipsis{padding:8px 4px;color:#9ca3af;font-size:14px}.stations-summary{text-align:center;margin-top:16px}.stations-summary p{font-size:14px;color:#6b7280;margin:0}.no-results{text-align:center;padding:48px 24px;background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;margin-bottom:24px}.no-results h3{font-size:18px;font-weight:600;color:#1a1d29;margin:0 0 8px;font-family:DM Sans,Inter,sans-serif}.no-results p{font-size:14px;color:#6b7280;margin:0;font-family:DM Sans,Inter,sans-serif}.station-list.loading,.station-list.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}@media (max-width: 768px){.station-list{padding:0 16px}.page-header h1{font-size:24px}.region-badges-container{padding:0 1rem}.region-badges{gap:.4rem;justify-content:flex-start}.region-badge{padding:.35rem .7rem;font-size:.75rem}.controls{flex-direction:column;gap:12px}.search-box{min-width:auto}.stations-table-container{overflow-x:auto;border-radius:6px}.stations-table{min-width:600px}.stations-table th,.stations-table td{padding:12px 8px;font-size:13px}.pagination-container{gap:12px}.pagination-info{flex-direction:column;gap:8px;text-align:center}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-btn{padding:6px 10px;font-size:13px;min-width:36px}}@media (max-width: 640px){.stations-table th,.stations-table td{padding:10px 6px;font-size:12px}.coordinates{font-size:11px}}.ocean-data-chart{width:100%;margin-bottom:2rem;background-color:var(--card-background, white);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:.25rem 1rem 1rem;transition:background-color .3s ease}.chart-container{width:100%;height:450px}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.btn-back{display:inline-flex;align-items:center;padding:8px 16px;background-color:#fff;border:1px solid #e1e5e9;color:#6b7280;text-decoration:none;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s ease}.btn-back:hover{border-color:#d1d5db;color:#374151;background-color:#f9fafb;text-decoration:none}.station-header{background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:20px;margin-bottom:24px;transition:all .2s ease;display:flex;flex-direction:row;gap:24px;align-items:flex-start}.station-header:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.station-title{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:20px}.station-badges{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.station-title h1{font-size:24px;font-weight:600;color:#1a1d29;margin:0;line-height:1.2}.data-type-badges{display:flex;gap:6px}.data-type-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid}.data-type-badge.available{background-color:#eff6ff;color:#1e40af;border-color:#3b82f6}.data-type-badge.unavailable{background-color:#f9fafb;color:#6b7280;border-color:#d1d5db}.data-type-icon{width:12px;height:12px;flex-shrink:0}.data-type-label{font-size:9px;font-weight:700}.station-location-map{margin:0;display:flex;justify-content:flex-start;align-items:flex-start}.station-left-section{display:flex;flex-direction:column;gap:2px}.station-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1;align-content:start;height:fit-content}.info-section{display:flex;flex-direction:column}.station-info-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f3f4f6}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;font-weight:500;color:#6b7280}.info-value{font-size:14px;font-weight:500;color:#1a1d29;text-align:right}.info-section h4{font-size:16px;font-weight:600;color:#1a1d29;margin:0 0 8px;padding-bottom:6px;border-bottom:1px solid #f3f4f6}.station-content{display:flex;flex-direction:column;gap:24px}.current-conditions{background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:24px;transition:all .2s ease}.current-conditions:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.current-conditions h3{font-size:18px;font-weight:600;color:#1a1d29;margin:0 0 16px}.conditions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.condition-item{display:flex;flex-direction:column;gap:4px}.condition-label{font-size:10px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.condition-value{font-size:14px;font-weight:600;color:#1a1d29}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-content{display:flex;align-items:center;gap:1rem}.header-content h1{color:var(--text-color);margin:0;font-size:1.3rem;font-weight:700}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:4px;font-weight:500;font-size:.85rem}.status-badge.active{background-color:#28a7451a;color:#28a745}.status-badge.inactive{background-color:#dc35451a;color:#dc3545}.detail-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:1.5rem;margin-bottom:2rem}.detail-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1rem;height:260px;display:flex;flex-direction:column;font-size:.8rem}.detail-card h2{color:var(--text-color);margin-top:0;margin-bottom:1rem;font-size:1rem;font-weight:700}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.info-item h3{color:var(--light-text-color);margin-top:0;margin-bottom:.5rem;font-size:.75rem;font-weight:600}.info-item p{margin:0;font-size:.8rem}.map-card{overflow:hidden}.map-card .station-map{flex:1;min-height:160px;max-height:180px}.chart-section{background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:24px;transition:all .2s ease}.chart-section:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:16px}.chart-header h2{font-size:18px;font-weight:600;color:#1a1d29;margin:0}.data-type-tabs{display:flex;gap:8px;flex-wrap:wrap}.tab-button{display:inline-flex;align-items:center;padding:6px 12px;background-color:#fff;border:1px solid #e1e5e9;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:#6b7280;transition:all .2s ease;white-space:nowrap}.tab-button:hover{border-color:#d1d5db;background-color:#f9fafb;color:#374151}.tab-button.active{background-color:var(--primary-color, #e1f3f9);border-color:var(--primary-color, #e1f3f9);color:#1a1d29;font-weight:600}.chart-container{min-height:400px;width:100%;border-radius:6px;overflow:hidden}.ocean-data-chart{width:100%;min-height:400px}.ocean-data-chart .chart-container{height:400px;width:100%}.no-chart-data{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background-color:#f9fafb;border:1px solid #e1e5e9;border-radius:6px;text-align:center}.no-chart-data p{font-size:14px;color:#6b7280;margin:4px 0}.station-detail.loading,.station-detail.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.loading h2,.error h2,.not-found h2{font-size:20px;font-weight:600;color:#1a1d29;margin:0 0 8px}.loading p,.error p,.not-found p{font-size:14px;color:#6b7280;margin:0 0 16px}@media (max-width: 768px){.station-detail{padding:0 16px}.station-title h1{font-size:20px}.station-header,.current-conditions,.chart-section{padding:20px}.chart-header{flex-direction:column;align-items:flex-start;gap:12px}.data-type-tabs{gap:6px}.tab-button{padding:6px 10px;font-size:11px}.conditions-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.station-header{flex-direction:column;gap:24px}.station-info-grid{grid-template-columns:1fr;gap:24px}}@media (max-width: 640px){.station-title{flex-direction:column;align-items:flex-start;gap:8px}.data-type-tabs{gap:4px}.tab-button{padding:5px 8px;font-size:10px}.conditions-grid{grid-template-columns:1fr 1fr}}.chart-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;background:var(--card-background, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;margin:1rem 0;min-height:200px}.chart-error h4{font-family:var(--font-primary, "Outfit", sans-serif);font-size:1.25rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 .75rem}.chart-error p{font-family:var(--font-primary, "Outfit", sans-serif);font-size:.95rem;font-weight:400;color:var(--text-secondary, #6b7280);margin:0 0 .5rem;line-height:1.5}.chart-error .suggestion{font-size:.9rem;color:var(--text-muted, #9ca3af);font-style:italic;margin-top:.75rem}.chart-loading{display:flex;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;background:var(--card-background, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;margin:1rem 0;min-height:200px}.chart-loading p{font-family:var(--font-primary, "Outfit", sans-serif);font-size:.95rem;font-weight:400;color:var(--text-secondary, #6b7280);margin:0}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:12px}.chart-header h2{font-size:12px;font-weight:600;color:#1a1d29;margin:0;text-transform:uppercase;letter-spacing:.5px}.time-range-controls{display:flex;align-items:center;gap:8px}.time-range-label{font-size:12px;font-weight:500;color:#6b7280;margin:0;white-space:nowrap}@media (max-width: 768px){.chart-header{flex-direction:column;align-items:flex-start;gap:8px}.time-range-controls{flex-direction:column;align-items:flex-start;gap:6px}.chart-header h2,.time-range-label{font-size:11px}}@media (max-width: 480px){.chart-header h2,.time-range-label{font-size:10px}}.chart-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:12px}.chart-header h2{display:none}@media (max-width: 768px){.chart-header{justify-content:center}}.time-range-controls{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.time-range-label{font-size:12px;font-weight:500;color:#6b7280;margin:0;white-space:nowrap;text-align:right}@media (max-width: 768px){.chart-header{justify-content:center}.time-range-controls{align-items:center}.time-range-label{text-align:center}}.chart-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:12px}.time-range-controls{display:flex;align-items:center;gap:0}.time-range-label{display:none}.time-range-buttons{display:flex;gap:6px}.chart-section .time-range-buttons{margin-left:0;padding-left:0}@media (max-width: 768px){.chart-header{justify-content:flex-start}.time-range-controls{align-items:flex-start}}.chart-header{display:block;margin-bottom:8px}.time-range-controls{display:block;margin:0;padding:0}.time-range-buttons{display:flex;gap:8px;flex-wrap:wrap;margin:0;padding:0}.time-range-buttons,.data-type-tabs{margin-left:0;padding-left:0;box-sizing:border-box}@media (max-width: 768px){.time-range-buttons{gap:6px}}@media (max-width: 480px){.time-range-buttons{gap:4px}}.time-range-buttons,.chart-header,.time-range-controls{margin-left:0!important;padding-left:0!important}.compare-dashboard{max-width:1400px;margin:0 auto;padding:0 24px}.dashboard-header{margin-bottom:24px;border-bottom:1px solid #e2e8f0}.header-content h1{font-size:26px;font-weight:600;color:#4b5563;margin:0 0 8px;line-height:1.2;font-family:DM Sans,Raleway,sans-serif;letter-spacing:normal}.header-content p{font-size:14px;color:#64748b;margin:0;line-height:1.4;font-family:DM Sans,Inter,sans-serif}.control-bar{display:flex;gap:24px;align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px 20px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.control-group{display:flex;flex-direction:column;gap:8px;min-width:0;align-self:flex-start}.control-group:nth-child(2),.control-group:nth-child(3){margin-top:52px}.control-group:first-child{flex:1;min-width:300px}.control-label{font-size:12px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.025em;margin:0;font-family:DM Sans,Inter,sans-serif}.instruction-text{margin-bottom:8px}.instruction-text span{font-size:13px;color:#64748b;font-weight:500;font-family:DM Sans,Inter,sans-serif}.regional-presets{margin-bottom:16px;padding:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.presets-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:8px;text-transform:uppercase;letter-spacing:.025em;font-family:DM Sans,Inter,sans-serif}.preset-badges{display:flex;flex-wrap:wrap;gap:6px}.preset-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:1;background-color:#fff;color:#374151;border:1px solid #d1d5db;cursor:pointer;transition:all .2s ease;font-family:DM Sans,Inter,sans-serif}.preset-badge:hover{background-color:#f3f4f6;border-color:#9ca3af;color:#111827}.preset-badge:active{background-color:#e5e7eb;transform:translateY(1px)}.station-selector{position:relative;width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center}.station-search{flex:1;padding:8px 50px 8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;transition:all .2s ease;font-family:DM Sans,Inter,sans-serif}.station-search:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.selection-count{position:absolute!important;right:12px!important;top:50%!important;transform:translateY(-50%)!important;font-size:12px!important;color:#6b7280!important;font-weight:500!important;background:#f9fafb!important;padding:2px 6px!important;border-radius:4px!important;z-index:10!important;pointer-events:none!important}.selected-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.station-chip{display:flex;align-items:center;gap:6px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:4px 8px;font-size:12px;color:#1e40af;font-weight:500;line-height:1}.chip-text{font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-remove{background:none;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.chip-remove:hover{background:#fee2e2;color:#dc2626}.station-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.dropdown-option{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .2s ease}.dropdown-option:last-child{border-bottom:none}.dropdown-option:hover{background:#f9fafb}.dropdown-option.selected{background:#eff6ff;color:#1e40af}.dropdown-option.disabled{opacity:.5;cursor:not-allowed}.dropdown-option.highlighted{background:#eff6ff;border-left:3px solid #3b82f6}.option-content{display:flex;flex-direction:column;gap:2px;flex:1}.option-name{font-size:14px;font-weight:500;color:#1f2937}.option-id{font-size:12px;color:#6b7280;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.option-location{font-size:11px;color:#9ca3af;font-style:italic}.dropdown-more{padding:8px 12px;font-size:12px;color:#6b7280;text-align:center;border-top:1px solid #f3f4f6;background:#f9fafb;font-style:italic}.option-indicator{font-size:16px;color:#10b981;font-weight:600}.metric-selector{position:relative;min-width:200px}.metric-select-button{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:200px}.metric-select-button:hover{border-color:#d1d5db}.metric-select-button:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.metric-select-text{font-family:DM Sans,Inter,sans-serif;font-size:14px;font-weight:500;color:#0f172a;flex:1;text-align:left}.metric-select-arrow{font-size:10px;color:#6b7280;margin-left:8px;transition:transform .2s ease}.metric-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.metric-group{border-bottom:1px solid #f3f4f6}.metric-group:last-child{border-bottom:none}.metric-group-label{font-family:DM Sans,Inter,sans-serif;padding:8px 12px 4px;font-size:12px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.025em;background:#f9fafb;border-bottom:1px solid #f1f5f9}.metric-option{padding:8px 12px;font-size:14px;color:#0f172a;background:#fff;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f9fafb;font-family:DM Sans,Inter,sans-serif}.metric-option:last-child{border-bottom:none}.metric-option:hover{background:#f9fafb}.metric-option.selected{background:#e1f3f9;color:#0f172a;font-weight:500}.action-buttons{display:flex;gap:8px}.action-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.action-btn.secondary{background:#f8fafc;color:#475569;border-color:#e2e8f0}.action-btn.secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.action-btn:disabled{opacity:.5;cursor:not-allowed}.chart-area{margin-bottom:24px;min-height:600px}.chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:visible;box-shadow:0 1px 3px #0000001a;min-height:580px;padding:24px}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f1f5f9;background:#fafafa}.chart-header h2{font-size:18px;font-weight:600;color:#0f172a;margin:0;font-family:DM Sans,Inter,sans-serif}.chart-meta{display:flex;gap:12px;align-items:center;font-size:14px;color:#64748b;font-family:DM Sans,Inter,sans-serif}.station-count{font-weight:500}.metric-unit{color:#94a3b8}.chart-container{height:400px;padding:0}.chart-loading{height:400px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.loading-content{text-align:center;max-width:300px;padding:40px}.loading-spinner{font-size:32px;margin-bottom:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-content h3{font-size:18px;font-weight:600;color:#334155;margin:0 0 8px;font-family:DM Sans,Inter,sans-serif}.loading-content p{font-size:14px;color:#64748b;margin:0;font-family:DM Sans,Inter,sans-serif}.chart-placeholder{height:400px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.placeholder-content{text-align:center;max-width:400px;padding:40px}.placeholder-icon{display:flex;justify-content:center;align-items:center;margin-bottom:16px;color:#64748b;opacity:.8}.placeholder-icon svg{width:48px;height:48px}.placeholder-content h3{font-size:20px;font-weight:600;color:#334155;margin:0 0 8px;font-family:DM Sans,Inter,sans-serif}.placeholder-content p{font-size:14px;color:#64748b;margin:0 0 20px;line-height:1.5;font-family:DM Sans,Inter,sans-serif}.placeholder-features{display:flex;flex-direction:column;gap:8px;font-size:13px;color:#64748b;text-align:left;max-width:280px;margin:0 auto}.feature-item{display:flex;align-items:center;line-height:1.4;padding:2px 0}.inline-controls{display:flex;gap:16px;align-items:flex-start;margin-top:12px;padding:8px 0}.control-group-inline{display:flex;flex-direction:column;gap:4px;min-width:0}.control-label-small{font-size:10px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.025em;margin:0}.metric-selector-small{position:relative;min-width:180px}.metric-select-button-small{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:180px}.metric-select-button-small:hover{border-color:#d1d5db}.metric-select-text-small{font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#0f172a;flex:1;text-align:left}.metric-select-arrow-small{font-size:8px;color:#6b7280;margin-left:6px;transition:transform .2s ease}.metric-dropdown-small{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:4px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:350px;overflow-y:auto;margin-top:2px}.metric-group-small{border-bottom:1px solid #f3f4f6}.metric-group-small:last-child{border-bottom:none}.metric-group-label-small{font-family:Inter,sans-serif;padding:6px 10px 3px;font-size:10px;font-weight:800;color:#374151;text-transform:uppercase;letter-spacing:.025em;background:#f9fafb;border-bottom:1px solid #f1f5f9}.metric-option-small{font-family:Inter,sans-serif;padding:6px 10px;font-size:12px;font-weight:300;color:#0f172a;background:#fff;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f9fafb}.metric-option-small:last-child{border-bottom:none}.metric-option-small:hover{background:#eff6ff;color:#1e40af}.metric-option-small.selected{background:#eff6ff;color:#1e40af;font-weight:500}.action-buttons-small{display:flex;gap:6px}.action-btn-small{padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.action-btn-small.secondary{background:#f8fafc;color:#475569;border-color:#e2e8f0}.action-btn-small.secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.action-btn-small:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1024px){.control-bar{flex-direction:column;gap:16px}.control-group:first-child{min-width:auto}}@media (max-width: 768px){.compare-dashboard{padding:0 16px}.control-bar{padding:12px 16px}.control-group{gap:6px}.selected-chips{gap:4px}.station-chip{font-size:11px;padding:3px 6px}.chart-header{flex-direction:column;align-items:flex-start;gap:8px}.chart-meta{gap:8px}.inline-controls{flex-direction:column;gap:12px}.metric-selector-small,.metric-select-button-small{min-width:0}}@media (max-width: 640px){.header-content h1{font-size:20px}.control-bar{padding:10px 12px}.station-search{font-size:13px;padding:6px 45px 6px 10px}.selection-count{font-size:11px;right:10px}.chart-container,.chart-placeholder{height:300px}.placeholder-content{padding:20px}.placeholder-icon{font-size:36px}}.compact-control-bar{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;position:relative}.compact-control-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap;min-height:40px}.compact-search-section{display:flex;align-items:center;gap:8px;flex:1;min-width:250px}.compact-search-icon{color:#6b7280}.compact-search-content{display:flex;align-items:center;gap:8px;flex:1;position:relative}.compact-search-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;transition:all .2s ease}.compact-search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.compact-selection-count{font-size:12px;color:#6b7280;font-weight:500;white-space:nowrap}.compact-metric-section{display:flex;align-items:center;gap:8px;min-width:180px}.compact-metric-icon{color:#6b7280}.compact-metric-content{flex:1}.compact-metric-selector{position:relative}.compact-metric-button{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:160px}.compact-metric-button:hover{border-color:#9ca3af}.compact-metric-text{font-size:12px;font-weight:500;color:#374151;flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-metric-arrow{font-size:10px;color:#6b7280;margin-left:8px}.compact-metric-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.compact-metric-group{border-bottom:1px solid #f3f4f6}.compact-metric-group:last-child{border-bottom:none}.compact-metric-group-label{padding:6px 12px 3px;font-size:11px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.025em;background:#f9fafb}.compact-metric-option{padding:6px 12px;font-size:13px;color:#374151;cursor:pointer;transition:all .2s ease}.compact-metric-option:hover{background:#f3f4f6}.compact-metric-option.selected{background:#eff6ff;color:#1e40af;font-weight:500}.compact-presets-section{display:flex;align-items:center;gap:8px;min-width:200px}.compact-presets-content{display:flex;align-items:center;gap:8px}.compact-presets-label{font-size:12px;color:#6b7280;font-weight:500;white-space:nowrap}.compact-preset-buttons{display:flex;gap:4px}.compact-preset-btn{padding:4px 8px;font-size:11px;font-weight:500;color:#374151;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.compact-preset-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.compact-actions-section{display:flex;align-items:center;gap:8px}.compact-actions-icon{color:#6b7280}.compact-actions-content{display:flex;gap:8px}.compact-clear-btn{padding:6px 12px;font-size:12px;font-weight:500;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;cursor:pointer;transition:all .2s ease}.compact-clear-btn:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.compact-clear-btn:disabled{opacity:.5;cursor:not-allowed}.compact-selected-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid #f3f4f6}.compact-selected-label{font-size:12px;color:#6b7280;font-weight:500;white-space:nowrap}.compact-selected-chips{display:flex;gap:6px;flex-wrap:wrap}.compact-station-chip{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;font-size:12px}.compact-chip-text{color:#1e40af;font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-chip-remove{background:none;border:none;color:#6b7280;font-size:12px;cursor:pointer;padding:0;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.compact-chip-remove:hover{background:#fee2e2;color:#dc2626}.compact-dropdown-container{position:absolute;top:100%;left:16px;right:16px;z-index:100}.compact-station-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;max-height:300px;overflow-y:auto;margin-top:4px}.compact-dropdown-option{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .2s ease}.compact-dropdown-option:last-child{border-bottom:none}.compact-dropdown-option:hover{background:#f9fafb}.compact-dropdown-option.selected{background:#eff6ff;color:#1e40af}.compact-dropdown-option.disabled{opacity:.5;cursor:not-allowed}.compact-dropdown-option.highlighted{background:#eff6ff;border-left:3px solid #3b82f6}.compact-option-content{display:flex;flex-direction:column;gap:2px;flex:1}.compact-option-name{font-size:14px;font-weight:500;color:#1f2937}.compact-option-id{font-size:12px;color:#6b7280;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.compact-option-indicator{font-size:16px;color:#10b981;font-weight:600}.compact-dropdown-more{padding:8px 12px;font-size:12px;color:#6b7280;text-align:center;border-top:1px solid #f3f4f6;background:#f9fafb;font-style:italic}@media (max-width: 768px){.compact-control-row{flex-direction:column;align-items:stretch;gap:16px}.compact-search-section,.compact-metric-section,.compact-presets-section{min-width:auto}.compact-preset-buttons{flex-wrap:wrap}}.time-range-controls{margin-bottom:20px;padding:16px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.time-range-label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#1a1d29}.time-range-buttons{display:flex;gap:8px;flex-wrap:wrap}.time-range-button{display:inline-flex;align-items:center;padding:6px 12px;background-color:#fff;border:1px solid #e1e5e9;border-radius:6px;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:40px;text-align:center;white-space:nowrap}.time-range-button:hover{border-color:#d1d5db;background-color:#f9fafb;color:#374151}.time-range-button.active{background-color:var(--primary-color, #e1f3f9);border-color:var(--primary-color, #e1f3f9);color:#1a1d29;font-weight:600}.time-range-button.active:hover{background-color:var(--secondary-color, #86c5da);border-color:var(--secondary-color, #86c5da);color:#1a1d29}@media (max-width: 768px){.time-range-buttons{justify-content:center}.time-range-button{flex:1;min-width:50px;max-width:60px}}.data-dictionary{all:initial;font-family:Inter,sans-serif!important;max-width:1400px;margin:0 auto;padding:0 24px;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;line-height:normal;letter-spacing:normal;word-spacing:normal;text-align:left;text-decoration:none;text-transform:none;white-space:normal;word-wrap:normal;direction:ltr}.data-dictionary *{box-sizing:border-box;font-family:inherit}.dictionary-header{margin-bottom:24px;border-bottom:1px solid #e2e8f0}.header-content{text-align:left}.data-dictionary .page-title{font-size:26px!important;font-weight:600!important;color:#4b5563!important;margin:0 0 8px!important;line-height:1.2!important;font-family:DM Sans,Raleway,sans-serif!important;letter-spacing:normal!important;text-align:left!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:normal!important}.data-dictionary .page-description{font-size:16px!important;color:#64748b!important;line-height:1.6!important;margin:0!important;text-align:left!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:normal!important}.dictionary-controls{margin-bottom:32px;display:flex;flex-direction:column;gap:20px}.search-section{display:flex;justify-content:center}.search-input-wrapper{position:relative;max-width:500px;width:100%}.search-input{width:100%;padding:12px 16px 12px 44px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;color:#0f172a;transition:all .2s ease}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#6b7280;font-size:16px}.category-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.category-btn{padding:8px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s ease;white-space:nowrap}.category-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.category-btn.active{background:#eff6ff;border-color:#bfdbfe;color:#1e40af;font-weight:600}.dictionary-content{margin-bottom:48px}.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.results-title{font-size:24px;font-weight:600;color:#0f172a;margin:0}.results-count{font-size:14px;color:#64748b;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.data-dictionary .metric-card{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;padding:24px!important;transition:all .2s ease!important;display:block!important;box-sizing:border-box!important;text-align:left!important;line-height:normal!important;word-spacing:normal!important;letter-spacing:normal!important}.metric-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a}.metric-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.data-dictionary .metric-name{font-size:18px!important;font-weight:600!important;color:#0f172a!important;margin:0!important;flex:1!important;text-align:left!important;line-height:1.3!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:normal!important}.data-dictionary .metric-meta{display:flex!important;flex-direction:column!important;align-items:flex-end!important;gap:4px!important}.data-dictionary .metric-abbr{font-size:12px!important;font-weight:600!important;color:#1e40af!important;background:#eff6ff!important;padding:2px 6px!important;border-radius:4px!important;font-family:Monaco,Menlo,Ubuntu Mono,monospace!important;text-align:center!important;line-height:1!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:nowrap!important}.data-dictionary .metric-unit{font-size:12px!important;color:#64748b!important;font-weight:500!important;text-align:right!important;line-height:1!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:nowrap!important}.data-dictionary .metric-content{display:flex!important;flex-direction:column!important;gap:16px!important}.data-dictionary .metric-description{font-size:14px!important;color:#374151!important;line-height:1.5!important;margin:0!important;text-align:left!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:normal!important}.data-dictionary .metric-details{display:flex!important;flex-direction:column!important;gap:0!important}.data-dictionary .detail-item{font-size:13px!important;color:#4b5563!important;line-height:1.6!important;text-align:left!important;margin:0 0 12px!important;padding:0!important;letter-spacing:normal!important;word-spacing:normal!important;text-decoration:none!important;text-transform:none!important;white-space:normal!important;display:block!important;word-wrap:break-word!important;overflow-wrap:break-word!important}.data-dictionary .detail-item strong{color:#374151!important;font-weight:600!important;text-decoration:none!important;text-transform:none!important;display:inline!important;margin-right:4px!important}.no-results{text-align:center;padding:48px 24px;color:#64748b}.no-results h3{font-size:18px;font-weight:600;color:#374151;margin:0 0 8px}.no-results p{font-size:14px;margin:0}@media (max-width: 768px){.data-dictionary{padding:0 16px}.page-title{font-size:28px}.dictionary-controls{gap:16px}.category-filters{justify-content:flex-start}.results-header{flex-direction:column;align-items:flex-start;gap:8px}.metrics-grid{grid-template-columns:1fr;gap:16px}.metric-card{padding:20px}.metric-header{flex-direction:column;gap:12px}.metric-meta{align-items:flex-start;flex-direction:row;gap:8px}}.sql-analytics{min-height:100vh;padding:1rem}.sql-analytics-loading,.sql-analytics-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.sql-analytics-error h2{color:#dc2626;margin-bottom:1rem}.security-error-content{max-width:800px;margin:0 auto;text-align:left}.error-explanation{background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;padding:1rem;margin-bottom:2rem}.error-explanation p{margin:.5rem 0;color:#92400e}.development-options h3{color:#1e293b;margin-bottom:1rem}.option-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:2rem}.option-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 4px -1px #0000001a}.option-card.recommended{border-color:#10b981;background:#f0fdf4}.option-card h4{color:#1e293b;margin-bottom:.5rem;font-size:1.1rem}.option-card p{color:#64748b;margin-bottom:.75rem}.option-card code{background:#f1f5f9;color:#475569;padding:.25rem .5rem;border-radius:.25rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;display:block;margin-top:.5rem}.option-card ul{margin:.5rem 0;padding-left:1.5rem}.option-card li{color:#64748b;margin-bottom:.25rem}.option-card li code{display:inline;margin:0;padding:.125rem .25rem;font-size:.75rem}.production-note{background:#dcfce7;border:1px solid #16a34a;border-radius:.5rem;padding:1rem;text-align:center}.production-note p{margin:0;color:#166534;font-weight:500}.generic-error-content{text-align:center}.retry-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-size:1rem;margin-top:1rem;transition:background-color .2s}.retry-button:hover{background:#2563eb}.header-content{text-align:left;margin-bottom:2rem}.header-content h1{font-size:2rem;color:#1e293b;margin:0 0 .5rem;font-family:Raleway,sans-serif;font-weight:600}.page-subtitle{color:#64748b;font-size:.875rem;margin:0 0 1rem;line-height:1.5}.duckdb-link{color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s}.duckdb-link:hover{color:#2563eb;text-decoration:underline}.section-header{display:flex!important;align-items:center!important;gap:.5rem!important;margin-bottom:1rem;text-align:left!important;justify-content:flex-start!important}.section-icon{color:#64748b}.status-info{display:flex;align-items:center;justify-content:center;gap:1rem}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.success{background:#dcfce7;color:#166534}.table-count{color:#64748b;font-size:.875rem}.analytics-workspace{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;min-height:70vh}.schema-explorer{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;overflow-y:auto;max-height:80vh}.schema-explorer h3{color:#1e293b;margin-bottom:1rem;font-size:1.1rem}.section-header h3{color:#1e293b;margin:0!important;font-size:1.1rem}.no-tables{text-align:center;padding:2rem 0;color:#64748b}.load-button{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;margin-top:1rem;transition:background-color .2s}.load-button:hover:not(:disabled){background:#059669}.load-button:disabled{background:#9ca3af;cursor:not-allowed}.load-error{margin-top:1rem;padding:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem}.load-error p{color:#dc2626;margin:0 0 .5rem;font-size:.875rem}.clear-error-btn{background:#dc2626;color:#fff;border:none;padding:.25rem .5rem;border-radius:.25rem;cursor:pointer;font-size:.75rem;transition:background-color .2s}.clear-error-btn:hover{background:#b91c1c}.tables-list{margin-bottom:1.5rem}.table-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;margin-bottom:.5rem;border:1px solid transparent}.table-item:hover{background:#f1f5f9}.table-item.selected{background:#dbeafe;border:1px solid #3b82f6}.table-info{display:flex;align-items:center;gap:.5rem}.table-name{font-weight:500;color:#1e293b;font-size:.875rem;font-family:Inter,sans-serif;white-space:nowrap;overflow:visible;text-overflow:clip;min-width:0;flex:1}.table-status{color:#10b981;font-size:.75rem}.debug-info{margin-top:1rem;padding:.5rem;background:#f3f4f6;border-radius:.25rem;border:1px solid #e5e7eb}.debug-info small{color:#6b7280;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;line-height:1.4;word-break:break-all}.table-schema{margin-bottom:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}.table-schema h4{color:#1e293b;margin-bottom:.75rem;font-size:.95rem}.schema-columns{max-height:200px;overflow-y:auto}.schema-column{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-radius:.25rem;margin-bottom:.25rem;background:#f8fafc}.column-name{font-weight:500;color:#374151;font-size:.875rem}.column-type{font-size:.75rem;color:#6b7280;background:#e5e7eb;padding:.125rem .375rem;border-radius:.25rem}.sample-data{padding-top:1rem;border-top:1px solid #e2e8f0}.sample-data h4{color:#1e293b;margin-bottom:.75rem;font-size:.95rem}.sample-table{overflow-x:auto}.sample-table table{width:100%;font-size:.75rem;border-collapse:collapse}.sample-table th,.sample-table td{padding:.375rem;text-align:left;border-bottom:1px solid #e5e7eb}.sample-table th{background:#f9fafb;font-weight:600;color:#374151}.sample-table td{color:#6b7280;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.query-workspace{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;overflow-y:auto;max-height:80vh}.data-types-list{display:flex;flex-direction:column;gap:.5rem}.data-type-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;border:1px solid transparent}.data-type-item.loaded{background:#f0f9ff;border-color:#bae6fd}.data-type-item.loaded:hover{background:#e0f2fe;border-color:#7dd3fc}.data-type-item.not-loaded{background:#f9fafb;border-color:#e5e7eb}.data-type-item.not-loaded:hover{background:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px)}.data-type-item.selected{background:#dbeafe;border-color:#3b82f6}.data-type-info{display:flex;align-items:center;gap:.75rem;flex:1}.data-type-icon{color:#64748b;flex-shrink:0}.data-type-details{display:flex;flex-direction:column;gap:.25rem}.data-type-name{font-weight:500;color:#1e293b;font-size:.875rem;font-family:Inter,sans-serif}.data-type-description{font-size:.75rem;color:#64748b;line-height:1.3}.data-type-status{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.status-loaded{color:#10b981;font-size:.875rem}.status-loading{color:#f59e0b;animation:spin 1s linear infinite}.status-load{color:#6b7280;transition:color .2s}.data-type-item:hover .status-load{color:#3b82f6}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-loading-progress{margin:1rem 0;padding:.75rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.sidebar-error{margin:1rem 0;padding:.75rem;background:#fef2f2;border-radius:.5rem;border:1px solid #fecaca}.sidebar-error p{color:#dc2626;margin:0 0 .5rem;font-size:.875rem}.progress-message{font-size:.875rem;color:#374151;margin-bottom:.5rem}.progress-message.error{color:#dc2626}.progress-bar{width:100%;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:#3b82f6;transition:width .3s ease}.query-templates{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.query-templates h3{color:#1e293b;margin-bottom:1rem;font-size:1.1rem}.template-selectors{display:flex;gap:1rem;flex-wrap:wrap}.template-selector{display:flex;flex-direction:column;gap:.5rem;min-width:200px;flex:1}.template-label{font-size:12px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.025em;margin:0}.template-dropdown-container{position:relative}.template-select-button{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:200px}.template-select-button:hover{border-color:#d1d5db}.template-select-button:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.template-select-text{font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#0f172a;flex:1;text-align:left}.template-select-arrow{font-size:10px;color:#6b7280;margin-left:8px;transition:transform .2s ease}.template-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.template-option{padding:12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .2s ease}.template-option:last-child{border-bottom:none}.template-option:hover{background:#eff6ff;color:#1e40af}.template-option-name{font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#0f172a;margin-bottom:4px}.template-option-desc{font-family:Inter,sans-serif;font-size:12px;color:#6b7280;line-height:1.4}.sql-editor-container{margin-bottom:1.5rem}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.editor-title{display:flex;align-items:center;gap:.5rem}.editor-icon{color:#64748b}.editor-header h3{color:#1e293b;font-size:1.1rem;margin:0}.editor-actions{display:flex;gap:.75rem}.run-button{background:transparent;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s;display:flex;align-items:center;gap:.5rem}.run-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.run-button:disabled{color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.clear-button{background:transparent;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s;display:flex;align-items:center;gap:.5rem}.clear-button:hover{background:#f9fafb;border-color:#9ca3af}.button-icon{flex-shrink:0}.sql-editor-container .monaco-editor{border:1px solid #d1d5db;border-radius:.5rem;overflow:hidden}.sql-editor-container .monaco-editor:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.monaco-editor .margin,.monaco-editor .monaco-editor-background{background-color:#1e1e1e!important}.sql-textarea{width:100%;min-height:200px;padding:1rem;border:1px solid #d1d5db;border-radius:.5rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;resize:vertical;background:#f9fafb}.sql-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.duckdb-attribution{margin-top:.5rem;text-align:right;font-size:.75rem;color:#64748b}.duckdb-attribution .duckdb-link{color:#3b82f6;text-decoration:none;font-weight:500}.duckdb-attribution .duckdb-link:hover{text-decoration:underline}.query-loading{display:flex;flex-direction:column;align-items:center;padding:2rem;color:#64748b}.query-error{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.query-error h4{color:#dc2626;margin-bottom:.5rem}.query-error pre{background:#fee2e2;padding:.75rem;border-radius:.25rem;font-size:.875rem;color:#991b1b;overflow-x:auto;white-space:pre-wrap}.clear-error-button{background:transparent;color:#dc2626;border:1px solid #dc2626;padding:.375rem .75rem;border-radius:.25rem;cursor:pointer;font-size:.75rem;margin-top:.5rem;display:flex;align-items:center;gap:.25rem;transition:all .2s}.clear-error-button:hover{background:#fef2f2}.query-results{margin-bottom:1.5rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.results-title{display:flex;align-items:center;gap:.5rem}.results-icon{color:#64748b}.results-header h3{color:#1e293b;font-size:1.1rem;margin:0}.results-actions{display:flex;align-items:center;gap:1rem}.results-meta{display:flex;gap:1rem;font-size:.875rem;color:#64748b}.truncation-notice{color:#f59e0b!important;font-weight:500}.download-buttons{display:flex;gap:.5rem}.download-button{background:transparent;color:#374151;border:1px solid #d1d5db;padding:.375rem .75rem;border-radius:.375rem;cursor:pointer;font-size:.75rem;transition:all .2s;display:flex;align-items:center;gap:.375rem;font-weight:500}.download-button:hover{background:#f9fafb;border-color:#9ca3af;color:#1f2937}.download-button:active{background:#f3f4f6;transform:translateY(1px)}.ocean-data-loader{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.loader-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}.loader-header-icon{color:#64748b}.ocean-data-loader h4{color:#1e293b;font-size:1rem;margin:0;font-family:Raleway,sans-serif;font-weight:600}.section-label{display:block;font-size:.75rem;font-weight:500;color:#374151;margin-bottom:.4rem}.time-period-selection{margin-bottom:1.5rem}.time-period-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.time-period-button{background:#f8fafc;color:#374151;border:1px solid #d1d5db;padding:.6rem .8rem;border-radius:.375rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.time-period-button:hover{background:#f1f5f9;border-color:#94a3b8}.time-period-button.selected{background:#e1f3f9;color:#1a1d29;border-color:#e1f3f9}.region-selection{margin-bottom:1.5rem}.region-dropdown{position:relative;width:100%}.region-select-button{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;width:100%;font-size:.8rem}.region-select-button:hover{border-color:#d1d5db}.region-select-button:focus,.region-select-button.open{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.region-select-text{color:#374151;font-weight:500}.region-select-arrow{color:#9ca3af;font-size:12px;transition:transform .2s ease}.region-select-arrow.open{transform:rotate(180deg)}.region-dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;overflow-y:auto;margin-top:4px}.region-dropdown-option{padding:8px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .2s ease;font-size:.875rem;color:#374151}.region-dropdown-option:last-child{border-bottom:none}.region-dropdown-option:hover{background:#eff6ff;color:#1e40af}.region-dropdown-option.selected{background:#e1f3f9;color:#1a1d29;font-weight:500}.station-count-selection{margin-bottom:1.5rem}.station-count-slider{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;cursor:pointer;margin-top:.5rem}.slider-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.75rem;color:#64748b}.performance-estimate{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;padding:1rem;margin-bottom:1.5rem}.estimate-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.estimate-row:last-child{margin-bottom:0}.estimate-label{font-size:.875rem;color:#64748b}.estimate-value{font-size:.875rem;font-weight:500;color:#374151}.load-ocean-data-button{width:100%;background:#059669;color:#fff;border:none;padding:.8rem;border-radius:.375rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.load-ocean-data-button:hover:not(:disabled){background:#047857}.load-ocean-data-button:disabled{background:#9ca3af;cursor:not-allowed}.current-data-status{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:.375rem;padding:.75rem;margin-bottom:1.25rem}.status-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.status-badge-sidebar{padding:.2rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:500;margin-left:auto}.status-badge-sidebar.success{background:#dcfce7;color:#166534}.status-icon{color:#0ea5e9}.status-header span{font-size:.8rem;font-weight:500;color:#0c4a6e}.status-details span{font-size:.7rem;color:#0369a1}.individual-tables{border-top:1px solid #e5e7eb;padding-top:1.5rem}.individual-tables h5{color:#1e293b;font-size:.9rem;margin:0 0 1rem;font-family:Raleway,sans-serif;font-weight:600}.table-loading-grid{display:flex;flex-direction:column;gap:.75rem}.table-load-button{display:flex;align-items:center;gap:.6rem;padding:.6rem;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;cursor:pointer;transition:all .2s;text-align:left;width:100%}.table-load-button:hover:not(.loaded):not(:disabled){border-color:#3b82f6;background:#f8fafc}.table-load-button.loaded{background:#e1f3f9;border-color:#e1f3f9;cursor:default}.table-load-button:disabled{opacity:.5;cursor:not-allowed}.table-load-icon{color:#64748b;flex-shrink:0}.table-load-button.loaded .table-load-icon{color:#22c55e}.table-load-info{display:flex;flex-direction:column;gap:.25rem;flex-grow:1}.table-load-name{font-size:.8rem;color:#374151;font-weight:500}.table-load-status{font-size:.7rem;color:#64748b}.table-load-button.loaded .table-load-status{color:#1a1d29;font-weight:500}.table-load-indicator{flex-shrink:0}.loaded-check{color:#22c55e}.load-dot{color:#d1d5db;font-size:1rem}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.quick-action-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.quick-action-button:hover:not(:disabled){background:#2563eb}.quick-action-button:disabled{background:#9ca3af;cursor:not-allowed}.custom-selection{border-top:1px solid #e5e7eb;padding-top:1rem}.custom-toggle{background:transparent;border:none;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.5rem 0;width:100%;text-align:left}.toggle-icon{transition:transform .2s}.toggle-icon.expanded{transform:rotate(180deg)}.custom-options{padding-top:1rem;display:flex;flex-direction:column;gap:1rem}.compact-filters{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.compact-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer}.station-count-control{display:flex;flex-direction:column;gap:.5rem}.control-label{font-size:.875rem;font-weight:500;color:#374151}.station-slider{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;cursor:pointer}.data-types-compact{display:flex;flex-direction:column;gap:.5rem}.data-type-pills{display:flex;flex-wrap:wrap;gap:.5rem}.data-type-pill{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.375rem .75rem;border-radius:1rem;font-size:.75rem;cursor:pointer;transition:all .2s}.data-type-pill.selected{background:#3b82f6;color:#fff;border-color:#3b82f6}.data-type-pill:hover:not(.selected){background:#e5e7eb}.performance-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.375rem;font-size:.75rem;color:#92400e}.info-icon{color:#f59e0b;flex-shrink:0}.load-custom-button{background:#059669;color:#fff;border:none;padding:.75rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.load-custom-button:hover:not(:disabled){background:#047857}.load-custom-button:disabled{background:#9ca3af;cursor:not-allowed}.station-search{position:relative;margin-bottom:1rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.search-input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.station-filters{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-label{font-size:.875rem;font-weight:500;color:#374151}.filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;transition:border-color .2s}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.station-selection{margin-bottom:1.5rem}.selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.selection-count{font-size:.875rem;color:#64748b;font-weight:500}.clear-selection-button{background:transparent;color:#ef4444;border:1px solid #ef4444;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;cursor:pointer;transition:all .2s}.clear-selection-button:hover{background:#ef4444;color:#fff}.station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;max-height:300px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem}.station-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s;background:#fff}.station-item:hover{border-color:#3b82f6;background:#f8fafc}.station-item.selected{border-color:#3b82f6;background:#eff6ff}.station-info{display:flex;flex-direction:column;gap:.25rem}.station-name{font-weight:500;color:#1e293b;font-size:.875rem}.station-details{font-size:.75rem;color:#64748b}.station-checkbox{width:20px;height:20px;border:1px solid #d1d5db;border-radius:.25rem;display:flex;align-items:center;justify-content:center;background:#fff}.station-item.selected .station-checkbox{background:#3b82f6;border-color:#3b82f6;color:#fff}.station-grid-notice{grid-column:1 / -1;text-align:center;padding:.75rem;color:#64748b;font-size:.875rem;background:#f8fafc;border-radius:.375rem;margin-top:.5rem}.data-type-selection{margin-bottom:1.5rem}.data-type-checkboxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.data-type-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:.375rem;transition:background-color .2s}.data-type-checkbox:hover{background:#f8fafc}.data-type-checkbox input[type=checkbox]{margin:0;cursor:pointer}.checkbox-label{font-size:.875rem;color:#374151;cursor:pointer}.performance-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;color:#92400e}.warning-icon{color:#f59e0b;flex-shrink:0}.load-data-button{width:100%;background:#3b82f6;color:#fff;border:none;padding:.75rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.load-data-button:hover:not(:disabled){background:#2563eb}.load-data-button:disabled{background:#9ca3af;cursor:not-allowed}.loaded-data-types,.loaded-tables-card{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.loaded-tables-card h4{color:#1e293b;font-size:1.1rem;margin:0 0 1rem;font-family:Raleway,sans-serif;font-weight:600}.tables-grid{display:flex;flex-direction:column;gap:.5rem}.table-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s;background:#fff}.table-item:hover:not(.not-loaded){border-color:#3b82f6;background:#f8fafc}.table-item.selected{border-color:#3b82f6;background:#eff6ff}.table-item.not-loaded{opacity:.5;cursor:not-allowed}.table-item.not-loaded:hover{border-color:#e5e7eb;background:#fff}.table-icon{color:#64748b;flex-shrink:0}.table-info{display:flex;flex-direction:column;gap:.25rem;flex-grow:1}.table-name{font-size:.875rem;color:#374151;font-weight:500}.table-description{font-size:.75rem;color:#64748b}.table-item.loaded .table-description{color:#059669;font-weight:500}.table-status{flex-shrink:0}.status-dot{font-size:1rem}.status-dot.loaded{color:#10b981}.status-dot.not-loaded{color:#d1d5db}.selected-table-info{margin-top:1rem;padding:.75rem;background:#f0f9ff;border:1px solid #0ea5e9;border-radius:.375rem}.info-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.info-icon{color:#0ea5e9}.info-header span{font-size:.875rem;font-weight:500;color:#0c4a6e}.info-actions{display:flex;align-items:center;gap:.5rem}.info-text{font-size:.75rem;color:#0369a1}.results-table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:.5rem}.results-table{width:100%;border-collapse:collapse;font-size:.8rem}.results-table th,.results-table td{padding:.6rem;text-align:left;border-bottom:1px solid #e5e7eb}.results-table th{background:#f9fafb;font-weight:600;color:#374151;position:sticky;top:0;font-size:.8rem}.results-table td{color:#6b7280;font-size:.8rem}.results-table tr:hover{background:#f9fafb}.no-results{text-align:center;padding:2rem;color:#64748b;font-style:italic}.query-history{padding-top:1.5rem;border-top:1px solid #e2e8f0}.history-title{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.history-icon{color:#64748b}.query-history h3{color:#1e293b;margin:0;font-size:1.1rem}.history-list{max-height:300px;overflow-y:auto}.history-item{padding:.75rem;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.history-item:hover{background:#f8fafc;border-color:#cbd5e1}.history-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.75rem;color:#64748b}.history-sql{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;color:#374151;background:#f1f5f9;padding:.5rem;border-radius:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 1024px){.analytics-workspace{grid-template-columns:1fr;gap:1rem}.schema-explorer{max-height:400px}.query-workspace{max-height:none}}@media (max-width: 640px){.sql-analytics{padding:.5rem}.analytics-header{padding:1rem}.analytics-header h1{font-size:2rem}.template-buttons{flex-direction:column}.editor-actions{flex-direction:column;gap:.5rem}.results-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.cache-toggle-button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#e2e8f0;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.cache-toggle-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.cache-status-panel{position:fixed;top:80px;right:20px;width:320px;max-height:500px;background:#1a1d29f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #0000004d;z-index:1000;overflow:hidden}.cache-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1)}.cache-title{display:flex;align-items:center;gap:8px;color:#e2e8f0;font-size:14px;font-weight:600}.cache-storage-type{background:#22c55e33;border:1px solid rgba(34,197,94,.3);font-size:10px;color:#86efac;font-weight:600;padding:2px 6px;background:#667eea33;border:1px solid rgba(102,126,234,.3);border-radius:4px;font-size:11px;color:#a5b4fc}.cache-actions{display:flex;align-items:center;gap:4px}.cache-action-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#e2e8f0;cursor:pointer;transition:all .2s ease}.cache-action-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.cache-clear-button:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.cache-close-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;color:#94a3b8;font-size:18px;cursor:pointer;transition:all .2s ease}.cache-close-button:hover{color:#e2e8f0;background:#ffffff1a;border-radius:4px}.cache-content{padding:16px;max-height:400px;overflow-y:auto}.cache-summary{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.cache-stat{display:flex;align-items:center;gap:8px;padding:8px;background:#ffffff0d;border-radius:6px}.cache-stat-label{flex:1;font-size:12px;color:#94a3b8}.cache-stat-value{font-size:12px;font-weight:600;color:#e2e8f0}.cache-expand-button{display:flex;align-items:center;gap:6px;width:100%;padding:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e2e8f0;font-size:12px;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.cache-expand-button:hover{background:#ffffff1a;border-color:#fff3}.cache-entries{display:flex;flex-direction:column;gap:8px}.cache-entry{padding:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px}.cache-entry-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.cache-entry-key{font-size:11px;font-weight:500;color:#e2e8f0;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.cache-entry-size{font-size:10px;color:#94a3b8}.cache-entry-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.cache-entry-age{font-size:10px;color:#64748b}.cache-entry-type{padding:1px 4px;background:#667eea26;border-radius:3px;font-size:9px;color:#a5b4fc}.cache-not-supported{text-align:center;padding:16px}.cache-not-supported p{margin:0 0 8px;font-size:13px;color:#e2e8f0}.cache-fallback-note{font-size:11px!important;color:#94a3b8!important;line-height:1.4}.cache-empty{text-align:center;padding:16px}.cache-empty p{margin:0 0 8px;font-size:13px;color:#94a3b8}.cache-empty-note{font-size:11px!important;color:#64748b!important;line-height:1.4}@media (max-width: 768px){.cache-status-panel{position:fixed;top:60px;left:10px;right:10px;width:auto}}.cache-content::-webkit-scrollbar{width:4px}.cache-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.cache-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.cache-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.searchable-station-selector{position:relative;min-width:250px;z-index:99999999}.selector-button{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:250px}.selector-button:hover{border-color:#d1d5db}.selector-button:focus,.selector-button.open{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.selector-text{font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#0f172a;flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selector-arrow{font-size:10px;color:#6b7280;margin-left:8px;transition:transform .2s ease;flex-shrink:0}.selector-arrow.open{transform:rotate(180deg)}.selector-menu{position:absolute;top:100%;background:#fff!important;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 8px 25px #00000026;z-index:99999999!important;margin-top:4px;opacity:1!important;background-color:#fff!important;background-image:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;box-sizing:border-box;min-width:300px;width:300px}.selector-menu{right:0}.selector-menu.left{left:0;right:auto}.search-section{padding:12px;border-bottom:1px solid #f1f5f9}.search-input-wrapper{position:relative}.search-input{width:100%;padding:8px 12px 8px 32px;border:1px solid #e2e8f0;border-radius:4px;font-family:Inter,sans-serif;font-size:12px;font-weight:400;color:#0f172a;background:#fff;transition:all .2s ease;box-sizing:border-box}.search-input:hover{border-color:#d1d5db}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none}.options-section{max-height:250px;overflow-y:auto;overflow-x:hidden}.station-option{padding:10px 12px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f9fafb;background:#fff!important;background-color:#fff!important;opacity:1!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background-image:none!important;box-sizing:border-box}.station-option:last-child{border-bottom:none}.station-option:hover,.station-option.selected{background:#eff6ff!important;background-color:#eff6ff!important}.station-id{font-family:Inter,sans-serif;font-size:12px;font-weight:600;color:#1e40af;margin-bottom:2px}.station-name{font-family:Inter,sans-serif;font-size:11px;font-weight:400;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-option.selected .station-id{color:#1e40af;font-weight:700}.station-option.selected .station-name{color:#475569}.no-results{padding:24px 12px;text-align:center;color:#64748b}.no-results-icon{font-size:24px;margin-bottom:8px}.no-results-text{font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:#374151;margin-bottom:4px}.no-results-hint{font-family:Inter,sans-serif;font-size:11px;font-weight:400;color:#9ca3af}.results-footer{padding:8px 12px;border-top:1px solid #f1f5f9;background:#f8fafc;font-family:Inter,sans-serif;font-size:11px;font-weight:500;color:#64748b;text-align:center}@media (max-width: 768px){.searchable-station-selector{min-width:200px}.selector-button{min-width:200px;padding:6px 10px}.selector-text{font-size:11px}.selector-menu{min-width:250px}}@media (max-width: 640px){.searchable-station-selector{min-width:180px}.selector-button{min-width:180px;padding:6px 8px}.selector-text{font-size:11px}.selector-menu{min-width:220px}}.wave-intelligence{min-height:100vh;padding:1rem;font-family:DM Sans,Raleway,sans-serif}.wave-intelligence .header-content{text-align:left;margin-bottom:32px;border-bottom:1px solid #e2e8f0}.wave-intelligence .header-content h1{font-size:26px!important;font-weight:600!important;color:#4b5563!important;margin:0 0 8px!important;line-height:1.2!important;font-family:DM Sans,Raleway,sans-serif!important;letter-spacing:normal!important}.wave-intelligence .page-subtitle{color:#64748b;font-size:14px;margin:0 0 16px;line-height:1.5;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-loading,.wave-intelligence .wi-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.wave-intelligence .wi-error h2{color:#dc2626;margin-bottom:16px;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-error p{color:#64748b;font-size:16px;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}.wave-intelligence .wi-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;transition:all .3s ease;box-shadow:0 2px 4px #0000000d;position:relative;overflow:hidden}.wave-intelligence .wi-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.wave-intelligence .wi-card-header{position:relative;z-index:2;margin-bottom:20px;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.wave-intelligence .wi-card-title{flex:1}.wave-intelligence .wi-station-selector{flex-shrink:0;min-width:200px;position:relative;z-index:10}.wave-intelligence .wi-station-dropdown{min-width:200px;position:relative;z-index:10}.wave-intelligence .wi-card-header{position:relative;z-index:10}.wave-intelligence .wi-card-content{position:relative;z-index:1}.wave-intelligence .wi-card-header h3{font-size:18px;font-weight:600;color:#0f172a;margin:0 0 8px;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-card-header p{font-size:14px;color:#64748b;margin:0;line-height:1.5;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-card-content{position:relative;z-index:2}.wave-intelligence .wi-placeholder-content{text-align:center;padding:20px}.wave-intelligence .wi-placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.7}.wave-intelligence .wi-placeholder-content p{font-size:14px;color:#374151;margin-bottom:16px;font-weight:500}.wave-intelligence .wi-placeholder-content ul{list-style:none;padding:0;margin:0;text-align:left}.wave-intelligence .wi-placeholder-content li{font-size:13px;color:#64748b;position:relative;padding:4px 0 4px 16px}.wave-intelligence .wi-placeholder-content li:before{content:"•";color:#3b82f6;position:absolute;left:0;font-weight:700}.wave-intelligence .wi-loading-content{text-align:center;padding:40px 20px}.wave-intelligence .wi-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #3b82f6;border-radius:50%;animation:wi-spin 1s linear infinite;margin:0 auto 16px}@keyframes wi-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wave-intelligence .wi-real-content{padding:0}.wave-intelligence .wi-data-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.wave-intelligence .wi-data-header h4{font-size:16px;font-weight:600;color:#0f172a;margin:0 0 4px;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-station-link{color:#0f172a;text-decoration:none;transition:color .2s ease}.wave-intelligence .wi-station-link:hover{color:#3b82f6;text-decoration:underline}.wave-intelligence .wi-timestamp{font-size:12px;color:#64748b;margin:0;font-family:DM Sans,Inter,monospace}.wave-intelligence .wi-analysis-summary{margin-bottom:20px}.wave-intelligence .wi-analysis-summary p{font-size:14px;color:#374151;margin:0 0 12px;line-height:1.5;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-metrics{display:flex;gap:16px;flex-wrap:wrap}.wave-intelligence .wi-metric{font-size:12px;color:#64748b;background:#f8fafc;padding:6px 12px;border-radius:6px;border:1px solid #e2e8f0}.wave-intelligence .wi-wave-systems{margin-top:16px}.wave-intelligence .wi-wave-systems h5{font-size:13px;font-weight:600;color:#374151;margin:0 0 12px}.wave-intelligence .wi-wave-system{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:8px}.wave-intelligence .wi-system-type{font-size:11px;font-weight:600;color:#3b82f6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.wave-intelligence .wi-system-details{display:flex;justify-content:space-between;font-size:12px;color:#64748b;font-family:Inter,monospace}.wave-intelligence .wi-retry-button{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;margin-top:16px;transition:background-color .2s}.wave-intelligence .wi-retry-button:hover{background:#2563eb}.wave-intelligence .wi-development-notice{background:#fbbf241a;border:1px solid rgba(251,191,36,.2);border-radius:12px;padding:20px;text-align:center;margin-top:32px}.wave-intelligence .wi-development-notice h4{font-size:16px;font-weight:600;color:#92400e;margin:0 0 8px}.wave-intelligence .wi-development-notice p{font-size:14px;color:#78716c;margin:0;line-height:1.6}@media (max-width: 1200px){.wave-intelligence .wi-grid{grid-template-columns:1fr 1fr;gap:20px}}@media (max-width: 768px){.wave-intelligence{padding:20px}.wave-intelligence .wi-grid{grid-template-columns:1fr;gap:20px}.wave-intelligence .wi-card{padding:20px}.wave-intelligence .header-content h1{font-size:1.5rem}}@media (max-width: 640px){.wave-intelligence,.wave-intelligence .wi-card{padding:16px}}.wave-intelligence .wi-chart-container{margin:20px 0;background:#f8fafc;border-radius:8px;padding:16px;border:1px solid #e2e8f0}.wave-intelligence .wi-chart-wrapper{position:relative;width:100%}.wave-intelligence .wi-chart-loading,.wave-intelligence .wi-chart-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center;color:#64748b;font-size:14px}.wave-intelligence .wi-storm-signatures{margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0}.wave-intelligence .wi-storm-signatures h5{font-size:13px;font-weight:600;color:#374151;margin:0 0 12px;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-signatures-list{display:flex;flex-direction:column;gap:8px}.wave-intelligence .wi-signature-item{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:8px 12px}.wave-intelligence .wi-signature-type{font-size:10px;font-weight:600;color:#dc2626;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.wave-intelligence .wi-signature-details{display:flex;gap:12px;font-size:11px;color:#64748b;font-family:Inter,monospace}.wave-intelligence .wi-spreading-details{margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0}.wave-intelligence .wi-detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.wave-intelligence .wi-detail-label{color:#64748b;font-weight:500;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-detail-value{color:#374151;font-family:DM Sans,Inter,monospace;font-weight:600}.wave-intelligence .wi-error-content{text-align:center;padding:40px 20px}.wave-intelligence .wi-error-message{color:#dc2626;font-size:14px;margin-bottom:16px}.wave-intelligence .wi-enhanced-metrics{margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0}.wave-intelligence .wi-metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.wave-intelligence .wi-metric-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:12px}.wave-intelligence .wi-metric-group h6{font-size:11px;font-weight:600;color:#374151;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding-bottom:4px}.wave-intelligence .wi-metric-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:11px}.wave-intelligence .wi-metric-label{color:#64748b;font-weight:500;flex:1}.wave-intelligence .wi-metric-value{color:#374151;font-family:Inter,monospace;font-weight:600;text-align:right;flex:0 0 auto;margin-left:8px}@media (max-width: 768px){.wave-intelligence .wi-metrics-grid{grid-template-columns:1fr;gap:12px}}.wave-intelligence .wi-info-icon{display:inline-flex;align-items:center;margin-left:8px;color:#64748b;cursor:help;transition:color .2s ease;vertical-align:middle;position:relative}.wave-intelligence .wi-info-icon:hover{color:#3b82f6}.wave-intelligence .wi-custom-tooltip{position:absolute;top:100%;left:0;transform:translate(-20%);background:#1f2937;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:400;white-space:normal;width:200px;z-index:1000;margin-top:4px;box-shadow:0 4px 6px -1px #0000001a;line-height:1.4}.wave-intelligence .wi-custom-tooltip:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:4px solid #1f2937}.wave-intelligence .wi-analysis-summary{margin-bottom:16px;padding:8px 12px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.wave-intelligence .wi-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.wave-intelligence .wi-summary-item{text-align:center}.wave-intelligence .wi-summary-label{font-size:10px;color:#64748b;font-weight:500;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px}.wave-intelligence .wi-summary-value{font-size:12px;font-weight:600;color:#374151;font-family:Inter,monospace}.wave-intelligence .wi-hazard-level{font-size:11px!important;font-weight:700!important}.wave-intelligence .wi-navigation-warning{display:flex;align-items:flex-start;gap:12px;padding:12px;margin-bottom:16px;border-left:4px solid;border-radius:6px;font-size:12px}.wave-intelligence .wi-warning-icon{font-size:16px;flex-shrink:0}.wave-intelligence .wi-warning-text{color:#374151;line-height:1.4;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-analysis-details{margin-top:16px}.wave-intelligence .wi-details-section{margin-bottom:16px}.wave-intelligence .wi-details-section h5{font-size:13px;font-weight:600;color:#374151;margin:0 0 8px}.wave-intelligence .wi-details-section p{font-size:12px;color:#64748b;margin:0;line-height:1.4}.wave-intelligence .wi-wave-systems-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.wave-intelligence .wi-wave-system-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:10px}.wave-intelligence .wi-system-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.wave-intelligence .wi-system-id{font-size:11px;font-weight:600;color:#3b82f6;background:#dbeafe;padding:2px 6px;border-radius:4px}.wave-intelligence .wi-system-type{font-size:10px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.wave-intelligence .wi-system-details{display:flex;flex-direction:column;gap:4px}.wave-intelligence .wi-system-metric{display:flex;justify-content:space-between;font-size:11px}.wave-intelligence .wi-metric-label{color:#64748b;font-family:DM Sans,Inter,sans-serif}.wave-intelligence .wi-metric-value{color:#374151;font-family:DM Sans,Inter,monospace;font-weight:500}.wave-intelligence .wi-interference-zones{display:flex;flex-direction:column;gap:10px}.wave-intelligence .wi-interference-zone{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:10px}.wave-intelligence .wi-zone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.wave-intelligence .wi-zone-hazard{font-size:11px;font-weight:600}.wave-intelligence .wi-zone-type{font-size:10px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.wave-intelligence .wi-zone-details{display:flex;flex-direction:column;gap:2px;font-size:11px;color:#64748b}@media (max-width: 768px){.wave-intelligence .wi-summary-grid{grid-template-columns:repeat(2,1fr);gap:12px}.wave-intelligence .wi-wave-systems-grid{grid-template-columns:1fr}}.scheduler-status{max-width:1200px;margin:0 auto;padding:20px;font-family:Inter,sans-serif}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e0f2fe}.header h2{margin:0;color:#1e40af;font-size:24px;font-weight:600}.controls{display:flex;gap:10px}.refresh-btn,.trigger-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.refresh-btn{background:#e0f2fe;color:#0369a1}.refresh-btn:hover{background:#bae6fd}.trigger-btn{background:#10b981;color:#fff}.trigger-btn:hover{background:#059669}.last-refresh{text-align:right;color:#64748b;font-size:12px;margin-bottom:20px}.loading{text-align:center;padding:40px;color:#64748b;font-size:16px}.error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:20px}.status-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.status-section h3{margin:0 0 15px;color:#374151;font-size:18px;font-weight:600}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.status-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:15px;text-align:center}.status-label{font-size:12px;color:#64748b;font-weight:500;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.status-value{font-size:18px;font-weight:600;color:#374151}.status-value.success{color:#10b981}.status-value.warning{color:#f59e0b}.status-value.error{color:#ef4444}.no-data{text-align:center;color:#64748b;font-style:italic;padding:20px}.station-details{margin-top:20px}.station-details h4{margin:0 0 15px;color:#374151;font-size:16px;font-weight:600}.station-table{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.table-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;background:#f3f4f6;padding:12px;font-weight:600;color:#374151;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:12px;border-top:1px solid #e5e7eb;align-items:center}.table-row:nth-child(2n){background:#f9fafb}.station-name{font-weight:500;color:#374151}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:capitalize}.status-badge.fresh{background:#d1fae5;color:#065f46}.status-badge.stale{background:#fef3c7;color:#92400e}.status-badge.no_data{background:#fee2e2;color:#991b1b}@media (max-width: 768px){.scheduler-status{padding:15px}.header{flex-direction:column;gap:15px;align-items:flex-start}.controls{width:100%;justify-content:flex-end}.status-grid{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1fr;gap:8px}.table-header>div,.table-row>div{padding:4px 0}}.admin-page{max-width:1200px;margin:0 auto}.page-header{margin-bottom:32px}.page-header h1{font-size:28px;font-weight:600;color:#1a1d29;margin:0 0 8px;line-height:1.2}.page-header p{font-size:16px;color:#6b7280;margin:0;line-height:1.5}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:16px;border-radius:8px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;font-size:18px;cursor:pointer;color:#dc2626;padding:4px;border-radius:4px;transition:background-color .2s ease}.error-message button:hover{background-color:#dc26261a}.admin-actions{margin-bottom:24px;display:flex;gap:16px;flex-wrap:wrap}.add-station-form,.edit-station-form,.bulk-import-form{background-color:var(--card-background, #ffffff);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin-bottom:24px;transition:all .2s ease;color:var(--text-color)}.add-station-form:hover,.edit-station-form:hover,.bulk-import-form:hover{border-color:var(--border-color);background-color:var(--card-hover-background, #f9fafb);box-shadow:0 2px 8px #0000000a}.edit-station-form{border-color:var(--secondary-color, #86c5da);background-color:#f8fffe}.add-station-form h2,.edit-station-form h2,.bulk-import-form h2{font-size:20px;font-weight:600;color:#1a1d29;margin:0 0 16px}.edit-station-form h2{color:var(--secondary-color, #86c5da)}.edit-station-form input[disabled]{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed;border-color:#e5e7eb}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:24px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group input,.form-group textarea{padding:10px 16px;border:1px solid #e1e5e9;border-radius:6px;font-size:14px;font-weight:400;color:#1a1d29;background-color:#fff;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color, #e1f3f9);box-shadow:0 0 0 3px #c2e7f21a}.form-group small{margin-top:4px;font-size:12px;color:#6b7280}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease;border:1px solid transparent;cursor:pointer;line-height:1}.btn-small{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .2s ease;text-align:center;line-height:1;margin-right:6px}.btn-outline{background-color:#fff;color:#6b7280;border-color:#e1e5e9}.btn-outline:hover{background-color:#f9fafb;border-color:#d1d5db;color:#374151}.btn-danger{background-color:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{background-color:#b91c1c;border-color:#b91c1c}.btn-success{background-color:#16a34a;color:#fff;border-color:#16a34a}.btn-success:hover{background-color:#15803d;border-color:#15803d}.btn-warning{background-color:#d97706;color:#fff;border-color:#d97706}.btn-warning:hover{background-color:#b45309;border-color:#b45309}.station-actions{display:flex;gap:6px;flex-wrap:nowrap;align-items:center;justify-content:flex-start;min-width:120px}.test-results,.test-results-global{margin-top:24px;padding:24px;background-color:var(--card-background, #ffffff);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease;color:var(--text-color)}.test-results:hover,.test-results-global:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.test-results h3,.test-results-global h3{font-size:18px;font-weight:600;color:#1a1d29;margin:0 0 8px}.test-explanation{font-size:14px;color:#6b7280;margin-bottom:20px;font-style:italic}.test-result{margin-bottom:16px;padding:16px;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.test-result:last-child{margin-bottom:0}.test-result h4{font-size:14px;font-weight:600;color:#1a1d29;margin:0 0 8px}.test-result .status{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;margin-bottom:8px;line-height:1}.status.success{background-color:#dcfce7;color:#166534}.status.error{background-color:#fef2f2;color:#dc2626}.status.testing{background-color:#fef3c7;color:#d97706}.test-result p{margin-bottom:8px;font-size:14px;color:#1a1d29}.test-result small{font-size:12px;color:#6b7280;word-break:break-all;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.test-summary{margin-top:20px;padding:16px;border-radius:6px;border:1px solid #e1e5e9}.summary-success{background-color:#f0fdf4;border-color:#16a34a}.summary-success strong{font-size:14px;font-weight:600;color:#166534;display:block;margin-bottom:4px}.summary-success p{font-size:12px;color:#166534;margin:0}.summary-warning{background-color:#fffbeb;border-color:#d97706}.summary-warning strong{font-size:14px;font-weight:600;color:#d97706;display:block;margin-bottom:4px}.summary-warning p{font-size:12px;color:#d97706;margin:0}.stations-list{background-color:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:24px;transition:all .2s ease}.stations-list:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.stations-list h2{font-size:20px;font-weight:600;color:#1a1d29;margin:0 0 20px}.stations-table{overflow-x:auto;border-radius:6px;border:1px solid #e1e5e9}.stations-table table{width:100%;border-collapse:collapse}.stations-table th,.stations-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #f3f4f6;font-size:14px;vertical-align:middle}.stations-table th:nth-child(2),.stations-table td:nth-child(2){max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stations-table th:nth-child(6),.stations-table td:nth-child(6){min-width:120px;white-space:nowrap}.stations-table th{background-color:#f9fafb;font-weight:600;color:#374151;border-bottom:1px solid #e1e5e9}.stations-table tbody tr:hover{background-color:#f9fafb}.stations-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:1}.status-badge.active{background-color:#dcfce7;color:#166534}.status-badge.inactive{background-color:#fef2f2;color:#dc2626}.bulk-import-form p{font-size:14px;color:#6b7280;margin-bottom:20px}.bulk-results{margin-top:20px;padding:20px;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.bulk-results h3{font-size:18px;font-weight:600;color:#1a1d29;margin:0 0 16px}.bulk-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.bulk-result-card{background-color:#fff;border-radius:6px;padding:16px;border:1px solid #e1e5e9;transition:all .2s ease}.bulk-result-card:hover{box-shadow:0 2px 8px #0000000a}.bulk-result-card.ready{border-color:#16a34a;background-color:#f0fdf4}.bulk-result-card.partial{border-color:#d97706;background-color:#fffbeb}.bulk-result-card.error{border-color:#dc2626;background-color:#fef2f2}.bulk-result-card h4{font-size:14px;font-weight:600;color:#1a1d29;margin:0 0 8px}.bulk-result-card .status{display:inline-flex;align-items:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;margin-bottom:8px;line-height:1}.bulk-result-card .status.ready{background-color:#dcfce7;color:#166534}.bulk-result-card .status.partial{background-color:#fef3c7;color:#d97706}.bulk-result-card .status.error{background-color:#fef2f2;color:#dc2626}.bulk-result-card p{margin-bottom:8px;font-size:13px;color:#1a1d29}.endpoint-status{display:flex;gap:.5rem;flex-wrap:wrap}.endpoint-status small{font-size:.7rem;color:var(--light-text-color)}.endpoint-status .success{color:#28a745;font-weight:500}.endpoint-status .error{color:#dc3545;font-weight:500}@media (max-width: 768px){.admin-page{padding:0 16px}.page-header h1{font-size:24px}.admin-actions{flex-direction:column;gap:12px}.add-station-form,.edit-station-form,.bulk-import-form,.stations-list,.test-results,.test-results-global{padding:20px}.form-grid{grid-template-columns:1fr;gap:12px}.form-actions{flex-direction:column;gap:8px}.stations-table th,.stations-table td{padding:10px 8px;font-size:13px}.station-actions{gap:4px}.btn-small{margin-right:4px}.bulk-results-grid{grid-template-columns:1fr;gap:12px}}@media (max-width: 640px){.form-actions{align-items:stretch}.station-actions{flex-direction:column;align-items:stretch;gap:6px}.btn-small{margin-right:0;margin-bottom:4px}.btn-small:last-child{margin-bottom:0}}.bulk-examples{margin:1.5rem 0;padding:1rem;background-color:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.bulk-examples h4{color:var(--text-color);margin-bottom:.75rem;font-size:.9rem;font-weight:600}.example-stations{display:flex;gap:.75rem;flex-wrap:wrap}.btn-outline{background-color:transparent;border:1px solid var(--primary-color);color:var(--text-color)}.btn-outline:hover{background-color:var(--primary-color);color:var(--text-color)}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.onboarding-status{color:var(--light-text-color);font-size:.9rem;font-style:italic;margin-left:1rem}.results-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1.5rem}.result-stat{text-align:center;padding:1rem;background-color:#fff;border-radius:4px;border:1px solid #e9ecef}.result-stat.success{border-color:#28a745;background-color:#f8fff9}.result-stat.warning{border-color:#ffc107;background-color:#fffdf5}.result-stat.error{border-color:#dc3545;background-color:#fff5f5}.stat-number{display:block;font-size:1.5rem;font-weight:700;color:var(--text-color);margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--light-text-color);font-weight:500}.result-section{margin-bottom:1.5rem;padding:1rem;background-color:#fff;border-radius:4px;border:1px solid #e9ecef}.result-section h4{color:var(--text-color);margin-bottom:.75rem;font-size:.9rem;font-weight:600}.result-section ul{list-style:none;padding:0;margin:0}.result-section li{padding:.5rem 0;border-bottom:1px solid #f8f9fa;font-size:.9rem;color:var(--text-color)}.result-section li:last-child{border-bottom:none}.result-section li strong{font-family:monospace;background-color:#f8f9fa;padding:.2rem .4rem;border-radius:3px;margin-right:.5rem}.wave-logo-container{display:inline-block;position:relative}.wave-logo{position:relative;display:inline-block;overflow:hidden}.wave-logo-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.wave-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;background:linear-gradient(135deg,rgba(0,119,182,.1) 0%,rgba(0,119,182,.05) 50%,transparent 100%)}.wave-logo-small .wave-logo{width:32px;height:32px}.wave-logo-medium .wave-logo{width:48px;height:48px}.wave-logo-large .wave-logo{width:64px;height:64px}.wave-logo-cresting .wave-logo{clip-path:polygon(0% 0%,100% 0%,100% 60%,95% 65%,90% 70%,85% 75%,75% 80%,65% 85%,50% 88%,35% 85%,25% 80%,15% 75%,10% 70%,5% 65%,0% 60%)}.wave-logo-ocean .wave-logo{clip-path:polygon(0% 0%,100% 0%,100% 70%,98% 72%,95% 75%,90% 78%,85% 82%,78% 85%,70% 88%,60% 90%,50% 92%,40% 90%,30% 88%,22% 85%,15% 82%,10% 78%,5% 75%,2% 72%,0% 70%)}.wave-logo-breaking .wave-logo{clip-path:polygon(0% 0%,100% 0%,100% 55%,97% 58%,93% 62%,88% 66%,82% 70%,75% 74%,67% 78%,58% 82%,48% 85%,37% 87%,26% 85%,18% 82%,12% 78%,8% 74%,5% 70%,3% 66%,1% 62%,0% 58%)}.wave-logo-tsunami .wave-logo{clip-path:polygon(0% 0%,100% 0%,100% 45%,96% 50%,90% 55%,83% 60%,75% 65%,66% 70%,56% 75%,45% 80%,33% 83%,20% 85%,10% 82%,5% 78%,2% 73%,0% 68%)}.wave-logo-gentle .wave-logo{clip-path:polygon(0% 0%,100% 0%,100% 75%,95% 78%,90% 80%,85% 82%,80% 84%,70% 86%,60% 87%,50% 88%,40% 87%,30% 86%,20% 84%,15% 82%,10% 80%,5% 78%,0% 75%)}.wave-logo:hover .wave-logo-image{transform:scale(1.05)}.wave-logo:hover .wave-overlay{background:linear-gradient(135deg,rgba(0,119,182,.2) 0%,rgba(0,119,182,.1) 50%,transparent 100%)}@keyframes wave-flow{0%{clip-path:polygon(0% 0%,100% 0%,100% 70%,98% 72%,95% 75%,90% 78%,85% 82%,78% 85%,70% 88%,60% 90%,50% 92%,40% 90%,30% 88%,22% 85%,15% 82%,10% 78%,5% 75%,2% 72%,0% 70%)}50%{clip-path:polygon(0% 0%,100% 0%,100% 65%,96% 68%,92% 72%,87% 76%,82% 80%,76% 83%,68% 86%,58% 88%,48% 90%,38% 88%,28% 86%,20% 83%,14% 80%,9% 76%,4% 72%,1% 68%,0% 65%)}to{clip-path:polygon(0% 0%,100% 0%,100% 70%,98% 72%,95% 75%,90% 78%,85% 82%,78% 85%,70% 88%,60% 90%,50% 92%,40% 90%,30% 88%,22% 85%,15% 82%,10% 78%,5% 75%,2% 72%,0% 70%)}}.wave-logo-animated .wave-logo{animation:wave-flow 3s ease-in-out infinite}@media (max-width: 768px){.wave-logo-large .wave-logo{width:48px;height:48px}.wave-logo-medium .wave-logo{width:40px;height:40px}}.wave-demo{padding:2rem;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#f8f9fa,#e9ecef);min-height:100vh}.wave-demo-header{text-align:center;margin-bottom:3rem}.wave-demo-header h1{color:var(--text-color);font-size:2.5rem;margin-bottom:1rem;font-weight:700}.wave-demo-header p{color:var(--light-text-color);font-size:1.2rem}.wave-demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.wave-demo-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.wave-demo-card:hover{transform:translateY(-5px);box-shadow:0 8px 15px #00000026}.wave-demo-preview{margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center;height:100px}.wave-demo-info h3{color:var(--text-color);margin-bottom:.5rem;font-size:1.3rem;font-weight:600}.wave-demo-info p{color:var(--light-text-color);margin-bottom:1rem;font-size:.9rem;line-height:1.5}.wave-demo-code{background:#f8f9fa;padding:.5rem 1rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8rem;color:#495057;border:1px solid #e9ecef;display:inline-block}.wave-demo-sizes{background:#fff;border-radius:12px;padding:2rem;margin-bottom:3rem;box-shadow:0 4px 6px #0000001a}.wave-demo-sizes h2{color:var(--text-color);margin-bottom:1.5rem;text-align:center;font-size:1.8rem;font-weight:600}.size-demo{display:flex;justify-content:center;align-items:center;gap:3rem;flex-wrap:wrap}.size-item{display:flex;flex-direction:column;align-items:center;gap:1rem}.size-item span{color:var(--light-text-color);font-size:.9rem;font-weight:500}.wave-demo-usage{background:#fff;border-radius:12px;padding:2rem;margin-bottom:3rem;box-shadow:0 4px 6px #0000001a}.wave-demo-usage h2{color:var(--text-color);margin-bottom:1.5rem;text-align:center;font-size:1.8rem;font-weight:600}.usage-examples{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.usage-example{border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;background:#f8f9fa}.usage-example h4{color:var(--text-color);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.navbar-preview{background:var(--navbar-bg, #e1f3f9);padding:1rem;border-radius:6px;display:flex;align-items:center}.logo-preview{display:flex;align-items:center;gap:.75rem}.logo-text-preview{font-family:Bistroc,sans-serif;font-size:1.2rem;color:var(--text-color);font-weight:500}.wave-demo-technical{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.wave-demo-technical h2{color:var(--text-color);margin-bottom:1.5rem;text-align:center;font-size:1.8rem;font-weight:600}.tech-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.tech-item{padding:1.5rem;border:1px solid #e9ecef;border-radius:8px;background:#f8f9fa}.tech-item h4{color:var(--text-color);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.tech-item p{color:var(--light-text-color);font-size:.9rem;line-height:1.5;margin:0}@media (max-width: 768px){.wave-demo{padding:1rem}.wave-demo-header h1{font-size:2rem}.wave-demo-grid{grid-template-columns:1fr;gap:1.5rem}.size-demo{gap:2rem}.usage-examples,.tech-info{grid-template-columns:1fr}}.about{min-height:80vh;max-width:800px;margin:0 auto;padding:0}.about-nav{text-align:center;margin-bottom:3rem;padding:0 2rem}.about .nav-link-button{display:inline-flex;align-items:center;gap:8px;background-color:#4b5563;color:#fff;padding:12px 24px;border-radius:8px;text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.about .nav-link-button:hover{background-color:#374151;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.about .nav-icon{font-size:16px;opacity:.9}.about-content{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:3rem;margin:0 2rem;line-height:1.7;font-size:16px}.about-content h2{color:var(--text-color);font-size:2rem;font-weight:700;margin:2.5rem 0 1.5rem;line-height:1.3;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem}.about-content h2:first-child{margin-top:0}.about-content h3{color:var(--text-color);font-size:1.5rem;font-weight:600;margin:2rem 0 1rem;line-height:1.4}.about-content h4{color:var(--text-color);font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem;line-height:1.4}.about-content p{color:#374151;line-height:1.7;margin-bottom:1.5rem;font-size:16px}.about-content p:last-child{margin-bottom:0}.about-content .feature-list{margin:1.5rem 0;padding-left:0;list-style:none}.about-content .feature-list li{margin-bottom:1rem;padding-left:1.5rem;position:relative;line-height:1.6;color:#374151}.about-content .feature-list li:before{content:"•";color:var(--primary-color);font-weight:700;position:absolute;left:0;font-size:1.2em}.about-content ul:not(.feature-list){margin:1rem 0 1.5rem;padding-left:1.5rem}.about-content ul:not(.feature-list) li{margin-bottom:.75rem;line-height:1.6;color:#374151}.about-content strong{color:var(--text-color);font-weight:600}@media (max-width: 768px){.about{max-width:100%}.about-content{margin:0 1rem;padding:2rem 1.5rem}.about-nav{padding:0 1rem;margin-bottom:2rem}.about-content h2{font-size:1.75rem}.about-content h3{font-size:1.375rem}}@media (max-width: 480px){.about-content{margin:0 .5rem;padding:1.5rem 1rem}.about-nav{padding:0 .5rem}.about-content h2{font-size:1.5rem}.about-content h3{font-size:1.25rem}.about-content p,.about-content li{font-size:15px}}.not-found{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center}.not-found-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:3rem;max-width:600px;width:100%}.not-found h1{font-size:6rem;color:var(--primary-color);margin:0;line-height:1}.not-found h2{font-size:2rem;color:var(--light-text-color);margin-top:.5rem;margin-bottom:1.5rem}.not-found p{margin-bottom:2rem;color:var(--light-text-color);font-size:1.1rem}.not-found-actions{display:flex;justify-content:center;gap:1rem}@media (max-width: 768px){.not-found-content{padding:2rem}.not-found h1{font-size:4rem}.not-found h2{font-size:1.5rem}.not-found-actions{flex-direction:column}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:var(--background-color)}@font-face{font-family:Zettameter;src:url(/zettameter.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Bistroc;src:url(/bistroc.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:LincolnElectric;src:url(/LincolnElectric-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:LincolnElectricOver;src:url(/LincolnElectric-Over.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:HaloGrotesk;src:url(/HaloGrotesk-Regular.otf) format("opentype"),url(/HaloGrotesk-Regular.otf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:VinnytsiaSans;src:url(/VinnytsiaSansBold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Official1;src:url(/official1.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--font-primary: "DM Sans", "Raleway", "Inter", "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;--font-brand: "Raleway", "Zettameter", "Official1", "LincolnElectricOver", "LincolnElectric", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-data: "Inter", "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", "Courier New", monospace;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--primary-color: #e1f3f9;--secondary-color: #86c5da;--accent-color: #e1f4f8;--background-color: #f8f9fa;--text-color: #333333;--light-text-color: #666;--border-color: #ddd;--success-color: #28a745;--warning-color: #ffc107;--danger-color: #dc3545;--info-color: #17a2b8;--chart-primary-color: var(--primary-color);--chart-secondary-color: var(--secondary-color);--chart-accent-color: var(--accent-color)}:root{--card-background: #ffffff;--card-hover-background: #f9fafb;--input-background: #ffffff;--dropdown-background: #ffffff}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-color);background-color:var(--background-color);min-height:100vh}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}.navbar-links a,.navbar-links a:hover,.navbar-links a:focus,.navbar-links a:active,.navbar-links a.active{text-decoration:none!important;border-bottom:none!important}.container{max-width:1200px;margin:0 auto;padding:0 1rem}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0;color:var(--text-color)}.page-header h1,.page-header h2,.page-header h3,.dashboard h1,.station-list h1,.station-detail h1,.compare-stations h1,.admin-page h1,.stations-list h2,.chart-header h2,.section-header h2{color:var(--text-color)!important}h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium)}h5{font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease;border:1px solid transparent;cursor:pointer;font-family:var(--font-primary);line-height:1}.btn-primary{background-color:var(--primary-color, #e1f3f9);color:#1a1d29;border-color:var(--primary-color, #e1f3f9)}.btn-primary:hover{background-color:var(--secondary-color, #86c5da);border-color:var(--secondary-color, #86c5da);text-decoration:none;color:#1a1d29}.btn-secondary{background-color:#fff;color:#6b7280;border-color:#e1e5e9}.btn-secondary:hover{background-color:#f9fafb;border-color:#d1d5db;color:#374151;text-decoration:none}.btn-small{padding:6px 12px;font-size:12px}.card{background-color:var(--card-background, #ffffff);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin-bottom:16px;transition:all .2s ease;color:var(--text-color)}.card:hover{border-color:var(--border-color);background-color:var(--card-hover-background, #f9fafb);box-shadow:0 2px 8px #0000000a}.data-table,.station-info-table,.current-conditions-table,.numerical-data,.data-value,.metric-value{font-family:var(--font-data)!important;font-feature-settings:"tnum" 1}.station-detail .data-table,.station-detail .station-info,.station-detail .current-conditions,.station-detail .metric-card .value,.station-detail .metric-card .unit{font-family:var(--font-data)!important}.current-conditions-table .info-label,.station-info-table .info-label,.data-table .info-label{color:#c50!important;font-weight:500}.current-conditions-table .data-value,.station-info-table .data-value,.data-table .data-value{color:var(--text-color)!important}.dashboard-field-label{color:#c50!important;font-weight:500;font-family:var(--font-data)!important}.dashboard-data-value{color:var(--text-color)!important;font-family:var(--font-data)!important;font-feature-settings:"tnum" 1}input,textarea,select{background-color:var(--input-background, #ffffff);border:1px solid var(--border-color);color:var(--text-color);transition:background-color .3s ease,border-color .3s ease}input:focus,textarea:focus,select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #c2e7f233}
