body{background:var(--sky-gray,#f0f4f8);font-family:var(--font-body);margin:0;padding-top:64px}.page-container{display:flex;min-height:calc(100vh - 64px)}.main-content{flex:1;margin:0 auto;max-width:1200px;padding:24px;width:100%}.forecast-analysis-section{background:#fff;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;margin-bottom:16px;overflow:hidden}.analysis-header{position:relative}.analysis-toggle{align-items:center;background:#fff;border:none;cursor:pointer;display:flex;font-family:var(--font-body);gap:12px;justify-content:space-between;padding:16px 20px;text-align:left;transition:background-color .2s ease;width:100%}.analysis-toggle:hover{background-color:var(--sky-gray,#f0f4f8)}.analysis-toggle:focus{outline:2px solid var(--ocean-blue);outline-offset:-2px}.analysis-toggle .toggle-icon{color:var(--text-secondary,#6b7280);flex-shrink:0;font-size:24px;margin-left:auto;transition:transform .3s ease}.analysis-toggle[aria-expanded=true] .toggle-icon{transform:rotate(180deg)}.analysis-toggle .analysis-icon{align-items:center;color:var(--ocean-blue,#068297);display:flex;flex-shrink:0;font-size:20px;justify-content:center;margin-left:0;width:20px}.analysis-title{color:var(--midnight-navy,#0f172a);flex:1;font-size:14px;font-weight:500;margin-left:4px}.analysis-updated{color:var(--text-secondary,#6b7280);font-size:12px;margin-left:8px}.analysis-content{animation:slideDown .3s ease-out;background:var(--sky-gray,#f0f4f8);border-top:1px solid var(--border-color,#e5e7eb)}.forecast-summary{color:var(--text-primary,#1f2937);font-size:14px;line-height:1.6;padding:20px}.forecast-summary p{margin:0}.forecast-summary .no-summary{color:var(--text-secondary,#6b7280);font-style:italic}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--ocean-blue);height:48px;margin-bottom:16px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{color:var(--text-secondary);font-size:var(--text-base)}.auth-message{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--elevation-2);margin:100px auto;max-width:600px;padding:48px;text-align:center}.auth-message h2{color:var(--text-primary);font-size:var(--text-2xl);margin-bottom:16px}.auth-message p{color:var(--text-secondary);margin-bottom:24px}.auth-message .btn{margin:0 8px}.location-navigation{align-items:center;display:flex;gap:24px;justify-content:center;margin-bottom:24px;padding:24px 0}.location-dropdown{display:inline-block;position:relative}.location-dropdown-trigger{align-items:center;background:transparent;border:none;border-radius:8px;cursor:default;display:flex;gap:8px;justify-content:center;padding:8px 4px;transition:background-color .2s ease}.location-dropdown.has-multiple .location-dropdown-trigger{cursor:pointer}.location-dropdown.has-multiple .location-dropdown-trigger:hover{background-color:var(--sky-gray,#f0f4f8)}.location-dropdown-trigger h1{color:var(--midnight-navy,#0f172a);font-size:32px;font-weight:700;line-height:1.2;margin:0}.location-dropdown-trigger .dropdown-arrow{color:var(--text-secondary,#6b7280);display:none;font-size:28px;transition:transform .2s ease}.location-dropdown.has-multiple .dropdown-arrow{display:block}.location-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.location-dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);left:50%;list-style:none;margin-top:8px;max-width:300px;min-width:200px;opacity:0;padding:8px 0;position:absolute;top:100%;transform:translateX(-50%);transform:translateX(-50%) translateY(-10px);transition:opacity .2s ease,transform .2s ease,visibility .2s;visibility:hidden;z-index:1000}.location-dropdown.open .location-dropdown-menu{opacity:1;transform:translateX(-50%) translateY(0);visibility:visible}.location-dropdown-item{align-items:center;color:var(--midnight-navy,#0f172a);cursor:pointer;display:flex;font-size:16px;gap:12px;justify-content:space-between;padding:12px 16px;transition:background-color .15s ease}.location-dropdown-item.selected,.location-dropdown-item:hover{background-color:var(--sky-gray,#f0f4f8)}.location-dropdown-item.selected{font-weight:600}.location-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-item-badge{background:var(--ocean-blue,#068297);border-radius:4px;color:#fff;flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.location-header{min-width:300px;text-align:center}.location-header h1{color:var(--text-primary);font-size:var(--text-4xl);font-weight:700;line-height:1.2;margin:0}.location-subtitle{color:var(--text-secondary);font-size:var(--text-lg);font-weight:400;margin:4px 0 0}.forecast-info-bar{align-items:center;background:var(--sky-gray);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:20px;padding:12px 16px}.info-actions{align-items:center;display:flex;gap:8px}.help-icon{background:transparent;color:var(--text-secondary);transition:color .2s}.help-icon:hover{background:var(--state-hover);color:var(--ocean-blue)}.btn-icon{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:50%;cursor:pointer;display:flex;height:48px;justify-content:center;min-height:48px;min-width:48px;padding:12px;transition:all .2s;width:48px}.btn-icon:hover{background:var(--state-hover);border-color:var(--ocean-blue)}.btn-icon .material-icons{color:var(--text-secondary);font-size:20px}.last-updated{align-items:center;color:#1f2937;display:flex;font-size:var(--text-sm);gap:8px}.last-updated .noaa-logo{height:20px;object-fit:contain;width:20px}.forecast-container{max-width:1200px;width:100%}.forecast-grid{display:flex;flex:1;flex-direction:column;gap:12px}.forecast-row{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--elevation-1);margin-bottom:8px;padding:16px;position:relative;transition:all .2s}.forecast-row:hover{box-shadow:var(--elevation-2)}.forecast-row.today{background:linear-gradient(135deg,var(--ocean-blue) 0,#0a9eb8 100%);color:#fff;padding:20px}.forecast-row.today .date,.forecast-row.today .day-forecast,.forecast-row.today .day-name,.forecast-row.today .temp-high,.forecast-row.today .temp-low{color:#fff}.forecast-row.today .detail-item,.forecast-row.today .night-forecast{color:hsla(0,0%,100%,.9)}.forecast-content{align-items:center;display:grid;gap:12px;grid-template-columns:110px 50px 200px minmax(300px,1fr);min-height:60px;width:100%}.forecast-date-section{display:flex;flex-direction:column}.day-name{color:var(--text-primary);font-size:var(--text-base);font-weight:600;line-height:1.2}.date{color:var(--text-secondary);font-size:var(--text-sm);margin-top:2px}.forecast-icon-section{align-items:center;display:flex;flex-shrink:0;justify-content:center}.weather-icon{color:var(--ocean-blue);font-size:40px}.forecast-row.today .weather-icon{color:#fff}.weather-extreme .weather-icon{color:var(--hibiscus-red)}.weather-severe .weather-icon{color:var(--sunset-orange)}.weather-high .weather-icon{color:var(--sunrise-yellow)}.weather-moderate .weather-icon{color:var(--ocean-blue)}.weather-low .weather-icon{color:var(--text-secondary)}.weather-normal .weather-icon{color:var(--ocean-blue)}.weather-icon.sunny-icon{color:var(--sunrise-yellow)!important}.temperature-section{display:flex;flex-direction:column;min-width:0}.temperature-display{align-items:center;display:flex;gap:8px}.temp-low{color:var(--text-secondary);text-align:right}.temp-high,.temp-low{font-size:var(--text-sm);width:35px}.temp-high{color:var(--text-primary);font-weight:600;text-align:left}.temperature-bar-container{align-items:center;display:flex;flex:1;height:8px;position:relative}.temperature-bar-background{background:linear-gradient(90deg,var(--ocean-blue) 0,var(--ocean-blue) 25%,var(--palm-green) 35%,var(--palm-green) 55%,var(--sunrise-yellow) 60%,var(--sunrise-yellow) 70%,var(--sunset-orange) 75%,var(--sunset-orange) 85%,var(--hibiscus-red) 90%,var(--hibiscus-red) 100%);border-radius:2px;height:4px;opacity:.2;position:absolute;width:100%}.temperature-bar-fill{border-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,.1);height:8px;position:absolute}.forecast-info-section{align-items:center;display:flex;gap:16px;justify-content:space-between;min-width:0}.forecast-description-section{display:flex;flex:1;flex-direction:column;gap:4px;min-width:0}.day-forecast{color:var(--text-primary);font-size:var(--text-sm)}.day-forecast,.night-forecast{line-height:1.4;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.night-forecast{color:var(--text-secondary);font-size:var(--text-xs)}.forecast-details-section{align-items:center;display:flex;flex-shrink:0;gap:12px}.detail-item{align-items:center;color:var(--text-secondary);font-size:var(--text-sm);gap:4px;white-space:nowrap}.detail-item .material-icons{font-size:16px}.precip-chance .material-icons{color:#60a5fa}.wind-info .material-icons{color:var(--text-muted)}.threat-section{border-top:1px solid var(--border-color);grid-column:1/-1;margin-top:12px;padding-top:12px}.forecast-row.today .threat-section{border-top-color:hsla(0,0%,100%,.2)}.threat-section:not(.threat-placeholder){border-top:none;margin-top:8px;padding:0}.threat-content{align-items:center;border-radius:var(--radius-md);display:flex;gap:12px;padding:12px 16px;transition:all .3s ease}.threat-icon{color:hsla(0,0%,100%,.95);flex-shrink:0;font-size:20px}.threat-description{color:hsla(0,0%,100%,.95);font-size:var(--text-sm);font-weight:500;line-height:1.4}.forecast-row.today .threat-content{backdrop-filter:blur(10px);background-color:hsla(0,0%,100%,.15)!important}.forecast-row.today .threat-description,.forecast-row.today .threat-icon{color:hsla(0,0%,100%,.95)}.threat-placeholder{background:var(--sky-gray);border:1px dashed var(--border-color);border-radius:var(--radius-md);padding:12px 16px}.forecast-row.today .threat-placeholder{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.3)}.threat-grid{display:flex;flex-direction:column;gap:4px}.threat-label{color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.threat-coming-soon{color:var(--text-muted);font-size:var(--text-sm)}.forecast-row.today .threat-coming-soon,.forecast-row.today .threat-label{color:hsla(0,0%,100%,.8)}.detailed-forecast{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.forecast-row.today .detailed-forecast{border-top-color:hsla(0,0%,100%,.2)}.detailed-forecast p{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin:0}.forecast-row.today .detailed-forecast p{color:hsla(0,0%,100%,.95)}.error-message{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--elevation-2);margin:48px auto;max-width:600px;padding:48px;text-align:center}.error-message .material-icons{color:var(--text-muted);font-size:64px;margin-bottom:16px}.error-message h3{color:var(--text-primary);font-size:var(--text-xl);margin-bottom:12px}.error-message p{color:var(--text-secondary);margin-bottom:24px}.no-forecast-data{color:var(--text-secondary);grid-column:1/-1;padding:48px;text-align:center}.no-forecast-data .material-icons{color:var(--text-muted);font-size:64px;margin-bottom:16px}.btn{border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-block;font-size:var(--text-base);font-weight:500;padding:10px 20px;text-decoration:none;transition:all .2s}.btn-primary{background:var(--ocean-blue);color:#fff}.btn-primary:hover{background:#057489;transform:translateY(-1px)}.btn-secondary{background:transparent;border:1px solid var(--ocean-blue);color:var(--ocean-blue)}.btn-secondary:hover{background:var(--state-hover)}@media (max-width:1024px){.forecast-content{gap:8px;grid-template-columns:100px 40px 160px 1fr}.forecast-info-section{align-items:stretch;flex-direction:column}.forecast-description-section{width:100%}.day-forecast,.night-forecast{white-space:normal}.forecast-details-section{margin-top:4px}.threat-section{margin-top:8px}}.modal-overlay{background:rgba(0,0,0,.5);bottom:0;display:none;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-overlay.active{align-items:center;display:flex;justify-content:center}.modal-content{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--elevation-3);display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.modal-header{align-items:center;background:var(--ocean-blue);border-radius:var(--radius-lg) var(--radius-lg) 0 0;color:#fff;display:flex;justify-content:space-between;padding:var(--spacing-6)}.modal-header h2{color:#fff;font-size:var(--text-xl);font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;opacity:.8;padding:0;transition:all .2s ease;width:32px}.modal-close:hover{background:hsla(0,0%,100%,.1);opacity:1}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-6)}.help-content{color:var(--text-primary);line-height:1.6}.help-content h3{color:var(--ocean-blue);font-size:var(--text-lg);margin-bottom:var(--spacing-3);margin-top:var(--spacing-5)}.help-content ul{margin:var(--spacing-3) 0;padding-left:var(--spacing-5)}.help-content li{margin-bottom:var(--spacing-3)}.help-content strong{color:var(--sunset-orange);font-weight:600}.help-note{align-items:flex-start;background:var(--sky-gray);border-radius:var(--radius-md);display:flex;gap:var(--spacing-2);margin-top:var(--spacing-5);padding:var(--spacing-4)}.help-note .material-icons{color:var(--ocean-blue);font-size:20px;margin-top:2px}@media (max-width:768px){.main-content{padding:16px}.location-navigation{gap:12px;padding:16px 0}.location-header{min-width:auto}.location-header h1{font-size:var(--text-2xl)}.location-subtitle{font-size:var(--text-base)}.location-dropdown-trigger .dropdown-arrow,.location-dropdown-trigger h1{font-size:24px}.location-dropdown-menu{max-width:280px;min-width:180px}.location-dropdown-item{font-size:15px;padding:10px 14px}.forecast-info-bar{align-items:flex-start;flex-direction:column;gap:8px}.forecast-grid{gap:8px}.forecast-row{padding:12px}.forecast-content{align-items:stretch;display:flex;flex-direction:column;gap:12px}.forecast-date-section{align-items:center;display:flex;flex-direction:row;justify-content:space-between;width:100%}.forecast-icon-section{align-self:center;margin:8px 0}.temperature-section{width:100%}.temperature-display{align-items:center;display:flex;gap:8px;justify-content:space-between;width:100%}.temperature-bar-container{flex:1;height:8px;max-width:200px;min-width:120px}.forecast-info-section{align-items:stretch;flex-direction:column;gap:8px}.forecast-description-section{width:100%}.day-forecast,.night-forecast{white-space:normal}.forecast-details-section{justify-content:center;margin-top:8px}.threat-section{margin-top:8px;padding-top:8px}.weather-icon{font-size:36px}.forecast-row.expanded .detailed-forecast{display:block}.forecast-row:not(.expanded) .detailed-forecast{display:none}.forecast-row.expanded{box-shadow:var(--elevation-3)}}@media (max-width:375px){.forecast-card{padding:12px}.temp-high,.temp-low{font-size:var(--text-sm);min-width:28px}.temperature-bar-container{min-width:80px}}.threat-color-grid{display:grid;font-size:var(--text-sm);gap:8px;grid-template-columns:120px repeat(3,1fr);margin:var(--spacing-4) 0}.grid-header{text-align:center}.grid-header,.grid-label{background:var(--sky-gray);border-radius:var(--radius-sm);color:var(--text-primary);font-weight:600;padding:8px}.grid-label,.threat-box{align-items:center;display:flex}.threat-box{border-radius:var(--radius-sm);color:#fff;font-size:var(--text-xs);font-weight:500;justify-content:center;min-height:44px;padding:12px 8px;text-align:center}@media (max-width:768px){.threat-color-grid{font-size:var(--text-xs);gap:6px;grid-template-columns:80px repeat(3,1fr)}.grid-header,.grid-label{font-size:10px;padding:6px 4px}.threat-box{font-size:9px;min-height:36px;padding:8px 4px}}.location-header-info{min-width:300px;text-align:center}.location-header-info h1{color:var(--midnight-navy,#0f172a);font-size:32px;font-weight:700;line-height:1.2;margin:0 0 12px}.tab-navigation{border-bottom:2px solid var(--border-color,#e5e7eb);display:flex;gap:24px;justify-content:center;padding-bottom:8px}.tab-btn{align-items:center;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;font-family:var(--font-body);font-size:16px;gap:8px;margin-bottom:-10px;min-height:48px;padding:12px 16px;transition:all .2s}.tab-btn i{height:18px;width:18px}.tab-btn.active,.tab-btn:hover:not(.disabled){color:var(--ocean-blue,#068297)}.tab-btn.active{border-bottom-color:var(--ocean-blue,#068297);font-weight:600}.tab-btn.disabled{cursor:not-allowed;opacity:.5}.tab-btn .coming-soon{color:var(--text-muted,#9ca3af);font-size:11px;margin-left:4px}.forecast-page-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto auto auto;margin:0 auto;max-width:1200px}.grid-item{min-height:0}.grid-full-width{grid-column:1/-1}.ai-summary-24h-card,.ai-summary-7day-card,.current-conditions-card,.hourly-chart-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);overflow:hidden}.card-header{align-items:flex-start;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:20px}.card-header-left{flex:1}.card-header h2{align-items:center;color:var(--midnight-navy,#0f172a);display:flex;font-size:18px;font-weight:600;gap:8px;margin:0}.header-icon{color:var(--ocean-blue,#068297);height:20px;width:20px}.data-source-logo{flex-shrink:0;height:28px;opacity:.85;width:auto}.data-source-logo.noaa-logo{height:32px}.data-source-logo.forecast-maven-logo{height:26px}.data-source-logo.forecast-maven-logo-large{height:52px}.ai-summary-footer{align-items:center;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:12px;justify-content:flex-end;margin-top:12px;padding-top:12px}.ai-summary-footer .forecast-generated-time{margin:0}.current-conditions-card .data-source-logo{opacity:.9}.current-conditions-card{background:var(--ocean-blue,#068297);color:#fff;min-height:auto}.current-conditions-card .card-header{background:transparent;border-bottom-color:hsla(0,0%,100%,.2)}.current-conditions-card .card-header h2{color:#fff}.current-conditions-card .last-updated{color:hsla(0,0%,100%,.9);font-size:12px;margin-top:4px}.current-main{align-items:flex-start;display:flex;gap:32px;padding:24px}.current-left{flex:0 0 40%;gap:24px}.current-icon,.current-left{align-items:center;display:flex}.current-icon{flex-shrink:0;height:140px;justify-content:center;width:140px}.current-icon i{display:block;height:140px;width:140px}.current-icon svg{height:140px!important;width:140px!important}.current-temp-section{flex-shrink:0;text-align:center}.current-temp{color:#fff;font-size:64px;font-weight:300;line-height:1;margin-bottom:8px}.current-conditions{color:#fff;font-size:18px;margin-bottom:4px}.feels-like{color:hsla(0,0%,100%,.9);font-size:14px}.current-details-grid{display:grid;flex:0 0 60%;gap:20px 24px;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto}.current-details-grid .detail-item:nth-child(2),.current-details-grid .detail-item:nth-child(3),.current-details-grid .detail-item:nth-child(5),.current-details-grid .detail-item:nth-child(6){padding-left:30px}.current-details-grid .detail-item{min-width:0}.detail-item{align-items:flex-start;display:flex;gap:8px}.detail-icon{color:#fff;flex-shrink:0;height:20px!important;width:20px!important}.detail-content{flex:1}.detail-label{color:hsla(0,0%,100%,.8);font-size:14px;margin-bottom:2px}.detail-value{color:#fff;font-size:16px;font-weight:600}.ai-summary-24h-card{border:2px solid var(--ocean-blue,#068297);min-height:280px}.ai-summary-24h-card .card-header h2{color:var(--ocean-blue,#068297)}.timeframe{color:var(--text-secondary,#6b7280);font-size:12px;margin-top:4px}.summary-content{padding:20px}.summary-text{color:var(--midnight-navy,#0f172a);font-size:16px;line-height:1.6;margin:0}.summary-text.placeholder-text{align-items:center;color:var(--text-secondary,#6b7280);display:flex;font-style:italic;gap:8px}.action-recommendations{background:var(--sky-gray,#f0f4f8);border-radius:6px;margin:16px 20px 20px;padding:16px}.actions-header{align-items:center;color:var(--midnight-navy,#0f172a);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:12px}.actions-header i{color:var(--ocean-blue,#068297);height:16px!important;width:16px!important}.actions-list{list-style:none;margin:0;padding:0}.actions-list li{color:var(--text-primary,#1f2937);font-size:14px;margin-bottom:8px;padding-left:20px;position:relative}.actions-list li:last-child{margin-bottom:0}.actions-list li:before{color:var(--ocean-blue,#068297);content:"→";font-weight:700;left:0;position:absolute}.ai-summary-7day-card{background:#fef3c7;border:2px solid #f59e0b}.ai-summary-7day-card .card-header{border-bottom-color:#fde68a}.ai-summary-7day-card .card-header h2{color:#92400e}.ai-summary-7day-card .summary-text{color:var(--midnight-navy,#0f172a)}.key-timing{align-items:center;background:#fff;border-radius:6px;color:#dc2626;display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin:16px 20px;padding:8px 16px}.key-timing i{height:16px!important;width:16px!important}.summary-footer{padding:0 20px 20px}.updated-time{align-items:center;color:var(--text-secondary,#6b7280);display:flex;font-size:12px;gap:6px}.footer-icon{height:14px!important;width:14px!important}.hourly-chart-card{min-height:450px}.chart-summary{background:var(--sky-gray,#f0f4f8);border-bottom:1px solid var(--border-color,#e5e7eb);padding:16px 20px}.chart-summary .summary-text{color:var(--midnight-navy,#0f172a);font-size:14px;line-height:1.6;margin:0}.chart-summary .summary-text.placeholder-text{align-items:center;color:var(--text-secondary,#6b7280);display:flex;font-style:italic;gap:8px}.chart-summary .summary-text.placeholder-text i{height:16px!important;width:16px!important}.forecast-tabs{background:#fff;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;gap:4px;overflow-x:auto;padding:12px 20px 0}.forecast-tab{align-items:center;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.forecast-tab:hover{background:var(--sky-gray,#f0f4f8);color:var(--midnight-navy,#0f172a)}.forecast-tab.active{background:transparent;border-bottom-color:var(--ocean-blue,#068297);color:var(--ocean-blue,#068297)}.forecast-tab i{height:16px!important;width:16px!important}.forecast-tab span{font-family:var(--font-body)}.chart-wrapper{min-height:400px;padding:20px}#hourlyChart{height:400px!important;width:100%!important}.chart-footer{display:flex;justify-content:flex-end;padding:8px 20px 16px}.chart-footer .noaa-logo{height:28px;opacity:.75}.hourly-icons-row{overflow:hidden;padding:8px 20px 0}.hourly-icons-container{display:flex;justify-content:flex-start}.hourly-icon-wrapper{align-items:center;display:flex;flex-shrink:0;justify-content:center}.hourly-condition-icon{height:18px!important;transition:transform .2s ease;width:18px!important}@media (max-width:1024px){.hourly-icon-wrapper:nth-child(odd){visibility:hidden}.hourly-condition-icon{height:16px!important;width:16px!important}}@media (max-width:767px){.hourly-icon-wrapper{visibility:hidden}.hourly-icon-wrapper:nth-child(3n+1){visibility:visible}.hourly-condition-icon{height:14px!important;width:14px!important}.hourly-icons-row{padding:4px 16px 0}}@media (max-width:480px){.hourly-icon-wrapper{visibility:hidden}.hourly-icon-wrapper:nth-child(4n+1){visibility:visible}}.map-view{padding:48px;text-align:center}.map-placeholder{background:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:48px}.map-placeholder i{color:var(--text-muted,#9ca3af);height:64px!important;margin-bottom:16px;width:64px!important}.map-placeholder p{color:var(--text-secondary,#6b7280);font-size:16px}.ai-summary-7day-card.no-data,.current-conditions-card.no-data,.hourly-chart-card.no-data{border:1px solid var(--border-color,#e5e7eb)}.no-data-message{padding:48px 20px;text-align:center}.no-data-message i{color:var(--text-muted,#9ca3af);height:48px!important;margin-bottom:12px;width:48px!important}.no-data-message p{color:var(--text-secondary,#6b7280);font-size:14px;margin:0}@media (max-width:767px){body{min-width:320px}.forecast-page-grid{gap:12px;grid-template-columns:1fr;padding:0}.grid-full-width{grid-column:1}.location-header-info h1{font-size:24px}.tab-navigation{gap:12px}.tab-btn{font-size:14px;padding:6px 8px}.tab-btn i{height:16px!important;width:16px!important}.current-conditions-card{min-height:auto}.current-main{display:flex;flex-direction:column;gap:20px;padding:20px}.current-left{align-items:center;display:flex;gap:16px;justify-content:center;width:100%}.current-icon{flex-shrink:0}.current-icon,.current-icon i{height:80px;width:80px}.current-icon svg{height:80px!important;width:80px!important}.current-temp-section{display:flex;flex-direction:column;justify-content:center;text-align:left}.current-temp{font-size:48px;line-height:1}.current-conditions{font-size:16px;margin-top:4px}.current-details-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;width:100%}.current-details-grid .detail-item{align-items:center;display:flex;gap:8px}.current-details-grid .detail-item:nth-child(2),.current-details-grid .detail-item:nth-child(3),.current-details-grid .detail-item:nth-child(5),.current-details-grid .detail-item:nth-child(6){padding-left:0}.ai-summary-24h-card{min-height:auto}.hourly-chart-card{min-height:400px}.chart-wrapper{min-height:350px;padding:16px}#hourlyChart{height:350px!important}.forecast-tabs{gap:2px;padding:8px 16px 0}.forecast-tab{font-size:12px;padding:6px 12px}.forecast-tab span{display:none}.forecast-tab i{height:18px!important;width:18px!important}}.forecast-horizontal-table{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);overflow:hidden}.forecast-table-header{background:var(--sky-gray,#f0f4f8);border-bottom:2px solid var(--border-color,#e5e7eb);padding:20px}.forecast-table-header h3{align-items:center;color:var(--midnight-navy,#0f172a);display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 12px}.forecast-table-header .header-icon{color:var(--ocean-blue,#068297);height:20px;width:20px}.forecast-generated-time{color:var(--text-secondary,#6b7280);font-size:12px;font-weight:400;margin:4px 0 0}.forecast-header-content{display:flex;flex-direction:column;gap:12px}.ai-summary-text{background:transparent;margin:0;padding:0}.ai-summary-text p{color:var(--text-primary,#1f2937);font-size:14px;line-height:1.6;margin:0}.key-timing-inline{align-items:center;background:#fef3c7;border-left:3px solid #f59e0b;border-radius:4px;color:#92400e;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 12px}.key-timing-inline i{color:#f59e0b;height:16px;width:16px}.forecast-days-container{display:grid;gap:0;grid-template-columns:repeat(7,1fr);min-height:450px;padding:24px 16px}.forecast-day-column{align-items:center;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:16px;padding:16px 8px;position:relative;transition:all .2s ease}.forecast-day-column:hover{background:var(--sky-gray,#f0f4f8);transform:translateY(-2px)}.forecast-day-column.selected{background:var(--sky-gray,#f0f4f8);box-shadow:0 2px 8px rgba(0,0,0,.15)}.day-temp-container{align-items:center;display:flex;flex:1;flex-direction:column;gap:8px;min-height:280px;width:100%}.temp-high-label{color:var(--midnight-navy,#0f172a);font-size:18px;font-weight:600;text-align:center}.temp-bar-track{flex:1;position:relative;width:32px}.temp-bar-fill{border-radius:16px;box-shadow:0 2px 8px rgba(0,0,0,.3);left:0;position:absolute;right:0;transition:all .3s ease;width:32px}.temp-low-label{color:#1f2937;font-size:14px;font-weight:500;text-align:center}.day-icon-container{align-items:center;display:flex;height:48px;justify-content:center;width:48px}.weather-icon-large{color:var(--ocean-blue,#068297);height:48px!important;width:48px!important}.day-date-container{align-items:center;display:flex;gap:6px;justify-content:center}.day-date{color:#374151;font-size:14px;font-weight:600;text-align:center;white-space:nowrap}.alert-indicator{animation:pulse 2s ease-in-out infinite;color:var(--sunset-orange,#ffb020);height:16px!important;width:16px!important}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.forecast-details-row{animation:slideDown .3s ease-out;border-top:2px solid var(--border-color,#e5e7eb)}.details-content{padding:24px}.details-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.details-header h4{color:var(--midnight-navy,#0f172a);font-size:20px;font-weight:600;margin:0}.close-details{background:none;border:none;border-radius:4px;cursor:pointer;padding:8px;transition:background .2s}.close-details:hover{background:var(--sky-gray,#f0f4f8)}.close-details i{color:var(--text-secondary,#6b7280);height:24px!important;width:24px!important}.details-body{display:grid;gap:24px;grid-template-columns:1fr 1fr}.details-forecast,.details-threats{background:var(--sky-gray,#f0f4f8);border-radius:8px;padding:16px}.details-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.details-section-header h5{margin:0}.details-section-header .data-source-logo{height:24px}.details-forecast h5,.details-threats h5{color:var(--ocean-blue,#068297);font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.details-section-header+p{margin-top:0}.details-forecast p{color:var(--text-primary,#1f2937);font-size:14px;line-height:1.6;margin:0 0 12px}.details-forecast p:last-child{margin-bottom:0}.threat-description{color:var(--text-primary,#1f2937);font-size:14px;line-height:1.6;margin:0 0 12px}.night-forecast-header{margin-top:16px!important}.threat-list{display:flex;flex-direction:column;gap:12px}.threat-item{align-items:flex-start;border-radius:6px;display:flex;gap:12px;padding:12px}.threat-icon-small{color:#fff;flex-shrink:0;height:20px!important;width:20px!important}.threat-text{color:#fff;flex:1}.threat-type{color:#fff;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:4px}.threat-desc{color:#fff;font-size:14px;line-height:1.4;margin-bottom:6px}.threat-meta{color:#374151;font-size:12px;opacity:1}@media (max-width:1024px){.forecast-days-container{gap:8px;grid-template-columns:repeat(7,1fr);padding:16px 8px}.forecast-day-column{gap:12px;padding:12px 4px}.temp-high-label{font-size:16px}.temp-bar-fill,.temp-bar-track{width:24px}.day-icon-container{height:36px;width:36px}.weather-icon-large{height:36px!important;width:36px!important}.day-date{font-size:12px}.details-body{grid-template-columns:1fr}}@media (max-width:768px){.forecast-days-container{gap:4px;grid-template-columns:repeat(7,1fr);min-height:auto;padding:16px 4px}.forecast-day-column{gap:8px;padding:8px 2px}.day-temp-container{min-height:140px}.temp-high-label{font-size:13px}.temp-bar-fill,.temp-bar-track{width:18px}.temp-low-label{font-size:11px}.day-icon-container{height:28px;width:28px}.weather-icon-large{height:28px!important;width:28px!important}.day-date{font-size:10px;line-height:1.3}.details-content{padding:16px}.details-header h4{font-size:16px}}@media (max-width:480px){.forecast-days-container{gap:2px;grid-template-columns:repeat(7,1fr);padding:12px 2px}.forecast-day-column{gap:6px;padding:6px 1px}.day-temp-container{min-height:100px}.temp-high-label{font-size:11px}.temp-bar-fill,.temp-bar-track{width:14px}.temp-low-label{font-size:10px}.day-icon-container{height:24px;width:24px}.weather-icon-large{height:24px!important;width:24px!important}.day-date{font-size:9px;line-height:1.2}.alert-indicator{height:12px!important;width:12px!important}}.active-alerts-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-bottom:24px;padding:24px}.alert-card-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;gap:12px;margin-bottom:20px;padding-bottom:16px}.alert-card-header .alert-icon{color:#f80;height:28px;width:28px}.alert-card-header h3{color:#1a1a1a;font-size:20px;font-weight:600;margin:0}.alerts-compact-list{display:flex;flex-direction:column;gap:12px}.alert-compact-item{align-items:flex-start;background:#fafafa;border-left:4px solid #f80;border-radius:8px;cursor:pointer;display:flex;gap:16px;padding:16px;transition:all .2s ease}.alert-compact-item:hover{background:#f0f0f0;box-shadow:0 2px 8px rgba(0,0,0,.1);transform:translateX(4px)}.alert-compact-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.alert-compact-icon,.alert-compact-icon i{height:32px;width:32px}.alert-compact-content{flex:1;min-width:0}.alert-compact-event{color:#1a1a1a;font-size:16px;font-weight:600;margin-bottom:4px}.alert-compact-headline{color:#666;display:-webkit-box;font-size:14px;-webkit-line-clamp:2;line-height:1.5;-webkit-box-orient:vertical;overflow:hidden}.alert-compact-arrow{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;opacity:.5;transition:opacity .2s ease;width:24px}.alert-compact-item:hover .alert-compact-arrow{opacity:1}.no-alerts-message{padding:24px;text-align:center}.no-alerts-message p{color:#666;font-size:16px;margin:0}.alert-modal{align-items:center;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.alert-modal.active{display:flex}.alert-modal-backdrop{backdrop-filter:blur(4px);background:rgba(0,0,0,.5);bottom:0;left:0;position:absolute;right:0;top:0}.alert-modal-content{animation:modalSlideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:85vh;max-width:700px;overflow-y:auto;position:relative;width:90%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.alert-modal-header{align-items:flex-start;background:#fff;border-bottom:2px solid #f0f0f0;border-radius:16px 16px 0 0;display:flex;gap:20px;justify-content:space-between;padding:28px 32px 20px;position:sticky;top:0;z-index:1}.alert-modal-header h2{font-size:24px;font-weight:700;line-height:1.3;margin:0}.alert-modal-close{align-items:center;background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.alert-modal-close:hover{background:#e0e0e0}.alert-modal-close i{color:#666;height:20px;width:20px}.alert-modal-body{padding:24px 32px 32px}.alert-modal-meta{justify-content:space-between;margin-bottom:20px}.alert-modal-meta,.alert-modal-meta-left{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.alert-modal-meta .noaa-logo{height:36px}.alert-modal-severity{border-radius:6px;color:#fff;display:inline-block;font-size:13px;font-weight:600;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase}.alert-modal-time{color:#666;font-size:14px;font-weight:500}.alert-modal-section{margin-bottom:24px}.alert-modal-section:last-child{margin-bottom:0}.alert-modal-section h4{color:#1a1a1a;font-size:16px;font-weight:600;margin:0 0 12px}.alert-modal-headline{background:#fffbea;border-left:4px solid gold;border-radius:6px;color:#333;font-size:16px;font-weight:600;line-height:1.6;padding:16px}.alert-modal-text{color:#444;font-size:15px;line-height:1.7;white-space:pre-wrap}.alert-modal-instructions{background:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:6px;padding:16px}.alert-timing-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.timing-item{background:#fafafa;border-left:3px solid #ddd;border-radius:8px;padding:12px 16px}.timing-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.timing-value{color:#1a1a1a;font-size:14px;font-weight:500}.alert-modal-footer{border-top:1px solid #e0e0e0;color:#888;font-size:13px;margin-top:20px;padding-top:20px;text-align:center}@media (max-width:768px){.alert-modal-content{max-height:90vh;width:95%}.alert-modal-header{padding:20px 20px 16px}.alert-modal-header h2{font-size:20px}.alert-modal-body{padding:20px}.alert-modal-close{height:32px;width:32px}.alert-compact-item{gap:12px;padding:12px}.alert-compact-icon,.alert-compact-icon i{height:28px;width:28px}.alert-timing-grid{grid-template-columns:1fr}}.personal-view{margin:0 auto;max-width:900px;width:100%}.personal-forecast-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);margin-bottom:24px;padding:32px}.personal-forecast-card .card-header{align-items:center;border-bottom:2px solid var(--sky-gray,#f0f4f8);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.personal-forecast-card .card-header h2{align-items:center;color:var(--midnight-navy,#0f172a);display:flex;font-size:24px;font-weight:700;gap:12px;margin:0}.personal-forecast-card .header-icon{color:var(--ocean-blue,#068297);height:28px;width:28px}.forecast-type-badge{background:var(--sky-gray,#f0f4f8);border-radius:6px;color:var(--text-secondary,#6b7280);font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.profile-notice{align-items:start;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;color:#78350f;display:flex;font-size:14px;gap:12px;margin-bottom:24px;padding:12px 16px}.profile-notice i{flex-shrink:0;height:20px;margin-top:2px;width:20px}.profile-link{color:#0369a1;font-weight:500;text-decoration:underline}.profile-link:hover{color:#0284c7}.personal-forecast-alerts{background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;margin-bottom:24px;padding:16px}.personal-forecast-alerts .alerts-header{align-items:center;color:#991b1b;display:flex;font-weight:600;gap:8px;margin-bottom:12px}.personal-forecast-alerts .alerts-header i{height:20px;width:20px}.alerts-list{list-style:none;margin:0;padding:0}.alert-item{align-items:center;border-bottom:1px solid #fca5a5;display:flex;justify-content:space-between;padding:8px 0}.alert-item:last-child{border-bottom:none}.alert-event{color:#7f1d1d;font-weight:500}.alert-severity{border-radius:4px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.severity-extreme{background:#7f1d1d;color:#fff}.severity-severe{background:#dc2626;color:#fff}.severity-moderate{background:#f59e0b;color:#fff}.severity-minor{background:#fde68a;color:#78350f}.forecast-section{display:flex;gap:16px;margin-bottom:32px}.forecast-section:last-child{margin-bottom:0}.section-icon{align-items:center;background:var(--sky-gray,#f0f4f8);border-radius:8px;color:var(--ocean-blue,#068297);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.section-icon i{height:24px;width:24px}.section-content{flex:1}.section-title{font-size:16px;margin:0 0 12px}.headline-text,.section-title{color:var(--midnight-navy,#0f172a);font-weight:600}.headline-text{font-size:18px;line-height:1.6;margin:0}.forecast-text{color:var(--text-primary,#374151);font-size:15px;line-height:1.7}.forecast-text p{margin:0 0 16px}.forecast-text p:last-child{margin-bottom:0}.forecast-footer{align-items:center;border-top:1px solid var(--border-color,#e5e7eb);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:32px;padding-top:20px}.ai-info,.generated-info{align-items:center;color:var(--text-secondary,#6b7280);display:flex;font-size:13px;gap:8px}.ai-info i,.generated-info i{height:16px;width:16px}.personal-forecast-card.error-state,.personal-forecast-card.no-data{display:flex;flex-direction:column;min-height:400px}.empty-state{align-items:center;display:flex;flex:1;flex-direction:column;justify-content:center;padding:48px 24px;text-align:center}.empty-state i{color:var(--text-secondary,#6b7280);height:64px;margin-bottom:16px;width:64px}.empty-state h3{color:var(--midnight-navy,#0f172a);font-size:20px;font-weight:600;margin:0 0 12px}.empty-state p{color:var(--text-secondary,#6b7280);font-size:15px;line-height:1.6;margin:0 0 8px;max-width:500px}.setup-message{margin-top:16px!important}@media (max-width:768px){.personal-forecast-card{padding:20px}.personal-forecast-card .card-header h2{font-size:20px}.forecast-section{flex-direction:column;gap:12px}.section-icon{height:36px;width:36px}.headline-text{font-size:16px}.forecast-text{font-size:14px}.forecast-footer{align-items:flex-start;flex-direction:column;gap:12px}}.sentiment-capture{padding:0 24px 24px}.sentiment-divider{background:hsla(0,0%,100%,.2);height:1px;margin-bottom:16px}.sentiment-prompt{color:hsla(0,0%,100%,.9);font-size:14px;font-weight:500;margin-bottom:12px;text-align:center}.sentiment-emojis{display:flex;gap:24px;justify-content:center;margin-bottom:8px}.sentiment-emoji-btn{background:transparent;border:none;border-radius:50%;cursor:pointer;padding:8px;position:relative;transition:all .2s ease}.sentiment-emoji-btn:hover{background:hsla(0,0%,100%,.1);transform:scale(1.1)}.sentiment-emoji-btn:focus{outline:2px solid hsla(0,0%,100%,.5);outline-offset:2px}.sentiment-emoji-btn .emoji{display:block;font-size:32px;line-height:1}.sentiment-emoji-btn.selected{background:hsla(0,0%,100%,.2)}.sentiment-emoji-btn.selected:after{background:#fff;border-radius:2px;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:24px}.sentiment-expanded{animation:slideDown .2s ease-out;margin-top:16px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sentiment-impact-label{color:hsla(0,0%,100%,.8);font-size:13px;margin-bottom:10px;text-align:center}.sentiment-impacts{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.sentiment-impact-btn{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:20px;color:#fff;cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.sentiment-impact-btn:hover{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.5)}.sentiment-impact-btn:focus{outline:2px solid hsla(0,0%,100%,.5);outline-offset:2px}.sentiment-impact-btn.selected{background:#fff;border-color:#fff;color:var(--ocean-blue,#068297)}.sentiment-comment-section{animation:slideDown .2s ease-out;margin-top:16px}.sentiment-comment-label{color:hsla(0,0%,100%,.8);display:block;font-size:13px;margin-bottom:8px}.sentiment-comment-input{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.3);border-radius:8px;box-sizing:border-box;color:#fff;font-family:var(--font-body);font-size:14px;padding:10px 12px;resize:none;width:100%}.sentiment-comment-input::placeholder{color:hsla(0,0%,100%,.5)}.sentiment-comment-input:focus{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.6);outline:none}.sentiment-submit-section{display:flex;justify-content:flex-end;margin-top:16px}.sentiment-submit-btn{background:#fff;border:none;border-radius:6px;color:var(--ocean-blue,#068297);cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s ease}.sentiment-submit-btn:hover:not(:disabled){background:hsla(0,0%,100%,.9);transform:translateY(-1px)}.sentiment-submit-btn:focus{outline:2px solid hsla(0,0%,100%,.5);outline-offset:2px}.sentiment-submit-btn:disabled{cursor:not-allowed;opacity:.6}.sentiment-confirmation{align-items:center;animation:fadeIn .3s ease-out;color:#fff;display:flex;font-size:15px;font-weight:500;gap:8px;justify-content:center;padding:16px 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sentiment-check-icon{color:#4ade80;height:20px;width:20px}@media (max-width:767px){.sentiment-capture{padding:0 20px 20px}.sentiment-emojis{gap:20px}.sentiment-emoji-btn .emoji{font-size:28px}.sentiment-impacts{gap:8px}.sentiment-impact-btn{font-size:13px;padding:6px 14px}}