.weather-page{margin:calc(-1 * var(--spacing-lg))}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-md);color:var(--color-text-light)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.weather-content{display:none}.wx-error{text-align:center;padding:var(--spacing-xl);color:var(--color-text-light);font-style:italic}.weather-hero{position:relative;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);margin:var(--spacing-lg) var(--spacing-lg) 0;border-radius:var(--radius-lg);color:#fff;overflow:hidden;transition:background .8s ease;background:linear-gradient(135deg,#667eea,#764ba2)}.weather-hero[data-bg=clear]{background:linear-gradient(135deg,#2196f3,#64b5f6 40%,#bbdefb)}.weather-hero[data-bg=night]{background:linear-gradient(135deg,#0d1b2a,#1b2838,#1a237e)}.weather-hero[data-bg=partcloud]{background:linear-gradient(135deg,#5c6bc0,#78909c)}.weather-hero[data-bg=cloudy]{background:linear-gradient(135deg,#546e7a,#78909c,#90a4ae)}.weather-hero[data-bg=rainy]{background:linear-gradient(135deg,#1a237e,#283593,#37474f)}.weather-hero[data-bg=heavyrain]{background:linear-gradient(135deg,#0d1b2a,#1a237e,#263238)}.weather-hero[data-bg=foggy]{background:linear-gradient(135deg,#78909c,#b0bec5)}.weather-hero[data-bg=snowy]{background:linear-gradient(135deg,#546e7a,#cfd8dc)}.weather-hero[data-bg=stormy]{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.weather-effect{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.rain-drop{position:absolute;top:-30px;width:2px;background:linear-gradient(transparent,#ffffff80);border-radius:0 0 2px 2px;animation:rainFall linear infinite}@keyframes rainFall{0%{transform:translateY(-30px);opacity:0}10%{opacity:1}to{transform:translateY(400px);opacity:0}}.snow-flake{position:absolute;top:-10px;background:#fff;border-radius:50%;opacity:.8;animation:snowFall linear infinite}@keyframes snowFall{0%{transform:translateY(-10px) translate(0);opacity:0}10%{opacity:.8}to{transform:translateY(400px) translate(30px);opacity:0}}.hero-body{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.hero-location{font-size:.9rem;opacity:.85;margin-bottom:var(--spacing-xs);display:block}.hero-temp{font-family:var(--font-sans);font-size:5rem;font-weight:700;line-height:1;letter-spacing:-2px}.hero-condition{font-size:1.4rem;font-weight:500;margin-top:var(--spacing-xs)}.hero-feels{font-size:.9rem;opacity:.8;margin-top:var(--spacing-xs)}.hero-update{font-size:.75rem;opacity:.6;margin-top:var(--spacing-sm)}.hero-icon{font-size:6rem;line-height:1;display:block;filter:drop-shadow(0 4px 16px rgba(0,0,0,.25))}.hero-icon-pulse{animation:pulse 3s ease-in-out infinite}.hero-icon-float{animation:float 4s ease-in-out infinite}.hero-icon-shake{animation:shake 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px) translateY(2px)}75%{transform:translate(4px) translateY(-2px)}}.hero-metrics{position:relative;z-index:1;display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.metric-card{background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center;display:flex;flex-direction:column;gap:2px;border:1px solid rgba(255,255,255,.15)}.mc-icon{font-size:1.2rem}.mc-value{font-weight:600;font-size:.85rem}.mc-label{font-size:.7rem;opacity:.75;text-transform:uppercase;letter-spacing:.5px}.wx-section{padding:var(--spacing-xl) var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.wx-section:last-child{border-bottom:none}.wx-section-title{font-family:var(--font-sans);font-size:1.1rem;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text)}.wx-section-subtitle{font-size:.9rem;color:var(--color-text-light);margin-top:-.75rem;margin-bottom:var(--spacing-lg)}.hourly-icons{display:flex;justify-content:space-between;overflow-x:auto;gap:0;margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--spacing-sm)}.hi-cell{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px 0}.hi-cell.hi-now{background:#e74c3c14;border-radius:var(--radius-sm)}.hi-icon{font-size:1.1rem;line-height:1}.hi-lbl{font-size:.6rem;color:var(--color-text-light);font-weight:600}.hourly-chart-wrap{position:relative;height:220px;margin-bottom:var(--spacing-md)}.hourly-chart-wrap.hourly-chart-sm{height:150px}.forecast-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:4px 0}.forecast-table{min-width:0}.fc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;min-width:700px}.fc-card{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px #0000000d;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.fc-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.fc-today{border:2px solid #1565c0;box-shadow:0 3px 12px #1565c026}.fc-today .fc-head{background:linear-gradient(135deg,#1565c0,#1e88e5)}.fc-today .fc-day,.fc-today .fc-date,.fc-today .fc-max,.fc-today .fc-min{color:#fff!important}.fc-today .fc-max svg path{fill:#ffcdd2}.fc-today .fc-min svg path{fill:#bbdefb}.fc-head{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:12px 8px 10px;text-align:center;border-bottom:1px solid rgba(0,0,0,.05)}.fc-day{display:block;font-weight:800;font-size:.95rem;color:var(--color-text);line-height:1.2}.fc-date{display:block;font-size:.68rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.6px;margin-top:1px}.fc-maxmin{display:flex;justify-content:center;gap:10px;margin-top:6px}.fc-max,.fc-min{font-size:.82rem;font-weight:700;display:inline-flex;align-items:center;gap:3px}.fc-max{color:#e53935}.fc-min{color:#1e88e5}.fc-slots{padding:6px 0;flex:1}.fc-slot{display:flex;align-items:center;padding:8px 10px;gap:6px;border-bottom:1px solid rgba(0,0,0,.04)}.fc-slot:last-child{border-bottom:none}.fc-hour{font-size:.7rem;font-weight:600;color:var(--color-text-light);min-width:34px}.fc-wicon{font-size:1.6rem;line-height:1;flex-shrink:0}.fc-stemp{font-weight:700;font-size:.95rem;color:#1565c0;margin-left:auto}.fc-data{background:#f8f9fb;border-top:1px solid rgba(0,0,0,.05);padding:8px 10px 10px}.fc-row{display:flex;align-items:center;gap:5px;padding:3px 0}.fc-row+.fc-row{border-top:1px solid rgba(0,0,0,.04);padding-top:4px}.fc-rlbl{font-size:.85rem;flex-shrink:0}.fc-rlbl2{margin-left:auto}.fc-rval{font-size:.78rem;color:var(--color-text);font-weight:600}.fc-arrow{font-size:1rem;color:var(--color-text-light)}.fc-sun-row{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:4px;align-items:center}.fc-sun-row .fc-rval{font-size:.72rem}.station-card{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px #0000001f}.station-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.station-badge{background:var(--color-accent);color:#fff;font-weight:800;font-size:.65rem;padding:5px 10px;border-radius:var(--radius-sm);letter-spacing:1px;animation:livePulse 2s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.6}}.station-header h3{font-family:var(--font-sans);font-size:1.15rem;font-weight:700}.station-loc{font-size:.8rem;opacity:.6;margin-top:2px}.station-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.sg-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;gap:4px;transition:background .2s}.sg-card:hover{background:#ffffff1a}.sg-card.sg-loading{grid-column:1 / -1;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);opacity:.6}.loading-spinner-sm{width:24px;height:24px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.sg-top{display:flex;align-items:center;gap:var(--spacing-xs)}.sg-icon{font-size:1.1rem}.sg-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;opacity:.6;font-weight:600}.sg-value{font-size:1.6rem;font-weight:800;font-family:var(--font-sans);line-height:1.2}.sg-sub{font-size:.75rem;opacity:.5}.sg-fallback{grid-column:1 / -1;text-align:center;padding:var(--spacing-xl);opacity:.7;line-height:1.8}.station-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md)}.station-update{font-size:.75rem;opacity:.5}.station-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff!important;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:.85rem;transition:background .2s}.station-btn:hover{background:#ffffff2e;color:#fff!important}.rain-summary{background:linear-gradient(135deg,#e3f2fd,#e8f5e9);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);border:1px solid rgba(33,150,243,.15)}.rs-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--spacing-sm)}.rs-year{font-weight:800;font-size:1.3rem;color:var(--color-primary)}.rs-total{font-weight:600;font-size:1rem;color:var(--color-text)}.rs-bar-bg{height:10px;background:#00000014;border-radius:5px;overflow:hidden;margin-bottom:var(--spacing-sm)}.rs-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),#2196F3);border-radius:5px;transition:width 1s ease}.rs-footer{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-light)}.rs-diff{font-weight:600}.chart-tabs{display:flex;gap:4px;margin-bottom:var(--spacing-lg);background:var(--color-border-light);border-radius:var(--radius-md);padding:4px}.chart-tab{flex:1;padding:10px var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:.85rem;color:var(--color-text-light);transition:all .2s;white-space:nowrap}.chart-tab:hover{color:var(--color-text)}.chart-tab.active{background:#fff;color:var(--color-primary);box-shadow:var(--shadow-sm)}.chart-panel{display:none;height:380px;position:relative}.chart-panel.active{display:block}.chart-source{text-align:center;font-size:.7rem;color:var(--color-text-muted);margin-top:var(--spacing-md)}.wx-source{text-align:right;font-size:.68rem;color:var(--color-text-muted);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm)}.wx-source a{color:var(--color-primary-light);text-decoration:none}.wx-source a:hover{text-decoration:underline}.station-source{display:block;font-size:.7rem;color:#ffffff73;margin-top:var(--spacing-sm)}.station-source a{color:#fff9;text-decoration:none}.station-source a:hover{text-decoration:underline;color:#fffc}@media(max-width:768px){.weather-page{margin:calc(-1 * var(--spacing-md))}.weather-hero{padding:var(--spacing-lg);margin:var(--spacing-md) var(--spacing-md) 0}.hero-temp{font-size:3.5rem}.hero-icon{font-size:4rem}.hero-condition{font-size:1.1rem}.hourly-icons{overflow-x:auto}.hourly-chart-wrap{height:180px}.hourly-chart-wrap.hourly-chart-sm{height:120px}.hero-metrics{grid-template-columns:repeat(3,1fr)}.wx-section{padding:var(--spacing-lg)}.fc-grid{gap:6px;min-width:620px}.fc-wicon{font-size:1.3rem}.fc-stemp,.fc-day{font-size:.85rem}.fc-slot{padding:6px 8px}.fc-card{border-radius:10px}.chart-tabs{flex-direction:column}.chart-panel{height:280px}.station-card{padding:var(--spacing-lg)}.station-grid{grid-template-columns:repeat(2,1fr)}.sg-value{font-size:1.3rem}.rs-footer{flex-direction:column;gap:4px}}@media(max-width:480px){.hero-body{flex-direction:column;text-align:center}.hero-metrics{grid-template-columns:repeat(2,1fr)}.hero-temp{font-size:3rem}.hero-icon{font-size:3.5rem}.station-grid{grid-template-columns:1fr}.fc-grid{gap:4px;min-width:560px}.fc-wicon{font-size:1.1rem}.fc-stemp,.fc-day{font-size:.78rem}.fc-date{font-size:.58rem}.fc-max,.fc-min{font-size:.72rem}.fc-head{padding:8px 4px}.fc-slot{padding:4px 6px;gap:4px}.fc-hour{font-size:.6rem;min-width:28px}.fc-data{padding:6px}.fc-rval{font-size:.68rem}.fc-card{border-radius:8px}}
