:root{--w-blue:#1a73e8;--w-blue-dark:#1557b0;--w-blue-light:#e8f0fe;--w-orange:#f9a825;--w-gray:#5f6368;--w-gray-light:#f8f9fa;--w-radius:16px;--w-shadow:0 2px 12px rgba(0,0,0,.08);--w-shadow-hover:0 4px 20px rgba(0,0,0,.12);--w-transition:all .3s ease}.weather-hero{background:linear-gradient(135deg,#1a73e8 0%,#4fc3f7 50%,#81d4fa 100%);border-radius:var(--w-radius);padding:28px 32px;color:#fff;position:relative;overflow:hidden;margin-bottom:24px;box-shadow:0 4px 24px rgb(26 115 232 / .25)}.weather-hero::before{content:'';position:absolute;top:-40%;right:-10%;width:300px;height:300px;border-radius:50%;background:rgb(255 255 255 / .08);pointer-events:none}.weather-hero::after{content:'';position:absolute;bottom:-30%;left:-5%;width:200px;height:200px;border-radius:50%;background:rgb(255 255 255 / .05);pointer-events:none}.weather-hero.weather-night{background:linear-gradient(135deg,#1a237e 0%,#283593 50%,#3949ab 100%);box-shadow:0 4px 24px rgb(26 35 126 / .3)}.weather-hero.weather-rain{background:linear-gradient(135deg,#37474f 0%,#546e7a 50%,#78909c 100%);box-shadow:0 4px 24px rgb(55 71 79 / .3)}.weather-hero.weather-cloudy{background:linear-gradient(135deg,#455a64 0%,#607d8b 50%,#90a4ae 100%);box-shadow:0 4px 24px rgb(69 90 100 / .25)}.weather-hero-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;position:relative;z-index:1}.weather-hero-left{flex:1;min-width:200px}.weather-hero-location{font-size:15px;opacity:.9;margin-bottom:4px;display:flex;align-items:center;gap:6px}.weather-hero-location i{font-size:14px}.weather-hero-temp{font-size:72px;font-weight:700;line-height:1;margin:8px 0;letter-spacing:-2px}.weather-hero-temp sup{font-size:32px;font-weight:400;vertical-align:super;letter-spacing:0}.weather-hero-desc{font-size:18px;text-transform:capitalize;margin-bottom:4px}.weather-hero-feels{font-size:14px;opacity:.8}.weather-hero-right{text-align:center;min-width:100px}.weather-hero-icon img{width:100px;height:100px;filter:drop-shadow(0 4px 8px rgb(0 0 0 / .15))}.weather-hero-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid rgb(255 255 255 / .2);position:relative;z-index:1}.weather-detail-item{display:flex;align-items:center;gap:8px;font-size:14px}.weather-detail-item i{width:20px;text-align:center;opacity:.8}.weather-detail-item span{opacity:.9}.weather-detail-item strong{opacity:1}.weather-hero-updated{margin-top:16px;font-size:12px;opacity:.6;text-align:right;position:relative;z-index:1}.weather-section{margin-bottom:28px}.weather-section-title{font-size:20px;font-weight:700;color:#202124;margin-bottom:16px;display:flex;align-items:center;gap:8px}.weather-section-title i{color:var(--w-blue);font-size:18px}.weather-hourly-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#c4c4c4 #fff0;padding-bottom:8px}.weather-hourly-wrap::-webkit-scrollbar{height:6px}.weather-hourly-wrap::-webkit-scrollbar-track{background:#fff0}.weather-hourly-wrap::-webkit-scrollbar-thumb{background:#c4c4c4;border-radius:3px}.weather-hourly{display:flex;gap:8px;min-width:max-content}.weather-hourly-item{flex:0 0 auto;width:80px;text-align:center;padding:14px 8px;border-radius:12px;background:var(--w-gray-light);transition:var(--w-transition);border:1px solid #fff0}.weather-hourly-item:hover{background:var(--w-blue-light);border-color:var(--w-blue);transform:translateY(-2px);box-shadow:var(--w-shadow)}.weather-hourly-item.active{background:var(--w-blue);color:#fff;border-color:var(--w-blue)}.weather-hourly-time{font-size:13px;font-weight:600;color:var(--w-gray);margin-bottom:6px}.weather-hourly-item.active .weather-hourly-time{color:rgb(255 255 255 / .8)}.weather-hourly-icon img{width:36px;height:36px;margin:4px 0}.weather-hourly-temp{font-size:16px;font-weight:700;color:#202124}.weather-hourly-item.active .weather-hourly-temp{color:#fff}.weather-hourly-rain{font-size:11px;color:var(--w-blue);margin-top:4px}.weather-hourly-item.active .weather-hourly-rain{color:rgb(255 255 255 / .7)}@keyframes wdr-slideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.weather-daily-list{display:flex;flex-direction:column;gap:6px}.weather-daily-row{display:grid;grid-template-columns:90px 48px 1fr 200px 130px;align-items:center;gap:12px;padding:12px 16px;border-radius:14px;background:#fff;border:1px solid #e8eaed;transition:all .25s ease;animation:wdr-slideIn .4s ease both;cursor:default}.weather-daily-row:hover{border-color:var(--w-blue);box-shadow:0 4px 20px rgb(26 115 232 / .1);transform:translateX(4px);background:linear-gradient(90deg,var(--w-blue-light) 0%,#fff 40%)}.weather-daily-row.today{border-color:var(--w-blue);background:linear-gradient(90deg,var(--w-blue-light) 0%,#fff 50%);box-shadow:0 2px 12px rgb(26 115 232 / .12)}.weather-daily-row.today .wdr-day{color:var(--w-blue)}.wdr-left{min-width:0}.wdr-day{font-size:14px;font-weight:700;color:#202124;line-height:1.3}.wdr-date{font-size:12px;color:#9aa0a6;margin-top:1px}.wdr-icon{display:flex;align-items:center;justify-content:center}.wdr-icon img{width:48px;height:48px;transition:transform .3s ease}.weather-daily-row:hover .wdr-icon img{transform:scale(1.15)}.wdr-desc{font-size:13px;color:var(--w-gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px}.wdr-temp-section{display:flex;align-items:center;gap:8px;min-width:0}.wdr-low{font-size:14px;color:#9aa0a6;font-weight:500;width:32px;text-align:right;flex-shrink:0}.wdr-high{font-size:14px;color:#202124;font-weight:700;width:32px;flex-shrink:0}.wdr-temp-bar{flex:1;height:6px;border-radius:3px;background:#e8eaed;position:relative;min-width:60px;overflow:hidden}.wdr-temp-fill{position:absolute;top:0;height:100%;border-radius:3px;background:linear-gradient(90deg,#4fc3f7,#1a73e8,#f9a825,#ef5350);background-size:400% 100%;transition:width .6s ease}.wdr-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.wdr-meta-item{font-size:12px;color:var(--w-gray);display:flex;align-items:center;gap:3px;white-space:nowrap}.wdr-meta-item i{font-size:11px;color:#9aa0a6}.wdr-rain{color:var(--w-blue)}.wdr-rain i{color:var(--w-blue)}.weather-chart-wrap{background:#fff;border:1px solid #e8eaed;border-radius:var(--w-radius);padding:20px;box-shadow:var(--w-shadow)}.weather-chart-wrap canvas{max-height:260px}.weather-suggest{background:var(--w-gray-light);border-radius:var(--w-radius);padding:20px 24px;border:1px solid #e8eaed}.weather-suggest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.weather-suggest-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:#fff;border-radius:12px;border:1px solid #e8eaed;transition:var(--w-transition)}.weather-suggest-item:hover{box-shadow:var(--w-shadow);transform:translateY(-1px)}.weather-suggest-icon{font-size:24px;line-height:1;flex-shrink:0}.weather-suggest-text strong{display:block;font-size:13px;color:#202124;margin-bottom:2px}.weather-suggest-text span{font-size:13px;color:var(--w-gray);line-height:1.4}.weather-faq{margin-top:28px}.weather-faq-item{border:1px solid #e8eaed;border-radius:12px;margin-bottom:10px;overflow:hidden;transition:var(--w-transition)}.weather-faq-item:hover{border-color:var(--w-blue)}.weather-faq-q{padding:14px 20px;font-weight:600;font-size:15px;color:#202124;cursor:pointer;display:flex;align-items:center;justify-content:space-between;background:#fff;transition:var(--w-transition);user-select:none}.weather-faq-q:hover{background:var(--w-blue-light)}.weather-faq-q i{transition:transform .3s ease;color:var(--w-blue);font-size:14px}.weather-faq-item.open .weather-faq-q i{transform:rotate(180deg)}.weather-faq-a{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;font-size:14px;color:var(--w-gray);line-height:1.7}.weather-faq-item.open .weather-faq-a{padding:0 20px 16px;max-height:500px}.weather-uv{display:flex;align-items:center;gap:12px;margin-top:8px}.weather-uv-bar{flex:1;height:8px;border-radius:4px;background:linear-gradient(to right,#4caf50,#ffeb3b,#ff9800,#f44336,#9c27b0);position:relative}.weather-uv-marker{position:absolute;top:-4px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid #333;transform:translateX(-50%);box-shadow:0 1px 4px rgb(0 0 0 / .2)}.weather-uv-label{font-size:13px;font-weight:600;white-space:nowrap}.weather-alert{background:#fef3e2;border:1px solid #f9a825;border-left:4px solid #f9a825;border-radius:8px;padding:14px 18px;margin-bottom:20px;display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#5d4037}.weather-alert.weather-alert-danger{background:#fdecea;border-color:#ef5350;color:#b71c1c}.weather-alert i{font-size:18px;flex-shrink:0;margin-top:1px}@media (max-width:991px){.weather-daily-row{grid-template-columns:80px 44px 1fr 160px 100px;gap:8px;padding:10px 12px}.wdr-icon img{width:44px;height:44px}}@media (max-width:767px){.weather-hero{padding:20px 16px;border-radius:12px}.weather-hero-temp{font-size:56px}.weather-hero-temp sup{font-size:24px}.weather-hero-icon img{width:72px;height:72px}.weather-hero-details{grid-template-columns:repeat(2,1fr);gap:8px}.weather-daily-row{grid-template-columns:70px 40px 1fr auto;gap:8px;padding:10px;border-radius:10px}.wdr-desc{display:none}.wdr-meta{display:none}.wdr-icon img{width:40px;height:40px}.wdr-temp-section{min-width:130px}.weather-suggest-grid{grid-template-columns:1fr}}@media (max-width:480px){.weather-hero-top{flex-direction:column;text-align:center}.weather-hero-right{order:-1}.weather-hero-location{justify-content:center}.weather-hero-details{grid-template-columns:1fr 1fr}.weather-daily-row{grid-template-columns:60px 36px 1fr auto;gap:6px;padding:8px}.wdr-day{font-size:13px}.wdr-date{font-size:11px}.wdr-icon img{width:36px;height:36px}.wdr-temp-section{min-width:110px}.wdr-low,.wdr-high{font-size:13px;width:28px}}