body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.app,body{align-items:center;display:flex;justify-content:center;min-height:100vh}.app{padding:min(5vw,20px);width:100%}.weather-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff26;border:1px solid #fff3;border-radius:clamp(16px,4vw,24px);box-shadow:0 8px 32px #0000001a;color:#fff;max-width:min(90vw,420px);padding:clamp(20px,5vw,32px);position:relative;width:100%}.header{gap:12px;justify-content:space-between;margin-bottom:clamp(20px,5vw,32px)}.header,.location-info{align-items:center;display:flex}.location-info{flex:1 1;gap:clamp(8px,2vw,12px);min-width:0}.thermometer-icon{flex-shrink:0;font-size:clamp(16px,4vw,18px);opacity:.9}.location-details{display:flex;flex:1 1;flex-direction:column;min-width:0}.location-text{font-size:clamp(15px,4vw,17px);font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-status{font-size:clamp(11px,3vw,13px);font-weight:400;opacity:.7}.add-location-btn{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:clamp(12px,3vw,16px);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:clamp(14px,4vw,16px);justify-content:center;min-height:48px;min-width:48px;padding:clamp(10px,2vw,14px);position:relative;transition:all .3s ease}.add-location-btn:hover{background:#ffffff40;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.add-location-btn:active{transform:translateY(0)}.search-icon{font-size:clamp(16px,4vw,18px)}.current-weather{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:clamp(24px,6vw,32px)}.temperature{font-size:clamp(48px,15vw,72px);font-weight:300;line-height:.9;margin:0}.condition-section{flex-shrink:0;text-align:center}.weather-icon-large{font-size:clamp(32px,10vw,48px);margin-bottom:clamp(4px,2vw,8px)}.condition-text{font-size:clamp(14px,4vw,16px);font-weight:500;opacity:.9}.weather-details{background:#ffffff14;border-radius:clamp(16px,4vw,20px);display:flex;gap:12px;justify-content:space-around;margin-bottom:clamp(24px,6vw,32px);padding:clamp(16px,4vw,20px)}.detail-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:clamp(6px,2vw,10px);padding:clamp(8px,2vw,12px);text-align:center}.detail-icon{font-size:clamp(18px,5vw,22px);margin-bottom:4px}.detail-info{align-items:center;display:flex;flex-direction:column;gap:2px}.detail-label{font-size:clamp(11px,3vw,13px);font-weight:500;letter-spacing:.5px;opacity:.8;text-transform:uppercase}.detail-value{color:#fffffff2;font-size:clamp(15px,4vw,17px);font-weight:600}.weekly-forecast{margin-bottom:clamp(24px,6vw,32px)}.week-days{grid-gap:clamp(2px,1vw,4px);background:#ffffff0d;border-radius:clamp(16px,4vw,20px);display:grid;gap:clamp(2px,1vw,4px);grid-template-columns:repeat(7,1fr);padding:clamp(12px,3vw,16px)}.day-item{align-items:center;border-radius:clamp(12px,3vw,16px);cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:80px;padding:clamp(12px,3vw,16px) clamp(4px,2vw,8px);transition:all .3s ease}.day-item.active{background:#fff3}.day-item:hover{background:#ffffff1a;transform:translateY(-2px)}.day-name{font-size:clamp(10px,3vw,12px);font-weight:500;opacity:.8}.day-icon,.day-name{margin-bottom:clamp(4px,2vw,8px)}.day-icon{font-size:clamp(16px,5vw,20px)}.day-temp{font-size:clamp(12px,3.5vw,14px);font-weight:600}.hourly-forecast{margin-bottom:clamp(24px,6vw,32px)}.section-title{font-size:clamp(14px,4vw,16px);font-weight:500;margin-bottom:clamp(12px,4vw,16px);opacity:.8}.hourly-items{grid-gap:clamp(6px,2vw,8px);display:grid;gap:clamp(6px,2vw,8px);grid-template-columns:repeat(auto-fit,minmax(70px,1fr))}.hourly-item{align-items:center;background:#ffffff1a;border-radius:clamp(12px,3vw,16px);cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:80px;padding:clamp(12px,4vw,16px) clamp(8px,3vw,12px);transition:all .3s ease}.hourly-item.active{background:#fff3}.hourly-item:hover{background:#ffffff26;transform:translateY(-2px)}.hour-time{font-size:clamp(10px,3vw,12px);font-weight:500;opacity:.8}.hour-icon,.hour-time{margin-bottom:clamp(4px,2vw,8px)}.hour-icon{font-size:clamp(14px,4.5vw,18px)}.hour-temp{font-size:clamp(12px,3.5vw,14px);font-weight:600}.chart-section{margin-bottom:clamp(12px,4vw,16px)}.chart-container{height:clamp(100px,25vw,120px);margin-top:clamp(12px,4vw,16px);position:relative}.loading{align-items:center;color:#fff;display:flex;flex-direction:column;gap:clamp(16px,4vw,20px);justify-content:center;padding:clamp(40px,8vw,60px) clamp(20px,5vw,30px);text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:clamp(40px,10vw,50px);margin-bottom:8px;width:clamp(40px,10vw,50px)}.loading-text{display:flex;flex-direction:column;gap:8px}.loading-text h3{font-size:clamp(18px,5vw,22px);font-weight:600;margin:0}.loading-text p{font-size:clamp(14px,4vw,16px);margin:0;opacity:.8}.loading-text small{font-size:clamp(12px,3vw,14px);margin-top:8px;opacity:.7}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error{align-items:center;color:#fff;display:flex;flex-direction:column;gap:clamp(16px,4vw,20px);justify-content:center;padding:clamp(40px,8vw,60px) clamp(20px,5vw,30px);text-align:center}.error-icon{font-size:clamp(40px,10vw,50px)}.error h3{font-size:clamp(18px,5vw,22px);font-weight:600;margin:0}.error p{font-size:clamp(14px,4vw,16px);margin:0;opacity:.8}.error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.error button{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:clamp(10px,3vw,12px);color:#fff;cursor:pointer;display:flex;font-size:clamp(14px,4vw,16px);font-weight:500;gap:6px;min-height:44px;padding:clamp(10px,3vw,12px) clamp(16px,4vw,20px);transition:all .3s ease}.error button:hover{background:#ffffff40;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}@media (max-width:480px){.app{padding:12px}.weather-card{border-radius:20px;padding:20px}.current-weather{flex-direction:column;gap:20px;text-align:center}.temperature{font-size:64px}.weather-icon-large{font-size:40px}.week-days{gap:1px}.day-item{min-height:70px;padding:10px 4px}.hourly-items{gap:4px;grid-template-columns:repeat(4,1fr)}.hourly-item{min-height:70px;padding:10px 6px}.chart-container{height:100px}}@media (min-width:481px) and (max-width:576px){.weather-card{max-width:95vw}.hourly-items{grid-template-columns:repeat(4,1fr)}}@media (min-width:577px) and (max-width:768px){.weather-card{max-width:85vw;padding:28px}.temperature{font-size:68px}.weather-icon-large{font-size:44px}}@media (min-width:769px) and (max-width:992px){.weather-card{max-width:70vw;padding:30px}.temperature{font-size:70px}.weather-icon-large{font-size:46px}.week-days{gap:6px}.hourly-items{gap:10px}}@media (min-width:993px) and (max-width:1200px){.weather-card{max-width:450px}}@media (min-width:1201px){.weather-card{max-width:480px;padding:36px}.temperature{font-size:76px}.weather-icon-large{font-size:52px}}@media (orientation:landscape) and (max-height:600px){.app{padding:8px}.weather-card{margin:8px 0;padding:16px}.current-weather,.hourly-forecast,.weekly-forecast{margin-bottom:16px}.chart-container{height:80px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.weather-card{border-width:.5px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none}}@media (prefers-color-scheme:dark){.weather-card{background:#0000004d;border-color:#ffffff1a}}@media (prefers-contrast:high){.weather-card{border-color:#fff9;border-width:2px}.add-location-btn{border-width:2px}}.add-location-btn:focus,.day-item:focus,.detail-item:focus,.hourly-item:focus{background:#ffffff1a;outline:3px solid #ffffffe6;outline-offset:2px}@media (pointer:coarse){.add-location-btn,.day-item,.detail-item,.hourly-item{min-height:44px;min-width:44px}}.weather-card{color:#fffffff2}.condition-text,.detail-value,.location-text,.temperature{color:#fffffffa;text-shadow:0 1px 2px #0003}.section-title{color:#fffffff2;text-shadow:0 1px 2px #0000001a}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.day-item,.detail-item,.hourly-item{cursor:pointer;transition:all .3s ease}.day-item:focus,.hourly-item:focus{transform:translateY(-2px)}.current-weather .temperature{text-shadow:0 2px 4px #0000004d}.weather-icon-large{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.day-item.active,.hourly-item.active{background:#ffffff40;border:1px solid #ffffff4d}.day-item:hover,.detail-item:hover,.hourly-item:hover{background:#ffffff26}.search-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:clamp(12px,4vw,20px);position:fixed;right:0;top:0;z-index:1000}.search-modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff26;border:1px solid #fff3;border-radius:clamp(16px,4vw,24px);box-shadow:0 8px 32px #0000001a;color:#fff;display:flex;flex-direction:column;max-height:min(85vh,600px);max-width:min(95vw,440px);overflow:hidden;width:100%}.search-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;flex-shrink:0;justify-content:space-between;padding:clamp(16px,5vw,24px) clamp(16px,5vw,24px) clamp(12px,3vw,16px)}.search-header h3{font-size:clamp(16px,5vw,20px);font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:clamp(4px,2vw,6px);color:#fff;cursor:pointer;display:flex;font-size:clamp(20px,6vw,24px);justify-content:center;min-height:44px;min-width:44px;padding:clamp(4px,2vw,8px);transition:all .3s ease}.close-btn:hover{background:#ffffff1a}.close-btn:focus{outline:2px solid #fffc;outline-offset:2px}.search-input-container{flex-shrink:0;padding:clamp(12px,4vw,16px) clamp(16px,5vw,24px);position:relative}.search-input{background:#ffffff1a;border:1px solid #fff3;border-radius:clamp(12px,3vw,16px);color:#fff;font-size:clamp(14px,4vw,16px);min-height:44px;outline:none;padding:clamp(10px,3vw,12px) clamp(56px,15vw,60px) clamp(10px,3vw,12px) clamp(12px,4vw,16px);transition:all .3s ease;width:100%}.search-input::placeholder{color:#fff9}.search-input:focus{background:#ffffff26;border-color:#ffffff4d}.search-icon{align-items:center;background-color:#ffffff26;border:1px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:clamp(18px,5vw,20px);height:44px;justify-content:center;margin-right:45px;opacity:1;position:absolute;right:-20px;top:50%;transform:translateY(-50%);transition:background-color .3s ease;width:44px}.search-icon:hover{background-color:#ffffff40}.search-content{flex:1 1;overflow-y:auto;padding-bottom:clamp(12px,4vw,16px)}.section{margin-bottom:clamp(16px,5vw,24px)}.section h4{font-size:clamp(12px,3.5vw,14px);font-weight:600;letter-spacing:.5px;margin:0 0 clamp(8px,3vw,12px);opacity:.8;padding:0 clamp(16px,5vw,24px);text-transform:uppercase}.current-location-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:clamp(12px,3vw,16px);color:#fff;cursor:pointer;display:flex;font-size:clamp(14px,4vw,16px);gap:clamp(8px,3vw,12px);justify-content:center;margin:0 clamp(16px,5vw,24px);min-height:48px;padding:clamp(12px,4vw,16px);transition:all .3s ease;width:calc(100% - clamp(32px, 10vw, 48px))}.current-location-btn:hover{background:#ffffff26;transform:translateY(-1px)}.current-location-btn:focus{outline:2px solid #fffc;outline-offset:2px}.location-icon{font-size:clamp(16px,4.5vw,18px)}.city-list{padding:0 clamp(16px,5vw,24px)}.city-item{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;min-height:48px;padding:clamp(10px,3vw,12px) 0;transition:all .3s ease}.city-item:last-child{border-bottom:none}.city-item:hover{background:#ffffff0d;border-radius:clamp(8px,2vw,12px);margin:0 clamp(-12px,-4vw,-16px);padding:clamp(10px,3vw,12px) clamp(12px,4vw,16px)}.city-info{cursor:pointer;display:flex;flex:1 1;flex-direction:column;min-width:0;padding:clamp(4px,2vw,8px) 0}.city-name{font-size:clamp(14px,4vw,16px);font-weight:500;margin-bottom:2px}.city-country,.city-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.city-country{font-size:clamp(12px,3.5vw,14px);opacity:.7}.favorite-btn{align-items:center;background:none;border:none;border-radius:clamp(4px,2vw,6px);cursor:pointer;display:flex;flex-shrink:0;font-size:clamp(16px,4.5vw,18px);justify-content:center;min-height:44px;min-width:44px;padding:clamp(6px,2vw,8px);transition:all .3s ease}.favorite-btn:hover{background:#ffffff1a;transform:scale(1.1)}.favorite-btn:focus{outline:2px solid #fffc;outline-offset:2px}.favorite-btn.favorited{animation:heartBeat .3s ease}@keyframes heartBeat{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.loading-results,.no-results{font-size:clamp(14px,4vw,16px);opacity:.7;padding:clamp(16px,5vw,20px);text-align:center}.search-content::-webkit-scrollbar{width:clamp(4px,1.5vw,6px)}.search-content::-webkit-scrollbar-track{background:#0000}.search-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.search-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width:480px){.search-overlay{padding:8px}.search-modal{border-radius:16px;max-height:90vh;max-width:100%}.search-header{padding:16px 16px 12px}.search-input-container{padding:12px 16px}.section h4{padding:0 16px}.current-location-btn{margin:0 16px;width:calc(100% - 32px)}.city-list{padding:0 16px}.city-item:hover{margin:0 -12px;padding:10px 12px}.search-icon{right:-30px}}@media (min-width:481px) and (max-width:576px){.search-modal{max-width:95vw}}@media (min-width:577px) and (max-width:768px){.search-modal{max-width:90vw}.search-header{padding:20px 20px 14px}.search-input-container{padding:14px 20px}.section h4{padding:0 20px}.current-location-btn{margin:0 20px;width:calc(100% - 40px)}.city-list{padding:0 20px}}@media (min-width:769px) and (max-width:992px){.search-modal{max-width:80vw}}@media (min-width:993px){.search-modal{max-width:460px}}@media (orientation:landscape) and (max-height:600px){.search-overlay{padding:4px}.search-modal{max-height:95vh}.search-header{padding:12px 16px 8px}.search-input-container{padding:8px 16px}.section{margin-bottom:16px}.city-item,.current-location-btn{min-height:40px}}@media (pointer:coarse){.close-btn,.current-location-btn,.favorite-btn{min-height:44px;min-width:44px}.city-item,.search-input{min-height:48px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.search-input,.search-modal{border-width:.5px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.favorite-btn.favorited{animation:none}}@media (prefers-color-scheme:dark){.search-modal{background:#0000004d;border-color:#ffffff1a}.current-location-btn,.search-input{background:#0003}}@media (prefers-contrast:high){.search-modal{border-color:#fff9;border-width:2px}.current-location-btn,.search-input{border-width:2px}}@supports (padding:max(0px)){.search-overlay{padding:max(clamp(12px,4vw,20px),env(safe-area-inset-top)) max(clamp(12px,4vw,20px),env(safe-area-inset-right)) max(clamp(12px,4vw,20px),env(safe-area-inset-bottom)) max(clamp(12px,4vw,20px),env(safe-area-inset-left))}}.close-btn:focus,.current-location-btn:focus,.favorite-btn:focus,.search-input:focus{outline:2px solid #fffc;outline-offset:2px}.city-info:focus{border-radius:4px;outline:2px solid #fffc;outline-offset:1px}.add-location-btn,.add-location-btn:hover{background:none;border:none}.add-location-btn:hover{box-shadow:none}.add-location-btn:active{outline:none}
/*# sourceMappingURL=main.a5557e45.css.map*/