*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Noto Sans SC,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#fff;-webkit-font-smoothing:antialiased}html,body,#root{min-height:100%}body{overflow-x:hidden}button,input{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:#ffffffd9}.app{position:relative;min-height:100vh;width:100%;max-width:1200px;margin:0 auto}.weather-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;transition:background .8s ease}.theme-clear{background:linear-gradient(165deg,#1e88e5,#42a5f5 45%,#90caf9)}.theme-cloudy{background:linear-gradient(165deg,#546e7a,#78909c,#b0bec5)}.theme-fog{background:linear-gradient(165deg,#607d8b,#90a4ae 60%,#cfd8dc)}.theme-rain{background:linear-gradient(165deg,#283593,#3949ab 45%,#5c6bc0)}.theme-snow{background:linear-gradient(165deg,#455a64,#78909c,#eceff1)}.theme-storm{background:linear-gradient(165deg,#1a237e,#303f9f 40%,#512da8)}.bg-sun{position:absolute;top:8%;right:12%;width:88px;height:88px;border-radius:50%;background:radial-gradient(circle,#fff9c4 0%,rgba(255,235,59,.4) 50%,transparent 70%);opacity:.9;animation:pulse 4s ease-in-out infinite}.theme-rain .bg-sun,.theme-storm .bg-sun,.theme-snow .bg-sun,.theme-fog .bg-sun,.theme-cloudy .bg-sun{opacity:.25}.bg-cloud{position:absolute;background:#ffffff59;border-radius:50px;filter:blur(2px)}.bg-cloud:before,.bg-cloud:after{content:"";position:absolute;background:inherit;border-radius:50%}.bg-cloud-1{width:120px;height:40px;top:18%;left:-20px;animation:drift 28s linear infinite}.bg-cloud-1:before{width:50px;height:50px;top:-22px;left:18px}.bg-cloud-1:after{width:60px;height:60px;top:-28px;right:20px}.bg-cloud-2{width:90px;height:32px;top:28%;right:-10px;opacity:.7;animation:drift 22s linear infinite reverse}.bg-cloud-2:before{width:40px;height:40px;top:-18px;left:12px}.bg-rain{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;background-image:repeating-linear-gradient(180deg,transparent,transparent 8px,rgba(255,255,255,.08) 8px,rgba(255,255,255,.08) 16px);pointer-events:none}.theme-rain .bg-rain,.theme-storm .bg-rain{opacity:1;animation:rain-fall .6s linear infinite}.app-content{position:relative;z-index:1;padding:16px 16px 32px;min-height:100vh;display:flex;flex-direction:column}.search-bar{margin-bottom:8px}.app-brand{margin-bottom:14px}.app-title{font-size:1.5rem;font-weight:700;letter-spacing:.02em}.app-tagline{margin-top:6px;font-size:.75rem;line-height:1.5;opacity:.88;font-weight:400}.search-row{display:flex;gap:8px;align-items:center}.search-input-wrap{flex:1;display:flex;align-items:center;gap:8px;background:#ffffff38;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:24px;padding:0 14px;border:1px solid rgba(255,255,255,.25)}.search-input{flex:1;background:transparent;border:none;outline:none;padding:12px 0;color:#fff}.search-input::placeholder{color:#ffffffa6}.search-icon{font-size:14px;opacity:.8}.search-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.icon-btn{width:44px;height:44px;border-radius:50%;background:#ffffff38;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.icon-btn:active{transform:scale(.94);background:#ffffff59}.suggestions{list-style:none;margin-top:8px;background:#fffffff2;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #00000026}.suggestion-item{width:100%;text-align:left;padding:12px 16px;color:#263238;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid #eceff1}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#e3f2fd}.suggestion-name{font-weight:600;font-size:15px}.suggestion-meta{font-size:12px;color:#78909c}.current-weather{padding:12px 4px 20px;text-align:center}.city-name{font-size:22px;font-weight:700;letter-spacing:.02em}.city-region{font-weight:500;opacity:.85;font-size:18px}.update-time{font-size:12px;opacity:.75;margin-top:4px}.temp-block{display:flex;align-items:center;justify-content:center;gap:8px;margin:16px 0 20px}.weather-emoji{font-size:72px;line-height:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.temperature{font-size:80px;font-weight:300;line-height:1;letter-spacing:-2px}.condition{font-size:18px;font-weight:500;opacity:.95}.metrics-row{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}.metric{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:72px}.metric-label{font-size:12px;opacity:.75}.metric-value{font-size:15px;font-weight:600}.main-panel{display:flex;flex-direction:column;gap:12px;flex:1}.card{background:#ffffff2e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;padding:16px;border:1px solid rgba(255,255,255,.22)}.card-title{font-size:14px;font-weight:600;opacity:.9;margin-bottom:12px}.chart-container{width:100%;position:relative}.hourly-icons{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;margin-top:8px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;-webkit-overflow-scrolling:touch}.hourly-icons::-webkit-scrollbar{height:4px}.hourly-icons::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.hourly-icon-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;cursor:pointer;border-radius:8px;transition:background .15s ease}.hourly-icon-item:hover{background:#ffffff1a}.icon-emoji{font-size:18px;line-height:1}.icon-temp{font-size:11px;font-weight:600;opacity:.85}.daily-details{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:8px;padding:8px 0}.daily-detail-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;cursor:pointer;border-radius:10px;transition:background .15s ease}.daily-detail-item:hover{background:#ffffff1a}.detail-icon{font-size:24px;line-height:1;margin-bottom:4px}.detail-temp{display:flex;flex-direction:column;align-items:center;gap:2px}.temp-max{font-size:13px;font-weight:600}.temp-min{font-size:12px;font-weight:500;opacity:.7}.detail-label{font-size:10px;opacity:.75;white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis;text-align:center}.aqi-main{display:flex;align-items:baseline;gap:12px;margin-bottom:12px}.aqi-value{font-size:42px;font-weight:700;line-height:1}.aqi-label{font-size:16px;font-weight:600;padding:4px 12px;border-radius:20px;background:#ffffff40}.aqi-details{display:flex;gap:32px}.aqi-detail-label{display:block;font-size:12px;opacity:.75}.aqi-detail-value{font-size:18px;font-weight:600}.state-message{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px 0;opacity:.9}.state-message.error p{text-align:center}.loader{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.retry-btn{padding:10px 24px;border-radius:20px;background:#ffffff40;border:1px solid rgba(255,255,255,.35);font-weight:600}.app-footer{margin-top:20px;text-align:center;font-size:11px;opacity:.65}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.05);opacity:1}}@keyframes drift{0%{transform:translate(-30px)}to{transform:translate(calc(100vw + 60px))}}@keyframes rain-fall{0%{background-position:0 0}to{background-position:0 16px}}@media(min-width:600px){.app-content{padding:24px 28px 40px}.app-title{font-size:1.75rem}.current-weather{padding:16px 8px 24px}.city-name{font-size:26px}.temperature{font-size:96px}.weather-emoji{font-size:88px}.metrics-row{gap:32px}.card{padding:20px;border-radius:24px}.card-title{font-size:15px;margin-bottom:16px}}@media(min-width:768px){.main-panel{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.current-weather{grid-column:1 / -1;padding:20px 16px 28px}.aqi-card,.hourly-card,.daily-card{grid-column:1 / -1}.forecast-container{overflow-x:visible}}@media(min-width:1024px){.app-content{padding:32px 40px 48px}.search-row{max-width:560px}.temp-block{gap:16px;margin:20px 0 28px}.main-panel{gap:20px}.hourly-card,.daily-card{grid-column:1 / -1}}@media(min-width:1200px){.app{box-shadow:0 0 80px #0000002e}}.app-header{margin-bottom:16px}.compare-controls{display:flex;gap:12px;align-items:center;margin-top:12px;flex-wrap:wrap}.city-search-wrapper{position:relative;flex:1;min-width:200px;max-width:320px}.city-search{position:relative;display:flex;align-items:center}.city-search input{width:100%;padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.25);background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:13px;outline:none;transition:border-color .2s ease,background .2s ease}.city-search input:focus{border-color:#ffffff80;background:#ffffff26}.city-search input::placeholder{opacity:.6}.city-search input:disabled{opacity:.5;cursor:not-allowed}.search-spinner{position:absolute;right:12px;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(255,255,255,.15);overflow:hidden;z-index:100;box-shadow:0 8px 32px #0000004d}.search-result-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;text-align:left;transition:background .15s ease}.search-result-item:hover{background:#ffffff1a}.result-name{font-weight:600;font-size:13px}.result-region{font-size:12px;opacity:.6}.compare-toggle{padding:10px 18px;border-radius:12px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);font-weight:600;font-size:13px;transition:all .2s ease}.compare-toggle:hover:not(:disabled){background:#ffffff40}.compare-toggle.active{background:#4caf504d;border-color:#4caf5080}.compare-toggle:disabled{opacity:.4;cursor:not-allowed}.clear-all-btn{padding:10px 18px;border-radius:12px;background:#f4433633;border:1px solid rgba(244,67,54,.3);font-weight:500;font-size:13px;transition:all .2s ease}.clear-all-btn:hover{background:#f443364d}.compare-view{display:grid;gap:16px;width:100%;height:calc(100vh - 200px);max-height:calc(100vh - 200px)}.compare-view.compare-1{grid-template-columns:1fr}.compare-view.compare-2{grid-template-columns:1fr 1fr}.compare-view.compare-3{grid-template-columns:1fr 1fr 1fr}.compare-view.compare-4{grid-template-columns:1fr 1fr 1fr 1fr}.compare-empty{padding:60px 20px;text-align:center;opacity:.6;font-size:15px}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cardSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}.card-enter{animation:cardSlideIn .4s ease forwards}.card-exit{animation:cardSlideOut .3s ease forwards}.compare-card{background:#ffffff14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;border:1px solid rgba(255,255,255,.1);overflow:hidden;display:flex;flex-direction:column;min-width:0;height:100%;max-height:100%}.compare-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;gap:8px}.compare-city-name{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px;flex:1}.drag-handle{cursor:grab;font-size:18px;opacity:.5;-webkit-user-select:none;user-select:none;transition:opacity .2s ease;flex-shrink:0;padding:4px;border-radius:4px}.drag-handle:hover{opacity:.9;background:#ffffff1a}.drag-handle:active{cursor:grabbing}.compare-city-region{font-size:12px;font-weight:400;opacity:.6}.remove-city-btn{width:28px;height:28px;border-radius:50%;background:#ffffff1a;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.remove-city-btn:hover{background:#f443364d}.compare-content{padding:12px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.compare-content::-webkit-scrollbar{width:6px}.compare-content::-webkit-scrollbar-track{background:transparent}.compare-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.compare-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.compare-content .card{background:#ffffff0d;border-color:#ffffff14;margin-bottom:10px;padding:12px}.compare-content .card:last-child{margin-bottom:0}.compare-content .current-weather{padding:8px 4px 12px}.compare-content .temp-block{margin:10px 0 12px}.compare-content .weather-emoji{font-size:48px}.compare-content .temperature{font-size:56px}.compare-content .metrics-row{gap:16px}.compare-content .aqi-card{padding:10px 12px}.compare-content .aqi-main{margin-bottom:8px}.compare-content .aqi-value{font-size:32px}.compare-content .aqi-label{font-size:14px;padding:3px 10px}.compare-content .aqi-detail-value{font-size:16px}.compare-content .card-title{font-size:13px;margin-bottom:8px}.compare-content .chart-container{height:120px}.compare-content .hourly-icons{grid-template-columns:repeat(24,1fr);gap:1px}.compare-content .icon-emoji{font-size:14px}.compare-content .icon-temp{font-size:10px}.compare-content .daily-details{grid-template-columns:repeat(7,1fr);gap:4px}.compare-content .detail-icon{font-size:18px}.compare-content .temp-max{font-size:12px}.compare-content .temp-min{font-size:11px}.compare-content .detail-label{font-size:9px}.compare-loading,.compare-error{padding:32px;text-align:center;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.compare-loading .loader{margin:0 auto 12px}@media(min-width:768px){.compare-controls{flex-wrap:nowrap}.city-search-wrapper{max-width:280px}}@media(min-width:1024px){.compare-view.compare-3{height:calc(100vh - 180px);max-height:calc(100vh - 180px)}}@media(min-width:1200px){.compare-view.compare-4{height:calc(100vh - 180px);max-height:calc(100vh - 180px)}.compare-view.compare-4 .compare-content .chart-container{height:100px}.compare-view.compare-4 .compare-content .weather-emoji{font-size:40px}.compare-view.compare-4 .compare-content .temperature{font-size:48px}}@media(max-width:767px){.compare-view{height:calc(100vh - 180px);max-height:calc(100vh - 180px)}.compare-view.compare-3,.compare-view.compare-4{grid-template-columns:1fr;height:auto;max-height:none}.compare-view.compare-3 .compare-card,.compare-view.compare-4 .compare-card{height:auto;max-height:70vh}}
