@charset "UTF-8";:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--bg-primary: rgba(30, 30, 30, .9);--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(20, 20, 20, .5);--bg-header: rgba(100, 97, 97, .65);--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-muted: #b0b0b0;--text-dark: #2c3e50;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .25);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(255, 255, 255, .2);--overlay-dark: rgba(0, 0, 0, .25);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95}:root{font-size:16px}@media(max-width:1024px){:root{font-size:15px}}@media(max-width:768px){:root{font-size:14px}}@media(max-width:480px){:root{font-size:13px}}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;overflow:hidden}body{margin:0;padding:0;width:100%;height:100%;min-height:100vh;min-height:100dvh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;position:fixed;inset:0}#app{width:100%;height:100%;overflow:hidden;position:relative}.weather-map-container{width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;position:relative;overflow:hidden}#map{flex:1;z-index:1;min-height:0}#map svg path{outline:none!important}#map svg path:focus,#map svg path:active{outline:none!important}#map .leaflet-interactive{outline:none!important}#map .leaflet-interactive:focus,#map .leaflet-interactive:active{outline:none!important}@media(max-width:768px){#map .leaflet-control-zoom{display:none!important}}.floating-header{position:absolute;top:20px;left:10rem;right:10rem;background:#646161a6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #0006;z-index:1000;transition:.4s cubic-bezier(.4,0,.2,1)}.floating-header:hover{background:#7c7c7ce6;box-shadow:0 12px 40px #47474780}@media(max-width:900px){.floating-header{left:2rem;right:2rem}}@media(max-width:768px){.floating-header{top:10px;left:10px;right:10px;border-radius:12px}}@media(max-width:768px){.floating-header.menu-open .header-controls{max-height:400px!important;opacity:1!important;margin-top:.875rem;padding-top:.875rem;border-top:1px solid rgba(255,255,255,.2)}}.floating-header.menu-open .hamburger-btn span:nth-child(1){top:18px;transform:rotate(45deg)}.floating-header.menu-open .hamburger-btn span:nth-child(2){opacity:0}.floating-header.menu-open .hamburger-btn span:nth-child(3){top:18px;transform:rotate(-45deg)}.header-wrapper{padding:.875rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;color:#fff;flex-wrap:nowrap}@media(max-width:1100px){.header-wrapper{gap:1.25rem}}@media(max-width:900px){.header-wrapper{gap:.875rem;padding:.75rem 1rem}}@media(max-width:768px){.header-wrapper{padding:.75rem 1rem;gap:0;flex-wrap:wrap}}.header-left{display:flex;align-items:center;gap:.875rem;flex-shrink:0}@media(max-width:1100px){.header-left{gap:.5rem}}@media(max-width:768px){.header-left{justify-content:space-between;width:100%}}.weather-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}@media(max-width:768px){.weather-icon{width:32px;height:32px}}.header-title h1{margin:0;font-size:1.15rem;font-weight:700;letter-spacing:-.3px;line-height:1.2;color:#fff}@media(max-width:1100px){.header-title h1{font-size:1rem}}@media(max-width:768px){.header-title h1{font-size:1rem}}@media(max-width:768px){.header-title{text-align:right;flex:1}}.subtitle{font-size:.85rem;opacity:.7;font-weight:500;color:#e0e0e0}@media(max-width:768px){.subtitle{font-size:.8rem}}.city-search{position:relative;display:flex;align-items:center}.city-search .search-toggle-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:.25rem;border-radius:8px;transition:all .3s ease}.city-search .search-toggle-btn:hover{background-color:#ffffff40;border-color:#fff6;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.city-search .search-toggle-btn:active{transform:translateY(0)}.city-search .search-toggle-btn svg{width:20px;height:20px}.city-search .main-search-dropdown{position:absolute;top:100%;right:0;background:#646161a6;border-radius:12px;box-shadow:0 4px 20px #0006;min-width:300px;z-index:1002;margin-top:.5rem}.city-search .main-search-dropdown .main-search-input{width:100%;padding:.875rem;border:none;border-radius:12px;background:#ffffff1a;color:#fff;font-size:.8rem}.city-search .main-search-dropdown .main-search-input::placeholder{color:#e0e0e0}.city-search .main-search-dropdown .main-search-input:focus{outline:none;background:#fff3}.city-search .main-search-dropdown .main-search-results{max-height:200px;overflow-y:auto}.city-search .main-search-dropdown .main-search-results .main-search-result-item{padding:.5rem .875rem;cursor:pointer;color:#fff;transition:all .3s ease;border-radius:8px;margin:2px}.city-search .main-search-dropdown .main-search-results .main-search-result-item:hover{background:#fff3;transform:translate(4px);box-shadow:0 2px 8px #0000001a}.city-search .main-search-dropdown .main-search-results .main-search-result-item:active{transform:translate(2px)}.city-search .main-search-dropdown .main-search-results .main-search-result-item:not(:last-child){border-bottom:1px solid rgba(255,255,255,.2)}.header-controls{display:flex;align-items:center;gap:1.25rem;flex-shrink:1;min-width:0}@media(max-width:1100px){.header-controls{gap:.875rem}}@media(max-width:900px){.header-controls{gap:.5rem}}@media(max-width:768px){.header-controls{width:100%;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease,margin .3s ease,padding .3s ease;flex-direction:column;align-items:stretch;gap:.875rem;padding:0;margin:0;border-top:1px solid transparent}}.control-item{display:flex;flex-direction:column;gap:.4rem;padding-left:1.25rem;border-left:2px solid rgba(255,255,255,.2);align-self:stretch;justify-content:center;min-width:0}.control-item:first-child{padding-left:1.25rem}@media(max-width:1100px){.control-item,.control-item:first-child{padding-left:.875rem}}@media(max-width:900px){.control-item,.control-item:first-child{padding-left:.5rem}}@media(max-width:768px){.control-item{width:100%;border-left:none;padding-left:0;padding-bottom:.875rem;border-bottom:1px solid rgba(255,255,255,.2)}.control-item:last-child{border-bottom:none;padding-bottom:0}}.control-item label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;color:#f0f0f0}@media(max-width:768px){.control-item label{font-size:.9rem}}.control-item label svg{flex-shrink:0;opacity:.9}.radius-control input[type=range]{width:140px;height:6px;border-radius:3px;background:#fff3;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}@media(max-width:1100px){.radius-control input[type=range]{width:120px}}@media(max-width:900px){.radius-control input[type=range]{width:100px}}@media(max-width:768px){.radius-control input[type=range]{width:100%}}.radius-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 6px #0006;transition:.2s ease}.radius-control input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 6px 20px #667eea99}.radius-control input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border:none;box-shadow:0 2px 6px #0006;transition:.2s ease}.radius-control input[type=range]::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:0 6px 20px #667eea99}.datetime-control{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;justify-content:space-between}@media(max-width:1100px){.datetime-control{gap:.35rem}}@media(max-width:900px){.datetime-control{gap:.25rem}}.datetime-control .datetime-toggle{user-select:none;-webkit-user-select:none;-moz-user-select:none}.datetime-control .datetime-toggle input[type=checkbox]{cursor:pointer;width:1rem;height:1rem;accent-color:#667eea}.datetime-control .date-btn{padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:.2s ease}.datetime-control .date-btn:hover{background:#fff3;border-color:#fff3;transform:translateY(-1px)}.datetime-control .date-btn:focus{outline:none;border-color:#667eea;background:#fff3;box-shadow:0 0 0 3px #667eea4d}.datetime-control .date-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;padding:.625rem 1.25rem;border-radius:12px;border:none;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap;box-shadow:0 4px 12px #667eea33}.datetime-control .date-btn svg{flex-shrink:0}.datetime-control .date-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea59}.datetime-control .date-btn:active{transform:translateY(0)}@media(max-width:1100px){.datetime-control .date-btn{padding:.5rem 1rem;font-size:.85rem}}@media(max-width:900px){.datetime-control .date-btn{padding:.45rem .875rem;font-size:.8rem;gap:.35rem}}@media(max-width:768px){.datetime-control .date-btn{padding:.5rem 1rem;font-size:.85rem}}@media(max-width:480px){.datetime-control .date-btn{padding:.45rem .875rem;font-size:.75rem}}.datetime-control .date-nav-btn{background:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;flex-shrink:0;color:#fff;background:#ffffff26;backdrop-filter:blur(10px)}.datetime-control .date-nav-btn:hover:not(:disabled){background:#ffffff40;border-color:#ffffff80;transform:scale(1.05)}.datetime-control .date-nav-btn:active:not(:disabled){transform:scale(.95)}.datetime-control .date-nav-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.datetime-control .date-nav-btn{width:2rem;height:2rem}.datetime-control .date-nav-btn svg{width:18px;height:18px}}@media(max-width:480px){.datetime-control .date-nav-btn{width:2rem;height:2rem}.datetime-control .date-nav-btn svg{width:16px;height:16px}}.datetime-control .datetime-inputs{display:flex;gap:.5rem;align-items:center}@media(max-width:768px){.datetime-control .datetime-inputs{flex-direction:row;gap:.5rem}}.datetime-control .datetime-inputs .input-wrapper{display:flex;align-items:center}@media(max-width:768px){.datetime-control .datetime-inputs .input-wrapper{flex:1}}.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:.2s ease}.datetime-control .datetime-inputs input[type=date]:hover,.datetime-control .datetime-inputs input[type=time]:hover{background:#fff3;border-color:#fff3;transform:translateY(-1px)}.datetime-control .datetime-inputs input[type=date]:focus,.datetime-control .datetime-inputs input[type=time]:focus{outline:none;border-color:#667eea;background:#fff3;box-shadow:0 0 0 3px #667eea4d}.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{width:115px;text-align:center}@media(max-width:768px){.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{width:100%;font-size:.85rem;padding:.45rem .5rem}}.datetime-control .datetime-inputs input[type=date]::-webkit-calendar-picker-indicator,.datetime-control .datetime-inputs input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;filter:brightness(0) invert(1);opacity:.8;transition:opacity .2s;padding:2px}.datetime-control .datetime-inputs input[type=date]::-webkit-calendar-picker-indicator:hover,.datetime-control .datetime-inputs input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}.day-carousel-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:10000;animation:fadeIn .2s ease}.day-carousel-container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:90%;width:600px;overflow:hidden;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.carousel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e8e8e8}.carousel-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#2c3e50}.carousel-header .close-btn{background:none;border:none;cursor:pointer;color:#666;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.carousel-header .close-btn:hover{background:#f5f5f5;color:#2c3e50}.carousel-wrapper{position:relative;padding:2rem 0;display:flex;align-items:center;gap:.5rem}.carousel-nav{background:#fff;border:2px solid #e8e8e8;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin:0 .5rem}.carousel-nav:hover:not(:disabled){background:#667eea;border-color:#667eea;color:#fff;transform:scale(1.1)}.carousel-nav:disabled{opacity:.3;cursor:not-allowed}.carousel-track{display:flex;gap:1rem;overflow-x:auto;scroll-behavior:smooth;padding:0 1rem;flex:1;scrollbar-width:none;-ms-overflow-style:none}.carousel-track::-webkit-scrollbar{display:none}.day-item{flex-shrink:0;background:#f8f9fa;border:2px solid transparent;border-radius:16px;padding:1rem;min-width:100px;cursor:pointer;transition:all .3s;text-align:center}.day-item .day-label{font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.5rem}.day-item .day-date{font-size:2rem;font-weight:700;color:#2c3e50;line-height:1;margin-bottom:.25rem}.day-item .day-month{font-size:.875rem;color:#666;text-transform:capitalize}.day-item:hover{background:#e8eaf6;border-color:#667eea;transform:translateY(-2px)}.day-item.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px #667eea4d}.day-item.selected .day-label,.day-item.selected .day-date,.day-item.selected .day-month{color:#fff}.time-selector{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8}.time-selector label{font-weight:600;color:#2c3e50}.time-selector input[type=time]{padding:.75rem 1rem;border:2px solid #e8e8e8;border-radius:12px;font-size:1rem;font-weight:600;color:#2c3e50;transition:all .2s;text-align:center;min-width:120px}.time-selector input[type=time]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.carousel-footer{display:flex;gap:1rem;padding:1.5rem;justify-content:flex-end}.carousel-footer button{padding:.75rem 2rem;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.carousel-footer button.btn-secondary{background:#f5f5f5;color:#666}.carousel-footer button.btn-secondary:hover{background:#e8e8e8}.carousel-footer button.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.carousel-footer button.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}@media(max-width:768px){.day-carousel-overlay{padding-top:20px;align-items:flex-start}.day-carousel-container{max-width:95%;margin:0 auto}.carousel-header{padding:1rem}.carousel-header h3{font-size:1.1rem}.carousel-wrapper{padding:1.5rem 0}.carousel-nav{width:36px;height:36px;margin:0 .25rem}.day-item{min-width:80px;padding:.75rem}.day-item .day-date{font-size:1.75rem}.time-selector{flex-direction:column;gap:.75rem;padding:1rem}.time-selector input[type=time]{width:100%;max-width:200px}.carousel-footer{padding:1rem;flex-direction:column-reverse}.carousel-footer button{width:100%}}@media(max-width:480px){.day-item{min-width:70px;padding:.625rem}.day-item .day-label{font-size:.75rem}.day-item .day-date{font-size:1.5rem}.day-item .day-month{font-size:.75rem}}.hamburger-btn{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:transparent;border:none;margin:0;padding:8px;width:40px;height:40px;position:relative;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;transition:all .3s ease}@media(max-width:768px){.hamburger-btn{display:flex}}.hamburger-btn:hover{background:#ffffff40;border-color:#fff6;transform:scale(1.05)}.hamburger-btn:active{transform:scale(.98)}.hamburger-btn span{display:block;width:24px;height:3px;background:#fff;border-radius:3px;transition:.4s cubic-bezier(.4,0,.2,1);position:absolute}.hamburger-btn span:nth-child(1){top:10px}.hamburger-btn span:nth-child(2){top:18px}.hamburger-btn span:nth-child(3){top:26px}.bottom-container{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-end;padding:1.5rem;pointer-events:none;z-index:999;gap:.875rem}@media(max-width:768px){.bottom-container{padding:.5rem;flex-direction:column;align-items:stretch;gap:.5rem}}.bottom-container>*{pointer-events:auto}.bottom-container .legend-footer,.bottom-container .stats-group{height:60px}@media(max-width:768px){.bottom-container .legend-footer,.bottom-container .stats-group{height:auto}}@media(max-width:768px){.bottom-container .legend-footer{order:2}}@media(max-width:768px){.bottom-container .stats-group{order:1}}.stats-group{display:flex;align-items:stretch;gap:0;height:60px}@media(max-width:768px){.stats-group{flex-direction:row;height:auto;gap:.25rem;width:100%}}.legend-footer{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);padding:.5rem .875rem;border-radius:16px;box-shadow:0 4px 20px #0006;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center}@media(max-width:768px){.legend-footer{padding:.25rem .5rem;width:100%;border-radius:12px;height:auto!important}}.legend-title{font-size:.85rem;font-weight:700;color:#e0e0e0;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}@media(max-width:768px){.legend-title{font-size:.8rem}}.legend-scale{display:flex;gap:.875rem;align-items:center}@media(max-width:768px){.legend-scale{gap:.25rem;flex-wrap:nowrap;overflow-x:auto;width:100%;justify-content:space-between;scrollbar-width:none;-ms-overflow-style:none}.legend-scale::-webkit-scrollbar{display:none}}@media(max-width:480px){.legend-scale{gap:.375rem}}.legend-item{display:flex;align-items:center;gap:.4rem;flex-shrink:0}@media(max-width:768px){.legend-item{gap:.25rem;flex-direction:column;align-items:center;text-align:center}}.legend-item span{font-size:.72rem;font-weight:600;color:#2c3e50;white-space:nowrap}@media(max-width:768px){.legend-item span{font-size:.6rem;line-height:1.2;max-width:4rem;white-space:normal}}@media(max-width:480px){.legend-item span{font-size:.55rem;max-width:3.5rem}}.legend-color{width:18px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.2);box-shadow:0 1px 3px #0000004d}@media(max-width:768px){.legend-color{width:20px;height:20px;border-radius:8px}}@media(max-width:480px){.legend-color{width:18px;height:18px}}.info-toggle-btn{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);border-left:none;padding:0 .875rem;border-radius:0 16px 16px 0;display:flex;align-items:center;cursor:pointer;transition:.3s ease;box-shadow:0 4px 20px #0006;font-weight:600;color:#2c3e50;backdrop-filter:blur(20px);min-width:180px;height:100%}@media(max-width:768px){.info-toggle-btn{padding:.25rem .5rem;border-radius:12px;border-left:1px solid rgba(255,255,255,.3);height:auto!important;min-width:auto;flex:1;justify-content:center}}.info-toggle-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.info-toggle-btn:active{transform:translateY(0) scale(.98)}.btn-content{display:flex;align-items:center;gap:.5rem;width:100%}.toggle-icon{flex-shrink:0;width:24px;height:24px;color:#667eea}.toggle-text{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem}@media(max-width:768px){.toggle-text{max-width:none;font-size:.7rem;overflow:visible;text-overflow:clip;white-space:normal;text-align:center;line-height:1.2}}.info-panel{position:absolute;bottom:90px;right:20px;min-width:21.5rem;max-height:calc(100vh - 120px);background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #00000080;overflow-y:auto;overflow-x:hidden;z-index:1001;transform:translate(calc(100% + 40px));opacity:0;pointer-events:none;transition:.4s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.3)}.info-panel.is-open{transform:translate(0);opacity:1;pointer-events:auto}@media(max-width:768px){.info-panel{position:fixed;inset:auto 0 0;width:100%;max-width:100%;max-height:70vh;border-radius:0;transform:translateY(100%)}.info-panel.is-open{transform:translateY(0)}}.panel-header{color:#fff;padding:1rem 1.25rem;position:sticky;top:0;z-index:10;background:linear-gradient(135deg,#667eea,#764ba2)}@media(max-width:768px){.panel-header{padding:.875rem .5rem}}.header-top{display:flex;align-items:center;justify-content:space-between;gap:.875rem;margin-bottom:.875rem}@media(max-width:768px){.header-top{gap:.25rem;margin-bottom:.25rem}}.header-top h2{margin:0;font-size:1.15rem;font-weight:700;flex:1}@media(max-width:768px){.header-top h2{font-size:1rem}}.header-top .city-name-clickable{margin:0;font-size:1.15rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-decoration:underline solid rgba(255,255,255,.5);text-decoration-thickness:2px;text-underline-offset:4px;padding:6px 10px;border-radius:12px;position:relative;background:#ffffff1a;width:fit-content}@media(max-width:768px){.header-top .city-name-clickable{font-size:1rem;padding:4px 8px}.header-top .city-name-clickable:after{font-size:.9rem;margin-left:6px}}.header-top .city-name-clickable:hover{text-decoration-color:#ffffffe6;background:#fff3;transform:translate(2px)}.header-top .city-name-clickable:hover:after{opacity:1;transform:translate(0)}.header-top .city-name-clickable:active{transform:translate(0) scale(.98);background:#ffffff40}.time-navigation{display:flex;justify-content:center;align-items:center;gap:.25rem;padding:.5rem 0;border-top:1px solid rgba(255,255,255,.2)}@media(max-width:768px){.time-navigation{padding:.25rem 0}}.nav-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:32px;height:32px;border-radius:12px;display:flex;justify-content:center;align-items:center;background:#ffffff26;color:#fff;transition:.2s ease;border:1px solid rgba(255,255,255,.3);flex-shrink:0}@media(max-width:768px){.nav-btn{width:28px;height:28px}}.nav-btn:hover:not(:disabled){background:#ffffff40;transform:scale(1.08)}.nav-btn:active:not(:disabled){transform:scale(.95)}.nav-btn:disabled{opacity:.25;cursor:not-allowed}.nav-btn svg{width:16px;height:16px}@media(max-width:768px){.nav-btn svg{width:14px;height:14px}}.nav-btn.nav-btn-day{width:38px;height:38px;background:linear-gradient(135deg,#ffffff40,#ffffff26);border:1.5px solid rgba(255,255,255,.5);border-radius:16px}@media(max-width:768px){.nav-btn.nav-btn-day{width:34px;height:34px}}.nav-btn.nav-btn-day svg{width:18px;height:18px}@media(max-width:768px){.nav-btn.nav-btn-day svg{width:16px;height:16px}}.nav-btn.nav-btn-day:hover:not(:disabled){background:linear-gradient(135deg,#ffffff59,#ffffff40);border-color:#ffffffb3;box-shadow:0 2px 8px #0000001a}.datetime-display{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:#ffffff40;border-radius:16px;color:#fff;border:1px solid rgba(255,255,255,.4);transition:.2s ease;flex:1;min-width:0}@media(max-width:768px){.datetime-display{padding:.25rem .5rem;gap:.25rem;margin:0 .5rem}}.datetime-display:hover{background:#ffffff59;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.datetime-display:active{transform:translateY(0)}.datetime-display svg{width:16px;height:16px;flex-shrink:0;opacity:.9}@media(max-width:768px){.datetime-display svg{width:14px;height:14px}}.datetime-display .datetime-text{font-size:.9rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}@media(max-width:768px){.datetime-display .datetime-text{font-size:.85rem}}.forecast-timeline{display:flex;gap:.5rem;padding:1.25rem;background:linear-gradient(to bottom,#f8fafce6,#f1f5f980);border-bottom:1px solid rgba(226,232,240,.5);overflow-x:auto}@media(max-width:768px){.forecast-timeline{gap:.25rem;padding:.5rem}}.forecast-card{flex:1;min-width:100px;padding:.875rem;background:#ffffffe6;border-radius:16px;border:2px solid rgba(226,232,240,.5);cursor:pointer;transition:.2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}@media(max-width:768px){.forecast-card{min-width:80px;padding:.5rem}}.forecast-card.is-current{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.forecast-card:not(.is-current):hover{background:#fff;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 16px #667eea80}.forecast-card:active{transform:translateY(0)}.forecast-card.is-loading{cursor:wait;opacity:.7}.forecast-time{font-size:.9rem;font-weight:700;color:#2c3e50;display:flex;flex-direction:column;align-items:center;gap:.15rem}@media(max-width:768px){.forecast-time{font-size:.8rem}}.forecast-date-label{font-size:.7rem;font-weight:600;color:#667eea;opacity:.8}@media(max-width:768px){.forecast-date-label{font-size:.6rem}}.forecast-content{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%}.forecast-temp{font-size:1.15rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.forecast-temp{font-size:1rem}}.forecast-rain{display:flex;justify-content:center;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:#667eea}@media(max-width:768px){.forecast-rain{font-size:.7rem}}.forecast-rain svg{width:14px;height:14px}@media(max-width:768px){.forecast-rain svg{width:12px;height:12px}}.forecast-loading{display:flex;justify-content:center;align-items:center;padding:.875rem 0}.spinner-small{width:20px;height:20px;border:2px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.header-right{display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.header-right{gap:.25rem}}.close-panel-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:32px;height:32px;border-radius:50%;display:flex;justify-content:center;align-items:center;color:#fff;transition:.2s ease;flex-shrink:0}.close-panel-btn:hover{background:#fff3;transform:scale(1.1)}.close-panel-btn:active{transform:scale(.95)}.close-panel-btn svg{width:20px;height:20px}.intensity-badge{display:inline-block;padding:.3rem .875rem;border-radius:12px;font-size:.8rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap;background:#00000040!important;backdrop-filter:brightness(.8)}@media(max-width:768px){.intensity-badge{font-size:.65rem;padding:.2rem .25rem}}.weather-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.25rem;background:#f8fafc80}@media(max-width:768px){.weather-grid{gap:.25rem;padding:.5rem}}.weather-item{display:flex;flex-direction:column;gap:.25rem}@media(max-width:768px){.weather-item{gap:.15rem}}.weather-label{font-size:.8rem;color:#2c3e50;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.7}@media(max-width:768px){.weather-label{font-size:.68rem}}.weather-value{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.weather-value{font-size:1.2rem}}.update-time{padding:.875rem 1.25rem;font-size:.8rem;color:#2c3e50;text-align:center;background:#f1f5f9cc;border-top:1px solid rgba(226,232,240,.8);font-weight:500;opacity:.8}@media(max-width:768px){.update-time{padding:.5rem;font-size:.75rem}}@media(max-width:768px){.header-top .city-name-clickable{padding:8px 12px;min-height:44px;display:flex;align-items:center;text-decoration:underline solid rgba(255,255,255,.5);text-decoration-thickness:2px;text-underline-offset:5px}.header-top .city-name-clickable:after{display:none}.header-top .city-name-clickable:active{background:#fff3;transform:scale(.97)}}@media(max-width:768px)and (hover:hover){.header-top .city-name-clickable:hover{background:#ffffff1f;text-decoration-color:#fff}}.stats-panel{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);padding:.5rem .875rem;border-radius:16px 0 0 16px;box-shadow:none;display:flex;gap:.875rem;align-items:center;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-right:none;height:100%}@media(max-width:768px){.stats-panel{padding:.25rem .5rem;gap:.5rem;border-radius:12px;border-right:1px solid rgba(255,255,255,.3);box-shadow:0 4px 20px #0006;height:auto!important;flex:1;justify-content:space-around}}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.15rem}.stat-label{font-size:.75rem;color:#2c3e50;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.stat-label{font-size:.6rem}}.stat-value{font-size:1.2rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.stat-value{font-size:.95rem}}.stat-divider{width:1px;height:30px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2),transparent)}@media(max-width:768px){.stat-divider{height:20px}}.loading-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1002;opacity:0;animation:fadeInDelayed .3s ease .2s forwards}.loading-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1003;display:flex;flex-direction:column;align-items:center;gap:1.25rem;opacity:0;animation:slideUpDelayed .4s cubic-bezier(.34,1.56,.64,1) .2s forwards}.loading-indicator .spinner-container{position:relative;width:4rem;height:4rem}.loading-indicator .spinner{width:100%;height:100%;border:.4rem solid rgba(255,255,255,.1);border-top:.4rem solid transparent;border-right:.4rem solid #667eea;border-radius:50%;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite;position:relative}@media(max-width:768px){.loading-indicator .spinner{border-width:.35rem}}.loading-indicator .spinner:before{content:"";position:absolute;inset:.2rem;border:.2rem solid transparent;border-bottom:.2rem solid rgba(255,255,255,.3);border-radius:50%;animation:spin-reverse .8s linear infinite}.loading-indicator .loading-text{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.2);padding:.875rem 1.5rem;border-radius:20px;box-shadow:0 6px 20px #667eea99;border:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:200px}@media(max-width:768px){.loading-indicator .loading-text{padding:.5rem 1.25rem;min-width:180px}}.loading-indicator .loading-text .main-text{font-size:.9rem;font-weight:700;color:#2c3e50;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}@media(max-width:768px){.loading-indicator .loading-text .main-text{font-size:.85rem}}.loading-indicator .loading-text .sub-text{font-size:.85rem;font-weight:500;color:#b0b0b0;text-align:center;opacity:.8}@media(max-width:768px){.loading-indicator .loading-text .sub-text{font-size:.75rem}}.loading-indicator .loading-text .dots{display:inline-flex;gap:2px}.loading-indicator .loading-text .dots span{width:4px;height:4px;background:#667eea;border-radius:50%;animation:dots 1.4s ease-in-out infinite both}.loading-indicator .loading-text .dots span:nth-child(1){animation-delay:-.32s}.loading-indicator .loading-text .dots span:nth-child(2){animation-delay:-.16s}.loading-indicator .loading-text .dots span:nth-child(3){animation-delay:0s}.loading-indicator .weather-icon-loading{width:4rem;height:4rem;opacity:.8;animation:float 2s ease-in-out infinite}@media(max-width:768px){.loading-indicator .weather-icon-loading{width:3rem;height:3rem}}.loading-indicator .weather-icon-loading svg{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.loading-indicator .progress-ring circle{fill:none;stroke-width:4}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin-reverse{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes progress{0%{stroke-dashoffset:283}50%{stroke-dashoffset:70}to{stroke-dashoffset:283}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-50%) translateY(30px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}@keyframes slideUpDelayed{0%{opacity:0;transform:translate(-50%,-50%) translateY(30px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDelayed{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes dots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}@media(max-width:768px){.loading-indicator{gap:.875rem}.loading-indicator .spinner-container{width:3rem;height:3rem}.loading-indicator .spinner{border-width:.3rem}.loading-indicator .spinner:before{inset:.15rem;border-width:.15rem}.loading-indicator .progress-ring{top:-.15rem;left:-.15rem;width:calc(100% + .3rem);height:calc(100% + .3rem)}}.weather-alerts{margin-top:20px;background:linear-gradient(135deg,#fff8dc,#fffaf0);padding:1rem;border-left:.1rem solid #ffa500}.alerts-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#d97706}.alerts-header svg{flex-shrink:0}.alerts-header h3{margin:0;font-size:16px;font-weight:600}.alerts-list{display:flex;flex-direction:column;gap:12px}.alert-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;background:#fff;border-left:3px solid;transition:transform .2s,box-shadow .2s;cursor:pointer;user-select:none}.alert-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.alert-item:active{transform:translate(2px) scale(.98)}.alert-item:focus{outline:2px solid rgba(0,0,0,.2);outline-offset:2px}.alert-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.alert-content{flex:1;min-width:0}.alert-description{font-size:14px;font-weight:500;margin-bottom:6px;line-height:1.4}.alert-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px;opacity:.7}.alert-code{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.alert-time{color:#666}.alert-arrow{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;opacity:.4;transition:opacity .2s,transform .2s}.alert-arrow svg{width:16px;height:16px}.alert-item:hover .alert-arrow{opacity:.8;transform:translate(2px)}.alert-item.severity-danger{border-left-color:#dc2626}.alert-item.severity-danger .alert-icon{color:#dc2626}.alert-item.severity-alert{border-left-color:#ea580c}.alert-item.severity-alert .alert-icon{color:#ea580c}.alert-item.severity-warning{border-left-color:#d97706}.alert-item.severity-warning .alert-icon{color:#d97706}.alert-item.severity-info{border-left-color:#0284c7}.alert-item.severity-info .alert-icon{color:#0284c7}@media(max-width:768px){.weather-alerts{padding:12px}.alerts-header h3{font-size:14px}.alert-item{padding:10px;gap:10px}.alert-icon{width:28px;height:28px}.alert-description{font-size:13px}.alert-meta{font-size:11px;gap:8px}}.alert-detail-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10001;padding:1.25rem}@media(max-width:768px){.alert-detail-overlay{padding:0;align-items:flex-end}}.alert-detail-card{background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;max-width:600px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;border-left:4px solid}.alert-detail-card.severity-danger{border-left-color:#dc2626}.alert-detail-card.severity-alert{border-left-color:#ea580c}.alert-detail-card.severity-warning{border-left-color:#d97706}.alert-detail-card.severity-info{border-left-color:#0284c7}@media(max-width:768px){.alert-detail-card{max-width:100%;max-height:90vh;border-radius:20px 20px 0 0}}.alert-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid rgba(0,0,0,.08)}@media(max-width:768px){.alert-header{padding:.875rem}}.severity-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:12px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.severity-badge.severity-danger{background:#dc26261a;color:#dc2626}.severity-badge.severity-alert{background:#ea580c1a;color:#ea580c}.severity-badge.severity-warning{background:#d977061a;color:#d97706}.severity-badge.severity-info{background:#0284c71a;color:#0284c7}.severity-badge .severity-icon{width:20px;height:20px}.close-button{background:#0000000d;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#0009}.close-button svg{width:20px;height:20px}.close-button:hover{background:#0000001a;color:#000c;transform:scale(1.1)}.close-button:active{transform:scale(.95)}.alert-detail-content{flex:1;overflow-y:auto;padding:1.25rem}@media(max-width:768px){.alert-detail-content{padding:.875rem}}.alert-detail-content::-webkit-scrollbar{width:8px}.alert-detail-content::-webkit-scrollbar-track{background:#00000008;border-radius:4px}.alert-detail-content::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.alert-detail-content::-webkit-scrollbar-thumb:hover{background:#00000040}.alert-detail-description{margin-bottom:1.5rem}.alert-detail-description h2{font-size:24px;font-weight:700;color:#000000e6;margin:0 0 .875rem;line-height:1.3}@media(max-width:768px){.alert-detail-description h2{font-size:20px}}.alert-detail-meta{display:flex;gap:.875rem;flex-wrap:wrap;font-size:14px}.alert-type{padding:4px .5rem;background:#0000000f;border-radius:8px;font-weight:500;color:#000000b3}.alert-detail-time{padding:4px .5rem;background:#0000000a;border-radius:8px;color:#0009;display:flex;align-items:center;gap:4px;border:none;font-family:inherit;font-size:14px;cursor:default}.alert-detail-time.clickable{cursor:pointer;transition:all .2s ease}.alert-detail-time.clickable:hover{background:#677eea1a;color:#667eea;transform:translateY(-1px);box-shadow:0 2px 8px #677eea33}.alert-detail-time.clickable:active{transform:translateY(0)}.alert-detail-time.clickable svg{transition:transform .2s ease}.alert-detail-time.clickable:hover svg{transform:rotate(15deg)}.technical-details{margin-bottom:1.5rem;padding:.875rem;background:#00000005;border-radius:12px;border:1px solid rgba(0,0,0,.05)}.technical-details h3{font-size:16px;font-weight:600;color:#000c;margin:0 0 .875rem;display:flex;align-items:center;gap:.5rem}.technical-details h3:before{content:"📊"}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.875rem}@media(max-width:768px){.details-grid{grid-template-columns:1fr;gap:.5rem}}.detail-item{display:flex;flex-direction:column;gap:4px;padding:.5rem;background:#fff9;border-radius:8px}.detail-label{font-size:12px;font-weight:500;color:#00000080;text-transform:uppercase;letter-spacing:.3px}.detail-value{font-size:18px;font-weight:700;color:#000000d9}@media(max-width:768px){.detail-value{font-size:16px}}.alert-panel-enter-active,.alert-panel-leave-active{transition:opacity .3s ease}.alert-panel-enter-active .alert-detail-card,.alert-panel-leave-active .alert-detail-card{transition:transform .3s ease,opacity .3s ease}.alert-panel-enter-from,.alert-panel-leave-to{opacity:0}.alert-panel-enter-from .alert-detail-card,.alert-panel-leave-to .alert-detail-card{transform:translateY(20px);opacity:0}@media(max-width:768px){.alert-panel-enter-from .alert-detail-card,.alert-panel-leave-to .alert-detail-card{transform:translateY(100%)}}.alert-panel-enter-to,.alert-panel-leave-from{opacity:1}.alert-panel-enter-to .alert-detail-card,.alert-panel-leave-from .alert-detail-card{transform:translateY(0);opacity:1}.search-modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:.875rem}.search-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}@media(max-width:768px){.search-modal{max-height:90vh}}.search-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}@media(max-width:768px){.search-modal-header{padding:.875rem 1.25rem}}.search-modal-title{color:#2c3e50;font-size:1rem;font-weight:700;margin:0}@media(max-width:768px){.search-modal-title{font-size:1rem}}.search-close-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;color:#b0b0b0;border-radius:12px;transition:all .3s ease}.search-close-btn:hover{background:#0000000d;color:#2c3e50}.search-close-btn:active{transform:scale(.95)}.search-input-container{position:relative;padding:.875rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}@media(max-width:768px){.search-input-container{padding:.875rem 1.25rem}}.search-icon{position:absolute;left:2.375rem;top:50%;transform:translateY(-50%);color:#b0b0b0;pointer-events:none}@media(max-width:768px){.search-icon{left:2.125rem}}.search-input{width:100%;padding:.875rem .875rem .875rem calc(1.75rem + 24px);border:2px solid rgba(0,0,0,.1);border-radius:16px;font-size:.8rem;color:#2c3e50;transition:all .3s ease;background:#00000008}.search-input::placeholder{color:#b0b0b0}.search-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}@media(max-width:768px){.search-input{font-size:.75rem;padding:.5rem .5rem .5rem calc(1rem + 20px)}}.search-clear-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;position:absolute;right:2rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:#b0b0b0;border-radius:12px;transition:all .3s ease}.search-clear-btn:hover{background:#0000000d;color:#2c3e50}.search-clear-btn:active{transform:translateY(-50%) scale(.95)}@media(max-width:768px){.search-clear-btn{right:1.75rem}}.search-results{flex:1;overflow-y:auto;padding:.875rem}@media(max-width:768px){.search-results{padding:.5rem}}.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:.875rem;color:#b0b0b0}.search-spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-empty,.search-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:.875rem;color:#b0b0b0;text-align:center}.search-empty svg,.search-hint svg{opacity:.5}.search-empty p,.search-hint p{margin:0;font-size:.8rem}.search-results-list{display:flex;flex-direction:column;gap:.25rem}.search-result-item{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#fff;border:2px solid rgba(0,0,0,.1);border-radius:16px;transition:all .3s ease;cursor:pointer;text-align:left}.search-result-item:hover{background:#00000008;border-color:#667eea;transform:translate(4px)}.search-result-item:hover .result-arrow{transform:translate(4px)}.search-result-item:active{transform:translate(2px)}@media(max-width:768px){.search-result-item{padding:.5rem .875rem}}.result-city-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.result-city-name{color:#2c3e50;font-size:.9rem;font-weight:600}@media(max-width:768px){.result-city-name{font-size:.8rem}}.result-city-state{color:#b0b0b0;font-size:.75rem}@media(max-width:768px){.result-city-state{font-size:.7rem}}.result-arrow{color:#b0b0b0;transition:all .3s ease;flex-shrink:0}.modal-enter-active,.modal-leave-active{transition:opacity .3s ease}.modal-enter-active .search-modal,.modal-leave-active .search-modal{transition:transform .3s ease}.modal-enter-from,.modal-leave-to{opacity:0}.modal-enter-from .search-modal,.modal-leave-to .search-modal{transform:scale(.95) translateY(-20px)}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(/assets/layers.BWBAp2CZ.png);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(/assets/layers-2x.Bpkbi35X.png);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(/assets/marker-icon.hN30_KVU.png)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}[data-v-68aea75f]:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--bg-primary: rgba(30, 30, 30, .9);--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(20, 20, 20, .5);--bg-header: rgba(100, 97, 97, .65);--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-muted: #b0b0b0;--text-dark: #2c3e50;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .25);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(255, 255, 255, .2);--overlay-dark: rgba(0, 0, 0, .25);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95}.weather-chart[data-v-68aea75f]{width:100%;min-height:500px;background:linear-gradient(135deg,#fffffffa,#f8fafffa);border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px #667eea1f;border:2px solid rgba(139,157,225,.2);transition:all .3s ease}.weather-chart[data-v-68aea75f]:hover{box-shadow:0 8px 32px #667eea2e;border-color:#667eea4d}@media(max-width:768px){.weather-chart[data-v-68aea75f]{padding:1.25rem;min-height:400px}}.chart-title[data-v-68aea75f]{font-size:1rem;font-weight:700;background:linear-gradient(135deg,#667eeae6,#764ba2cc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1.5rem;text-align:center}@media(max-width:768px){.chart-title[data-v-68aea75f]{font-size:.9rem;margin-bottom:1.25rem}}.chart-container[data-v-68aea75f]{position:relative;width:100%;height:400px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}@media(max-width:768px){.chart-container[data-v-68aea75f]{height:300px}}@media(max-width:480px){.chart-container canvas[data-v-68aea75f]{min-width:450px}}.chart-container canvas[data-v-68aea75f]{max-width:100%}@media(prefers-reduced-motion:reduce){.weather-chart[data-v-68aea75f] *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}[data-v-647861ea]:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--bg-primary: rgba(30, 30, 30, .9);--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(20, 20, 20, .5);--bg-header: rgba(100, 97, 97, .65);--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-muted: #b0b0b0;--text-dark: #2c3e50;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .25);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(255, 255, 255, .2);--overlay-dark: rgba(0, 0, 0, .25);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95}.hourly-chart[data-v-647861ea]{width:100%;animation:fadeIn-647861ea .6s ease-out .3s both}.chart-title[data-v-647861ea]{font-size:.9rem;font-weight:700;color:#2d3748;margin-bottom:1.25rem;text-align:center}@media(max-width:768px){.chart-title[data-v-647861ea]{font-size:.8rem;margin-bottom:.875rem}}.chart-container[data-v-647861ea]{position:relative;width:100%;height:350px;background:linear-gradient(135deg,#ffffffe6,#f8faffeb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:20px;box-shadow:0 4px 16px #8b9de11f;border:2px solid rgba(139,157,225,.15);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}@media(max-width:768px){.chart-container[data-v-647861ea]{height:300px;padding:1.25rem}}@media(max-width:480px){.chart-container[data-v-647861ea]{height:280px;padding:.875rem}.chart-container canvas[data-v-647861ea]{min-width:500px}}@keyframes fadeIn-647861ea{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay[data-v-6bed2092]{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;padding:0}@media(min-width:769px){.modal-overlay[data-v-6bed2092]{display:none!important}}.modal-container[data-v-6bed2092]{background:linear-gradient(135deg,#fffffffa,#f8fafffa);width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}@media(orientation:portrait){.modal-container[data-v-6bed2092]{transform:rotate(90deg);transform-origin:center center;width:calc(100vh - 40px);height:calc(100vw - 40px);position:fixed;left:50%;top:50%;margin-left:calc(-50vh + 20px);margin-top:calc(-50vw + 20px)}}.modal-header[data-v-6bed2092]{display:flex;justify-content:space-between;align-items:center;padding:.5rem .875rem;border-bottom:2px solid rgba(139,157,225,.2);background:#ffffffe6;backdrop-filter:blur(10px);flex-shrink:0;min-height:56px;gap:.5rem}@media(orientation:landscape){.modal-header[data-v-6bed2092]{padding:.875rem 1.25rem;min-height:64px}}.modal-title[data-v-6bed2092]{font-size:14px;font-weight:700;color:#667eea;margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(orientation:landscape){.modal-title[data-v-6bed2092]{font-size:.9rem}}.close-button[data-v-6bed2092]{background:#8b9de126;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;z-index:10}.close-button span[data-v-6bed2092]{font-size:22px;color:#667eea;font-weight:700;line-height:1}.close-button[data-v-6bed2092]:active{transform:scale(.95);background:#8b9de140}.modal-body[data-v-6bed2092]{flex:1;overflow-x:auto;overflow-y:hidden;padding:.25rem;-webkit-overflow-scrolling:touch;min-height:0}.modal-body[data-v-6bed2092] .hourly-chart{height:100%;width:100%}.modal-body[data-v-6bed2092] .chart-title{display:none}@media(orientation:portrait){.modal-body[data-v-6bed2092] .chart-container{height:100%;width:100%;min-width:unset;margin:0;padding:.25rem;overflow-x:auto;overflow-y:hidden}.modal-body[data-v-6bed2092] .chart-container canvas{width:100%!important;height:100%!important;max-height:calc(100vh - 60px)}}@media(orientation:landscape){.modal-body[data-v-6bed2092]{padding:.5rem}.modal-body[data-v-6bed2092] .chart-container{height:100%;width:100%;min-width:unset;margin:0;padding:.25rem;overflow-x:auto;overflow-y:hidden}.modal-body[data-v-6bed2092] .chart-container canvas{width:100%!important;height:100%!important}}.modal-enter-active[data-v-6bed2092],.modal-leave-active[data-v-6bed2092]{transition:opacity .3s ease}.modal-enter-from[data-v-6bed2092],.modal-leave-to[data-v-6bed2092]{opacity:0}.modal-enter-active .modal-container[data-v-6bed2092],.modal-leave-active .modal-container[data-v-6bed2092]{transition:transform .3s ease}.modal-enter-from .modal-container[data-v-6bed2092],.modal-leave-to .modal-container[data-v-6bed2092]{transform:translateY(100%)}.modal-overlay[data-v-0e6ffff7]{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;padding:0}@media(min-width:769px){.modal-overlay[data-v-0e6ffff7]{display:none!important}}.modal-container[data-v-0e6ffff7]{background:linear-gradient(135deg,#fffffffa,#f8fafffa);width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}@media(orientation:portrait){.modal-container[data-v-0e6ffff7]{transform:rotate(90deg);transform-origin:center center;width:calc(100vh - 40px);height:calc(100vw - 40px);position:fixed;left:50%;top:50%;margin-left:calc(-50vh + 20px);margin-top:calc(-50vw + 20px)}}.modal-header[data-v-0e6ffff7]{display:flex;justify-content:space-between;align-items:center;padding:.5rem .875rem;border-bottom:2px solid rgba(139,157,225,.2);background:#ffffffe6;backdrop-filter:blur(10px);flex-shrink:0;min-height:56px;gap:.5rem}@media(orientation:landscape){.modal-header[data-v-0e6ffff7]{padding:.875rem 1.25rem;min-height:64px}}.modal-title[data-v-0e6ffff7]{font-size:14px;font-weight:700;color:#667eea;margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(orientation:landscape){.modal-title[data-v-0e6ffff7]{font-size:.9rem}}.close-button[data-v-0e6ffff7]{background:#8b9de126;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;z-index:10}.close-button span[data-v-0e6ffff7]{font-size:22px;color:#667eea;font-weight:700;line-height:1}.close-button[data-v-0e6ffff7]:active{transform:scale(.95);background:#8b9de140}.modal-body[data-v-0e6ffff7]{flex:1;overflow-x:auto;overflow-y:hidden;padding:.25rem;-webkit-overflow-scrolling:touch;min-height:0}.modal-body[data-v-0e6ffff7] .weather-chart{height:100%;width:100%;min-height:auto}.modal-body[data-v-0e6ffff7] .chart-title{display:none}@media(orientation:portrait){.modal-body[data-v-0e6ffff7] .chart-container{height:100%;width:100%;min-width:unset;margin:0;padding:.25rem;overflow-x:auto;overflow-y:hidden}.modal-body[data-v-0e6ffff7] .chart-container canvas{width:100%!important;height:100%!important;max-height:calc(100vh - 60px)}}@media(orientation:landscape){.modal-body[data-v-0e6ffff7]{padding:.5rem}.modal-body[data-v-0e6ffff7] .chart-container{height:100%;width:100%;min-width:unset;margin:0;padding:.25rem;overflow-x:auto;overflow-y:hidden}.modal-body[data-v-0e6ffff7] .chart-container canvas{width:100%!important;height:100%!important}}.modal-enter-active[data-v-0e6ffff7],.modal-leave-active[data-v-0e6ffff7]{transition:opacity .3s ease}.modal-enter-from[data-v-0e6ffff7],.modal-leave-to[data-v-0e6ffff7]{opacity:0}.modal-enter-active .modal-container[data-v-0e6ffff7],.modal-leave-active .modal-container[data-v-0e6ffff7]{transition:transform .3s ease}.modal-enter-from .modal-container[data-v-0e6ffff7],.modal-leave-to .modal-container[data-v-0e6ffff7]{transform:translateY(100%)}[data-v-d4c70d0f]:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--bg-primary: rgba(30, 30, 30, .9);--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(20, 20, 20, .5);--bg-header: rgba(100, 97, 97, .65);--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-muted: #b0b0b0;--text-dark: #2c3e50;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .25);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(255, 255, 255, .2);--overlay-dark: rgba(0, 0, 0, .25);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95}.wind-compass[data-v-d4c70d0f]{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:0;background:transparent;border:none;box-shadow:none;min-width:auto;position:relative;transition:all .3s ease}.wind-compass[data-v-d4c70d0f]:hover{transform:scale(1.02)}@media(max-width:768px){.wind-compass[data-v-d4c70d0f]{min-width:auto;padding:0;gap:.5rem}}.compass-svg[data-v-d4c70d0f]{width:100%;max-width:180px;height:auto;color:#5a6b7d;filter:drop-shadow(0 2px 8px rgba(139,157,225,.15))}@media(max-width:768px){.compass-svg[data-v-d4c70d0f]{max-width:160px}}.cardinal-point[data-v-d4c70d0f]{fill:#5a6b7d;font-weight:600}.cardinal-point.cardinal-n[data-v-d4c70d0f]{fill:#ef4444;font-weight:800;filter:drop-shadow(0 1px 2px rgba(239,68,68,.5))}.degree-marks[data-v-d4c70d0f]{stroke:#8394a8}@keyframes windOscillation-d4c70d0f{0%,to{transform:rotate(calc(var(--wind-direction) - 3deg))}50%{transform:rotate(calc(var(--wind-direction) + 3deg))}}.wind-arrow[data-v-d4c70d0f]{transform-origin:100px 100px;transform:rotate(var(--wind-direction));animation:windOscillation-d4c70d0f 2s ease-in-out infinite;filter:drop-shadow(0 3px 8px rgba(239,68,68,.4));will-change:transform}@media(prefers-reduced-motion:reduce){.wind-arrow[data-v-d4c70d0f]{animation:none}}.wind-speed[data-v-d4c70d0f]{display:flex;flex-direction:column;align-items:center;gap:2px;padding-top:.25rem;width:100%}.wind-speed-value[data-v-d4c70d0f]{font-size:1.75rem;font-weight:800;color:#8b9de1;line-height:1;font-variant-numeric:tabular-nums}@media(max-width:768px){.wind-speed-value[data-v-d4c70d0f]{font-size:1.5rem}}.wind-speed-unit[data-v-d4c70d0f]{font-size:.7rem;font-weight:700;color:#5a6b7d;text-transform:uppercase;letter-spacing:.5px;opacity:.75}[data-v-4bd52d5b]:root{--color-primary-start: #667eea;--color-primary-end: #764ba2;--bg-primary: rgba(30, 30, 30, .9);--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(20, 20, 20, .5);--bg-header: rgba(100, 97, 97, .65);--bg-card: rgba(255, 255, 255, .95);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-muted: #b0b0b0;--text-dark: #2c3e50;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .25);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(255, 255, 255, .2);--overlay-dark: rgba(0, 0, 0, .25);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95}.city-detail-page .weather-alerts[data-v-4bd52d5b]{background:linear-gradient(135deg,#dbeafe99,#bfdbfe80);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1.5rem;border-left:4px solid #8b9de1;border-radius:20px;box-shadow:0 4px 16px #8b9de114;border:2px solid rgba(139,157,225,.2);border-left-width:4px}@media(max-width:768px){.city-detail-page .weather-alerts[data-v-4bd52d5b]{padding:1.25rem}}.city-detail-page .alerts-header[data-v-4bd52d5b]{display:flex;align-items:center;gap:.875rem;margin-bottom:1.25rem;color:#8b9de1}.city-detail-page .alerts-header svg[data-v-4bd52d5b]{flex-shrink:0;width:24px;height:24px;filter:drop-shadow(0 2px 4px rgba(59,130,246,.2))}@media(max-width:768px){.city-detail-page .alerts-header svg[data-v-4bd52d5b]{width:20px;height:20px}}.city-detail-page .alerts-header h3[data-v-4bd52d5b]{margin:0;font-size:1rem;font-weight:800;color:#2d3748;letter-spacing:-.3px}@media(max-width:768px){.city-detail-page .alerts-header h3[data-v-4bd52d5b]{font-size:.9rem}}.city-detail-page .alerts-list[data-v-4bd52d5b]{display:flex;flex-direction:column;gap:.875rem}.city-detail-page .alert-item[data-v-4bd52d5b]{display:flex;align-items:center;gap:1.25rem;padding:1.25rem;border-radius:16px;background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-left:4px solid;transition:all .3s ease;cursor:pointer;user-select:none;box-shadow:0 2px 8px #3b82f614}.city-detail-page .alert-item[data-v-4bd52d5b]:hover{transform:translate(4px);box-shadow:0 4px 16px #3b82f626;background:#fff}.city-detail-page .alert-item[data-v-4bd52d5b]:active{transform:translate(2px) scale(.99)}.city-detail-page .alert-item[data-v-4bd52d5b]:focus-visible{outline:3px solid rgba(59,130,246,.5);outline-offset:2px}@media(max-width:768px){.city-detail-page .alert-item[data-v-4bd52d5b]{padding:.875rem;gap:.875rem}}.city-detail-page .alert-icon[data-v-4bd52d5b]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.city-detail-page .alert-icon svg[data-v-4bd52d5b]{width:28px;height:28px}@media(max-width:768px){.city-detail-page .alert-icon[data-v-4bd52d5b]{width:36px;height:36px}.city-detail-page .alert-icon svg[data-v-4bd52d5b]{width:24px;height:24px}}.city-detail-page .alert-content[data-v-4bd52d5b]{flex:1;min-width:0}.city-detail-page .alert-description[data-v-4bd52d5b]{font-size:.8rem;font-weight:700;margin-bottom:.5rem;line-height:1.5;color:#2d3748}.city-detail-page .alert-description .alert-emoji[data-v-4bd52d5b]{margin-right:.25rem;font-size:1.2em}@media(max-width:768px){.city-detail-page .alert-description[data-v-4bd52d5b]{font-size:.75rem}}.city-detail-page .alert-meta[data-v-4bd52d5b]{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap;font-size:.75rem;color:#5a6b7d}@media(max-width:768px){.city-detail-page .alert-meta[data-v-4bd52d5b]{font-size:.7rem;gap:.5rem}}.city-detail-page .alert-code[data-v-4bd52d5b]{font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:4px 10px;background:#3b82f61a;border-radius:12px;color:#8b9de1}.city-detail-page .alert-time[data-v-4bd52d5b]{color:#8394a8;font-weight:600;font-variant-numeric:tabular-nums}.city-detail-page .alert-arrow[data-v-4bd52d5b]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:#8394a8;opacity:.5;transition:all .3s ease}.city-detail-page .alert-arrow svg[data-v-4bd52d5b]{width:20px;height:20px}.alert-item:hover .city-detail-page .alert-arrow[data-v-4bd52d5b]{opacity:1;transform:translate(4px);color:#8b9de1}.city-detail-page .alert-item.severity-danger[data-v-4bd52d5b]{border-left-color:#dc2626}.city-detail-page .alert-item.severity-danger .alert-icon[data-v-4bd52d5b]{color:#dc2626}.city-detail-page .alert-item.severity-danger .alert-code[data-v-4bd52d5b]{background:#dc26261a;color:#dc2626}.city-detail-page .alert-item.severity-alert[data-v-4bd52d5b]{border-left-color:#ea580c}.city-detail-page .alert-item.severity-alert .alert-icon[data-v-4bd52d5b]{color:#ea580c}.city-detail-page .alert-item.severity-alert .alert-code[data-v-4bd52d5b]{background:#ea580c1a;color:#ea580c}.city-detail-page .alert-item.severity-warning[data-v-4bd52d5b]{border-left-color:#d97706}.city-detail-page .alert-item.severity-warning .alert-icon[data-v-4bd52d5b]{color:#d97706}.city-detail-page .alert-item.severity-warning .alert-code[data-v-4bd52d5b]{background:#d977061a;color:#d97706}.city-detail-page .alert-item.severity-info[data-v-4bd52d5b]{border-left-color:#0284c7}.city-detail-page .alert-item.severity-info .alert-icon[data-v-4bd52d5b]{color:#0284c7}.city-detail-page .alert-item.severity-info .alert-code[data-v-4bd52d5b]{background:#0284c71a;color:#0284c7}.city-detail-page[data-v-4bd52d5b]{min-height:100vh;height:100vh;background:linear-gradient(135deg,#8b9de114,#9d85c71a,#a98fd21f 70%,#8b9de11a);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.page-content[data-v-4bd52d5b]{max-width:1400px;margin:0 auto;padding:0 1.5rem 2rem;flex:1;overflow-y:auto;width:100%}@media(max-width:768px){.page-content[data-v-4bd52d5b]{padding:0 .875rem 2rem}}.current-weather-section[data-v-4bd52d5b]{margin-bottom:2rem;animation:fadeIn-4bd52d5b .6s ease-out;padding:1.5rem;background:linear-gradient(135deg,#3b82f614,#6366f114,#8b5cf614);border-radius:24px;backdrop-filter:blur(10px);border:1px solid rgba(59,130,246,.15);box-shadow:0 4px 24px #3b82f614}@media(max-width:768px){.current-weather-section[data-v-4bd52d5b]{padding:1.25rem}}.section-title[data-v-4bd52d5b]{font-size:1rem;font-weight:700;background:linear-gradient(135deg,#3b82f6e6,#6366f1d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;position:relative}@media(max-width:768px){.section-title[data-v-4bd52d5b]{font-size:1rem}}.section-header[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1.25rem}@media(max-width:768px){.section-header[data-v-4bd52d5b]{flex-direction:column;align-items:flex-start;margin-bottom:1.25rem;gap:.875rem}}.forecast-date-badge[data-v-4bd52d5b]{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;color:#3b82f6e6;background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.5rem 1.25rem;border-radius:16px;border:2px solid rgba(59,130,246,.2);font-weight:700;white-space:nowrap;box-shadow:0 2px 8px #3b82f61a;transition:all .3s ease}.forecast-date-badge[data-v-4bd52d5b]:hover{border-color:#3b82f666;box-shadow:0 4px 12px #3b82f626}.forecast-date-badge svg[data-v-4bd52d5b]{width:16px;height:16px;opacity:.9;flex-shrink:0}@media(max-width:768px){.forecast-date-badge[data-v-4bd52d5b]{font-size:.7rem;padding:.25rem .875rem;gap:.25rem;width:100%;justify-content:center}.forecast-date-badge svg[data-v-4bd52d5b]{width:14px;height:14px}}.loading-container[data-v-4bd52d5b],.error-container[data-v-4bd52d5b]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.25rem;padding:2rem}.loading-container svg[data-v-4bd52d5b],.error-container svg[data-v-4bd52d5b]{color:#e0e0e0}.loading-container h2[data-v-4bd52d5b],.error-container h2[data-v-4bd52d5b]{font-size:1rem;color:#2c3e50;margin:0}.loading-container p[data-v-4bd52d5b],.error-container p[data-v-4bd52d5b]{color:#e0e0e0;text-align:center;max-width:400px}.spinner[data-v-4bd52d5b]{width:48px;height:48px;border:4px solid rgba(0,0,0,.1);border-left-color:#667eea;border-radius:50%;animation:spin-4bd52d5b 1s linear infinite}@keyframes spin-4bd52d5b{to{transform:rotate(360deg)}}.retry-button[data-v-4bd52d5b]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;padding:.875rem 1.5rem;background:#667eea;color:#fff;border-radius:12px;font-weight:600;transition:.2s ease}.retry-button[data-v-4bd52d5b]:hover{background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 16px #667eea80}.alerts-section[data-v-4bd52d5b]{margin-bottom:2rem;animation:fadeIn-4bd52d5b .6s ease-out .3s both}.visualization-section[data-v-4bd52d5b]{margin-bottom:2rem;animation:fadeIn-4bd52d5b .6s ease-out .3s both;padding:1.5rem;background:linear-gradient(135deg,#3b82f614,#6366f114,#8b5cf614);border-radius:24px;backdrop-filter:blur(10px);border:1px solid rgba(59,130,246,.15);box-shadow:0 4px 24px #3b82f614}@media(max-width:768px){.visualization-section[data-v-4bd52d5b]{padding:1.25rem}}.page-header[data-v-4bd52d5b]{background:linear-gradient(135deg,#8b9de1f2,#667eeaeb);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:.3rem;box-shadow:0 4px 20px #667eea40;position:sticky;top:0;z-index:100;flex-shrink:0;border:2px solid rgba(255,255,255,.2);margin:.875rem 1.5rem 1.5rem;border-radius:20px}@media(max-width:768px){.page-header[data-v-4bd52d5b]{margin:.5rem .875rem 1.25rem;border-radius:16px}}.header-content[data-v-4bd52d5b]{display:flex;align-items:center;gap:.875rem;max-width:1400px;margin:0 auto}@media(max-width:768px){.header-content[data-v-4bd52d5b]{gap:.5rem}}.back-button[data-v-4bd52d5b]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;color:#fff;border-radius:16px;transition:all .3s ease;background:#ffffff26;border:2px solid rgba(255,255,255,.3);flex-shrink:0;box-shadow:0 2px 8px #0000001a}.back-button[data-v-4bd52d5b]:hover{background:#ffffff40;transform:scale(1.05);box-shadow:0 4px 16px #00000026;border-color:#ffffff80}.back-button[data-v-4bd52d5b]:active{transform:scale(1.02)}.back-button svg[data-v-4bd52d5b]{width:24px;height:24px}@media(max-width:768px){.back-button[data-v-4bd52d5b]{width:40px;height:40px}.back-button svg[data-v-4bd52d5b]{width:20px;height:20px}}.city-search-container[data-v-4bd52d5b]{position:relative;flex:1;max-width:600px}.city-search-button[data-v-4bd52d5b]{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;color:#fff;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer;box-shadow:0 2px 8px #0000001a}.city-search-button[data-v-4bd52d5b]:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.city-search-button[data-v-4bd52d5b]:active{transform:translateY(0)}.city-search-button .location-icon[data-v-4bd52d5b]{flex-shrink:0;width:20px;height:20px;transition:all .4s cubic-bezier(.4,0,.2,1)}.city-search-button .city-info[data-v-4bd52d5b]{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.city-search-button .city-name[data-v-4bd52d5b]{color:#fff;font-size:1rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.15);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.city-search-button .city-state[data-v-4bd52d5b]{color:#fffffff2;font-size:.8rem;font-weight:600;background:#fff3;padding:.25rem .5rem;border-radius:8px;border:1px solid rgba(255,255,255,.3);white-space:nowrap;flex-shrink:0}@media(max-width:768px){.city-search-button[data-v-4bd52d5b]{padding:.5rem .875rem;gap:.5rem}.city-search-button .location-icon[data-v-4bd52d5b]{width:18px;height:18px}.city-search-button .city-name[data-v-4bd52d5b]{font-size:.8rem}.city-search-button .city-state[data-v-4bd52d5b]{font-size:.75rem;padding:2px .25rem}}.inline-search-box[data-v-4bd52d5b]{position:relative;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:16px;box-shadow:0 2px 8px #0000001a;animation:searchBoxFadeIn-4bd52d5b .4s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(max-width:768px){.inline-search-box[data-v-4bd52d5b]{padding:.5rem .875rem;gap:.5rem}}@keyframes searchBoxFadeIn-4bd52d5b{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.inline-search-input[data-v-4bd52d5b]{flex:1;border:none;background:transparent;font-size:.8rem;color:#fff;outline:none;font-weight:600}.inline-search-input[data-v-4bd52d5b]::placeholder{color:#ffffffb3;font-weight:500}@media(max-width:768px){.inline-search-input[data-v-4bd52d5b]{font-size:.75rem}}.inline-clear-btn[data-v-4bd52d5b]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:#fffc;border-radius:12px;transition:all .2s ease;flex-shrink:0}.inline-clear-btn[data-v-4bd52d5b]:hover{background:#fff3;color:#fff}.inline-clear-btn[data-v-4bd52d5b]:active{transform:scale(.95)}.search-dropdown[data-v-4bd52d5b]{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-height:400px;overflow-y:auto;z-index:1000;animation:dropdownSlideIn-4bd52d5b .3s cubic-bezier(.4,0,.2,1);border:2px solid rgba(139,157,225,.2)}@media(max-width:768px){.search-dropdown[data-v-4bd52d5b]{max-height:300px}}@keyframes dropdownSlideIn-4bd52d5b{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item[data-v-4bd52d5b]{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;text-align:left;border-bottom:1px solid rgba(0,0,0,.05);transition:all .2s ease;cursor:pointer}.dropdown-item svg[data-v-4bd52d5b]{flex-shrink:0;width:16px;height:16px;color:#b0b0b0;transition:all .2s ease}.dropdown-item[data-v-4bd52d5b]:hover{background:linear-gradient(135deg,#8b9de114,#667eea0d)}.dropdown-item:hover svg[data-v-4bd52d5b]{color:#667eea;transform:scale(1.1)}.dropdown-item:hover .dropdown-city-name[data-v-4bd52d5b]{color:#667eea}.dropdown-item[data-v-4bd52d5b]:last-child{border-bottom:none}.dropdown-item[data-v-4bd52d5b]:first-child{border-top-left-radius:16px;border-top-right-radius:16px}.dropdown-item[data-v-4bd52d5b]:last-child{border-bottom-left-radius:16px;border-bottom-right-radius:16px}@media(max-width:768px){.dropdown-item[data-v-4bd52d5b]{padding:.5rem .875rem;gap:.5rem}}.dropdown-city-info[data-v-4bd52d5b]{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.dropdown-city-name[data-v-4bd52d5b]{color:#2c3e50;font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}@media(max-width:768px){.dropdown-city-name[data-v-4bd52d5b]{font-size:.75rem}}.dropdown-city-state[data-v-4bd52d5b]{color:#b0b0b0;font-size:.75rem}@media(max-width:768px){.dropdown-city-state[data-v-4bd52d5b]{font-size:.7rem}}.search-dropdown-empty[data-v-4bd52d5b]{padding:1.5rem;text-align:center;color:#b0b0b0;font-size:.75rem;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;position:absolute;top:calc(100% + .5rem);left:0;right:0;z-index:1000;animation:dropdownSlideIn-4bd52d5b .3s cubic-bezier(.4,0,.2,1);border:2px solid rgba(139,157,225,.2)}.hero-cards-grid[data-v-4bd52d5b]{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media(max-width:768px){.hero-cards-grid[data-v-4bd52d5b]{grid-template-columns:1fr;gap:1.25rem}}.hero-temp-card[data-v-4bd52d5b]{background:linear-gradient(135deg,#ffffffe6,#f8faffeb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:2rem;border-radius:24px;box-shadow:0 4px 24px #8b9de11f;display:flex;align-items:center;gap:1.5rem;border:2px solid rgba(139,157,225,.15);transition:all .3s ease;animation:slideDown-4bd52d5b .6s ease-out;position:relative;overflow:hidden}.hero-temp-card[data-v-4bd52d5b]:hover{transform:translateY(-4px);box-shadow:0 12px 40px #8b9de133;border-color:#8b9de14d}.hero-temp-card:hover .hero-icon[data-v-4bd52d5b]{transform:scale(1.15) rotate(5deg)}.hero-temp-card:hover .hero-temp-value[data-v-4bd52d5b]{transform:scale(1.05)}@media(max-width:768px){.hero-temp-card[data-v-4bd52d5b]{flex-direction:column;padding:1.5rem;gap:.875rem}}.hero-icon[data-v-4bd52d5b]{font-size:120px;line-height:1;filter:drop-shadow(0 8px 20px rgba(59,130,246,.3));transition:all .4s cubic-bezier(.34,1.56,.64,1);animation:floatIcon-4bd52d5b 3s ease-in-out infinite;position:relative;z-index:1}@media(max-width:768px){.hero-icon[data-v-4bd52d5b]{font-size:96px}}@keyframes floatIcon-4bd52d5b{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-temp-info[data-v-4bd52d5b]{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;position:relative;z-index:2;margin-left:-40px}@media(max-width:768px){.hero-temp-info[data-v-4bd52d5b]{margin-left:0}}.hero-temp-value[data-v-4bd52d5b]{font-size:96px;font-weight:800;background:linear-gradient(135deg,#8b9de1e6,#9d85c7d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-3px;transition:transform .3s ease;text-shadow:0 4px 12px rgba(139,157,225,.2);animation:pulseTemp-4bd52d5b 2s ease-in-out infinite}@media(max-width:768px){.hero-temp-value[data-v-4bd52d5b]{font-size:72px;letter-spacing:-2px}}@keyframes pulseTemp-4bd52d5b{0%,to{opacity:1}50%{opacity:.95}}.hero-temp-label[data-v-4bd52d5b]{font-size:1rem;color:#3b82f6bf;text-transform:capitalize;font-weight:600}@media(max-width:768px){.hero-temp-label[data-v-4bd52d5b]{font-size:.9rem}}.hero-temp-range[data-v-4bd52d5b]{display:flex;align-items:center;gap:.875rem;margin-top:.875rem;padding:.5rem 1.25rem;background:linear-gradient(135deg,#3b82f61a,#6366f11a);border-radius:16px;border:1px solid rgba(59,130,246,.2)}@media(max-width:768px){.hero-temp-range[data-v-4bd52d5b]{gap:.5rem;padding:.25rem .875rem}}.temp-range-max[data-v-4bd52d5b],.temp-range-min[data-v-4bd52d5b]{display:flex;align-items:center;gap:.25rem;font-size:.9rem;font-weight:700}.temp-range-max svg[data-v-4bd52d5b],.temp-range-min svg[data-v-4bd52d5b]{width:16px;height:16px;flex-shrink:0}@media(max-width:768px){.temp-range-max[data-v-4bd52d5b],.temp-range-min[data-v-4bd52d5b]{font-size:.8rem}.temp-range-max svg[data-v-4bd52d5b],.temp-range-min svg[data-v-4bd52d5b]{width:14px;height:14px}}.temp-range-max[data-v-4bd52d5b]{color:#fb923c}.temp-range-min[data-v-4bd52d5b]{color:#60a5fa}.temp-range-separator[data-v-4bd52d5b]{color:#667eea4d;font-weight:500;font-size:1rem}@media(max-width:768px){.temp-range-separator[data-v-4bd52d5b]{font-size:.9rem}}.hero-wind-card[data-v-4bd52d5b]{background:linear-gradient(135deg,#ffffffe6,#f8faffeb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:24px;box-shadow:0 4px 24px #8b9de11f;border:2px solid rgba(139,157,225,.15);transition:all .3s ease;animation:slideDown-4bd52d5b .6s ease-out .1s both;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem}.hero-wind-card[data-v-4bd52d5b]:hover{transform:translateY(-2px);box-shadow:0 8px 32px #8b9de12e;border-color:#8b9de140}@media(max-width:768px){.hero-wind-card[data-v-4bd52d5b]{padding:1.25rem}}.wind-card-title[data-v-4bd52d5b]{margin:0;font-size:.9rem;font-weight:700;color:#3b82f6d9;text-align:center}@media(max-width:768px){.wind-card-title[data-v-4bd52d5b]{font-size:.8rem}}@keyframes slideDown-4bd52d5b{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.metrics-container[data-v-4bd52d5b]{margin-top:1.5rem;animation:fadeIn-4bd52d5b .6s ease-out .2s both}.metrics-header[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;cursor:pointer;user-select:none}@media(max-width:768px){.metrics-header[data-v-4bd52d5b]{margin-bottom:.875rem}}.metrics-title[data-v-4bd52d5b]{font-size:1rem;font-weight:700;color:#3b82f6d9;margin:0}@media(max-width:768px){.metrics-title[data-v-4bd52d5b]{font-size:.9rem}}.metrics-toggle[data-v-4bd52d5b]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;background:#3b82f61a;color:#3b82f6cc;transition:all .3s ease}.metrics-toggle svg[data-v-4bd52d5b]{transition:transform .3s ease}.metrics-toggle.expanded svg[data-v-4bd52d5b]{transform:rotate(180deg)}.metrics-toggle[data-v-4bd52d5b]:hover{background:#3b82f626;color:#3b82f6}@media(max-width:768px){.metrics-toggle[data-v-4bd52d5b]{display:flex}}.metrics-grid[data-v-4bd52d5b]{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}@media(max-width:768px){.metrics-grid[data-v-4bd52d5b]{grid-template-columns:1fr;gap:.875rem;max-height:1000px;overflow:hidden;transition:max-height .4s ease-out,opacity .3s ease-out}.metrics-grid.collapsed[data-v-4bd52d5b]{max-height:0;opacity:0}}.metric-item[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;gap:.875rem;padding:1.25rem;background:#ffffffbf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:16px;border:2px solid rgba(139,157,225,.15);box-shadow:0 2px 8px #8b9de114;transition:all .3s ease}.metric-item[data-v-4bd52d5b]:hover{transform:translateY(-2px);box-shadow:0 4px 16px #8b9de126;border-color:#8b9de140;background:#ffffffd9}@media(max-width:768px){.metric-item[data-v-4bd52d5b]{padding:.875rem;gap:.5rem}}.metric-label[data-v-4bd52d5b]{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#3b82f6e6;font-size:.8rem}@media(max-width:768px){.metric-label[data-v-4bd52d5b]{font-size:.75rem;gap:.25rem}}.metric-value[data-v-4bd52d5b]{font-weight:700;color:#2d3748;font-size:.9rem;white-space:nowrap}@media(max-width:768px){.metric-value[data-v-4bd52d5b]{font-size:.8rem}}.metric-icon[data-v-4bd52d5b]{font-size:20px;line-height:1;filter:drop-shadow(0 2px 4px rgba(59,130,246,.15))}@media(max-width:768px){.metric-icon[data-v-4bd52d5b]{font-size:18px}}.hourly-forecast-section[data-v-4bd52d5b]{margin-bottom:2rem;animation:fadeIn-4bd52d5b .6s ease-out .35s both;padding:1.5rem;background:linear-gradient(135deg,#8b5cf614,#6366f114,#3b82f614);border-radius:24px;backdrop-filter:blur(10px);border:1px solid rgba(139,92,246,.15);box-shadow:0 4px 24px #8b5cf614}@media(max-width:768px){.hourly-forecast-section[data-v-4bd52d5b]{padding:1.25rem}}.hourly-scroll-container[data-v-4bd52d5b]{display:flex;gap:.875rem;overflow-x:auto;scroll-snap-type:x mandatory;margin:0 -1.5rem;padding:.875rem 1.5rem 1.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.hourly-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar{height:6px}.hourly-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-track{background:#8b5cf61a;border-radius:50%;margin:0 1.5rem}.hourly-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:50%}.hourly-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-thumb:hover{background:#8b5cf680}@media(max-width:768px){.hourly-scroll-container[data-v-4bd52d5b]{gap:.5rem;margin:0 -1.25rem;padding-left:1.25rem;padding-right:1.25rem}}.hourly-card[data-v-4bd52d5b]{min-width:110px;max-width:110px;flex-shrink:0;scroll-snap-align:start;background:linear-gradient(135deg,#ffffffe0,#f5f3ffe6);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.875rem;border-radius:16px;box-shadow:0 3px 12px #8b5cf61a;border:2px solid rgba(139,92,246,.12);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}.hourly-card[data-v-4bd52d5b]:hover{transform:translateY(-2px);box-shadow:0 6px 18px #8b5cf62e;border-color:#8b5cf640}@media(max-width:768px){.hourly-card[data-v-4bd52d5b]{min-width:95px;max-width:95px;padding:.5rem}}.hourly-time[data-v-4bd52d5b]{font-size:.7rem;font-weight:700;color:#8b5cf6d9;text-align:center;white-space:pre-line;line-height:1.3}@media(max-width:768px){.hourly-time[data-v-4bd52d5b]{font-size:10px}}.hourly-icon[data-v-4bd52d5b]{font-size:32px;text-align:center;line-height:1;filter:drop-shadow(0 2px 6px rgba(139,92,246,.15));margin:.25rem 0;cursor:help}@media(max-width:768px){.hourly-icon[data-v-4bd52d5b]{font-size:28px}}.hourly-description[data-v-4bd52d5b]{font-size:10px;font-weight:600;color:#8b5cf6bf;text-align:center;line-height:1.2;min-height:24px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.hourly-description[data-v-4bd52d5b]{font-size:9px;min-height:22px}}.hourly-temp[data-v-4bd52d5b]{font-size:.9rem;font-weight:700;color:#8b5cf6;text-align:center}@media(max-width:768px){.hourly-temp[data-v-4bd52d5b]{font-size:.8rem}}.hourly-detail[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:10px;font-weight:600;color:#2d3748;width:100%}@media(max-width:768px){.hourly-detail[data-v-4bd52d5b]{font-size:9px}}.hourly-detail .detail-icon[data-v-4bd52d5b]{font-size:12px}@media(max-width:768px){.hourly-detail .detail-icon[data-v-4bd52d5b]{font-size:11px}}.forecast-section[data-v-4bd52d5b]{margin-bottom:2rem;animation:fadeIn-4bd52d5b .6s ease-out .4s both;padding:1.5rem;background:linear-gradient(135deg,#3b82f614,#6366f114,#8b5cf614);border-radius:24px;backdrop-filter:blur(10px);border:1px solid rgba(59,130,246,.15);box-shadow:0 4px 24px #3b82f614}@media(max-width:768px){.forecast-section[data-v-4bd52d5b]{padding:1.25rem}}.forecast-header[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}@media(max-width:768px){.forecast-header[data-v-4bd52d5b]{flex-direction:column;align-items:flex-start;gap:.875rem;margin-bottom:1.25rem}}.forecast-nav-buttons[data-v-4bd52d5b]{display:flex;gap:.5rem}@media(max-width:768px){.forecast-nav-buttons[data-v-4bd52d5b]{width:100%;justify-content:flex-end}}.forecast-nav-btn[data-v-4bd52d5b]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(59,130,246,.2);color:#3b82f6cc;transition:all .3s ease;box-shadow:0 2px 8px #3b82f61a}.forecast-nav-btn[data-v-4bd52d5b]:not(:disabled):hover{background:#3b82f61a;border-color:#3b82f666;color:#3b82f6;transform:scale(1.05);box-shadow:0 4px 12px #3b82f626}.forecast-nav-btn[data-v-4bd52d5b]:not(:disabled):active{transform:scale(.98)}.forecast-nav-btn[data-v-4bd52d5b]:disabled{opacity:.3;cursor:not-allowed}.forecast-nav-btn svg[data-v-4bd52d5b]{width:20px;height:20px}@media(max-width:768px){.forecast-nav-btn[data-v-4bd52d5b]{width:36px;height:36px}.forecast-nav-btn svg[data-v-4bd52d5b]{width:18px;height:18px}}.forecast-scroll-container[data-v-4bd52d5b]{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;margin:0 -1.5rem;padding:.875rem 1.5rem 1.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.forecast-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar{height:8px}.forecast-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-track{background:#8b9de11a;border-radius:50%;margin:0 1.5rem}.forecast-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-thumb{background:#8b9de14d;border-radius:50%}.forecast-scroll-container[data-v-4bd52d5b]::-webkit-scrollbar-thumb:hover{background:#8b9de180}@media(max-width:768px){.forecast-scroll-container[data-v-4bd52d5b]{gap:.875rem;margin:0 -1.25rem;padding-left:1.25rem;padding-right:1.25rem}}.forecast-card[data-v-4bd52d5b]{min-width:220px;max-width:220px;flex-shrink:0;scroll-snap-align:start;background:linear-gradient(135deg,#ffffffe6,#f8faffeb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:20px;box-shadow:0 4px 16px #8b9de11f;border:2px solid rgba(139,157,225,.15);transition:all .3s ease;display:flex;flex-direction:column;gap:.875rem}.forecast-card[data-v-4bd52d5b]:hover{transform:translateY(-4px);box-shadow:0 8px 24px #8b9de133;border-color:#8b9de14d}@media(max-width:768px){.forecast-card[data-v-4bd52d5b]{min-width:180px;max-width:180px;padding:1.25rem;gap:.5rem}}.forecast-date[data-v-4bd52d5b]{font-size:.8rem;font-weight:700;color:#3b82f6e6;text-align:center;text-transform:capitalize;padding-bottom:.5rem;border-bottom:2px solid rgba(139,157,225,.15)}@media(max-width:768px){.forecast-date[data-v-4bd52d5b]{font-size:.75rem}}.forecast-icon[data-v-4bd52d5b]{font-size:48px;text-align:center;line-height:1;filter:drop-shadow(0 2px 8px rgba(59,130,246,.2));margin:.5rem 0}@media(max-width:768px){.forecast-icon[data-v-4bd52d5b]{font-size:40px}}.forecast-temps[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:1rem;font-weight:700;margin:.5rem 0}@media(max-width:768px){.forecast-temps[data-v-4bd52d5b]{font-size:1rem}}.temp-max[data-v-4bd52d5b]{color:#fb923c}.temp-min[data-v-4bd52d5b]{color:#60a5fa}.temp-separator[data-v-4bd52d5b]{color:#667eea4d;font-weight:500}.forecast-detail[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;padding:.5rem .875rem;background:#8b9de114;border-radius:12px;font-size:.75rem}@media(max-width:768px){.forecast-detail[data-v-4bd52d5b]{padding:.25rem .5rem;font-size:.7rem}}.detail-icon[data-v-4bd52d5b]{font-size:18px}@media(max-width:768px){.detail-icon[data-v-4bd52d5b]{font-size:16px}}.detail-value[data-v-4bd52d5b]{font-weight:600;color:#2d3748}.wind-dir-label[data-v-4bd52d5b]{font-size:.7rem;text-transform:uppercase;opacity:.7}.forecast-uv[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .875rem;border-radius:12px;font-size:.75rem;font-weight:700;margin-top:.25rem}@media(max-width:768px){.forecast-uv[data-v-4bd52d5b]{padding:.25rem .5rem;font-size:.7rem}}.uv-icon[data-v-4bd52d5b]{width:14px;height:14px;flex-shrink:0}@media(max-width:768px){.uv-icon[data-v-4bd52d5b]{width:12px;height:12px}}@keyframes fadeIn-4bd52d5b{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chart-mobile-trigger[data-v-4bd52d5b]{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1.25rem;background:linear-gradient(135deg,#667eea14,#764ba214);border:2px solid rgba(139,157,225,.2);border-radius:12px;cursor:pointer;transition:all .3s ease}@media(min-width:481px){.chart-mobile-trigger[data-v-4bd52d5b]{display:none!important}}.chart-mobile-trigger[data-v-4bd52d5b]:active{transform:scale(.98);background:linear-gradient(135deg,#667eea26,#764ba226)}.chart-mobile-trigger .trigger-icon[data-v-4bd52d5b]{font-size:24px;margin-right:.5rem}.chart-mobile-trigger .trigger-text[data-v-4bd52d5b]{flex:1;font-size:.8rem;font-weight:700;color:#667eea;text-align:left}.chart-mobile-trigger .trigger-arrow[data-v-4bd52d5b]{font-size:28px;color:#667eea;font-weight:700}.chart-desktop-wrapper[data-v-4bd52d5b]{display:none}@media(min-width:481px){.chart-desktop-wrapper[data-v-4bd52d5b]{display:block!important}}
