.header-content{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;max-width:1400px;margin:0 auto;width:100%}.weather-header{background:linear-gradient(135deg,#1a1a2ef2,#0f0f1ef2);backdrop-filter:blur(20px);padding:6px 0;border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:1000;box-shadow:0 4px 20px #0006,0 0 40px #6464ff1a;display:flex;align-items:center}.update-notification{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#4caf50e6,#388e3ce6);border:1px solid rgba(76,175,80,.3);border-radius:20px;padding:.25rem .75rem;margin-right:1rem;animation:pulse 2s infinite;box-shadow:0 2px 10px #4caf504d}.update-info{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:.75rem}.update-badge{font-size:.875rem;animation:spin 2s linear infinite}.update-text{font-weight:600;color:#e8f5e8}.version-info{font-size:.7rem;opacity:.8;color:#c8e6c9}.update-actions{display:flex;align-items:center;gap:.25rem}.update-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.update-btn:hover{background:#ffffff4d;transform:translateY(-1px);box-shadow:0 2px 8px #fff3}.update-btn:active{transform:translateY(0)}.dismiss-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:.25rem .5rem;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .3s ease;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.dismiss-btn:hover{background:#fff3;color:#fff;transform:scale(1.1)}.dismiss-btn:active{transform:scale(.95)}.version-display{display:flex;align-items:center;color:#ffffffb3;font-size:.7rem;margin-right:1rem;padding:.25rem .5rem;background:#ffffff1a;border-radius:10px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.version-display:hover{background:#ffffff26;color:#ffffffe6}.version-text{font-family:Courier New,monospace;font-weight:500}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.9}}@media (max-width: 768px){.header-content{padding:0 1rem;flex-wrap:wrap;gap:.5rem}.header-right{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.update-notification{flex-direction:column;gap:.25rem;padding:.5rem;margin-right:.5rem;max-width:200px}.update-info{flex-direction:column;align-items:center;text-align:center}.update-actions{justify-content:center}.version-display{display:flex;font-size:.6rem;padding:.2rem .4rem;margin-right:.5rem;min-width:fit-content}.version-text{font-size:.55rem}}@media (max-width: 480px){.update-notification{margin-right:.25rem;padding:.25rem .5rem;max-width:180px}.update-text{font-size:.65rem}.version-info{font-size:.6rem}.update-btn{font-size:.6rem;padding:.2rem .5rem}.dismiss-btn{width:20px;height:20px;font-size:.7rem}.version-display{font-size:.55rem;padding:.15rem .3rem;margin-right:.25rem}.version-text{font-size:.5rem}}.header-left{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.header-left .logo{display:flex;align-items:center;gap:8px;color:#fff;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s ease;padding:8px 16px;border-radius:25px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);position:relative;overflow:hidden}.header-left .logo:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.header-left .logo:hover:before{left:100%}.header-left .logo:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;background:#ffffff26}.logo-text{color:#fff;font-size:1rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.location-display{display:flex;align-items:center;gap:8px;color:#fff;font-size:1.1rem;font-weight:500;background:#ffffff1a;padding:8px 12px;border-radius:25px;border:1px solid rgba(255,255,255,.2);transition:all .2s ease}.location-display:hover{background:#ffffff26;transform:translateY(-1px)}.location-icon{font-size:1.2rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.location-name{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.btn-sm{padding:10px 20px;font-size:13px;border-radius:25px;transition:all .3s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:600;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.btn-sm:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-sm:hover:before{left:100%}.btn-sm:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;background:#fff3;border-color:#ffffff4d}.btn-sm:active{transform:translateY(0);box-shadow:0 2px 8px #0003}.nav-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.nav-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.nav-btn:hover:before{left:100%}.nav-btn:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#ffffff4d;color:#fff}.nav-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0003}.nav-btn.active{background:#3498db4d;border-color:#3498db80;color:#3498db;box-shadow:0 0 15px #3498db4d}.nav-btn.active:hover{background:#3498db66;box-shadow:0 0 20px #3498db80}.refresh-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.refresh-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.refresh-btn:hover:before{left:100%}.refresh-btn:hover{animation:spin .5s ease;background:#2ecc7133;border-color:#2ecc7180;transform:translateY(-2px);box-shadow:0 4px 15px #2ecc714d}.location-btn{background:#3498db33;border:1px solid rgba(52,152,219,.4);color:#3498db;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.location-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(52,152,219,.3),transparent);transition:left .5s ease}.location-btn:hover:before{left:100%}.location-btn:hover{background:#3498db4d;border-color:#3498db99;color:#5dade2;transform:translateY(-2px);box-shadow:0 4px 15px #3498db66}.search-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:14px 18px;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.search-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.search-btn:hover:before{left:100%}.search-btn:hover{color:#fff;background:#fff3;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#ffffff4d}.mobile-menu-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:12px 24px;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.mobile-menu-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.mobile-menu-btn:hover:before{left:100%}.mobile-menu-btn:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#ffffff4d}.mobile-menu-btn:active{transform:translateY(0)}.locate-me-btn{background:#2ecc7133;border:1px solid rgba(46,204,113,.4);color:#2ecc71;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;text-decoration:none}.locate-me-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(46,204,113,.3),transparent);transition:left .5s ease}.locate-me-btn:hover:before{left:100%}.locate-me-btn:hover{background:#2ecc714d;border-color:#2ecc7199;color:#58d68d;transform:translateY(-2px);box-shadow:0 4px 15px #2ecc7166}.locate-me-btn.locating{animation:pulse 1.5s ease-in-out infinite;background:#f1c40f4d;border-color:#f1c40f99;color:#f1c40f}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.menu-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);z-index:2000;animation:fadeIn .3s ease}.menu-sidebar{position:fixed;top:0;right:0;width:300px;height:100%;background:#1a1a2efa;backdrop-filter:blur(10px);border-left:1px solid rgba(255,255,255,.1);box-shadow:-2px 0 10px #0000004d;animation:slideIn .3s ease;overflow-y:auto}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.menu-header h3{color:#fff;margin:0;font-size:1.25rem;font-weight:600}.menu-close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:5px;border-radius:5px;transition:background .2s ease}.menu-close-btn:hover{background:#ffffff1a}.menu-content{padding:20px}.menu-section{margin-bottom:30px}.menu-section h4{color:#ffffffb3;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin:0 0 15px}.menu-item{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;color:#fff;padding:12px 15px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;font-size:1rem}.menu-item:hover{background:#ffffff1a;transform:translate(5px)}.menu-icon{font-size:1.2rem;width:24px;text-align:center}.menu-footer{margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.menu-info p{color:#fff9;font-size:.875rem;margin:5px 0}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);z-index:3000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.modal-content{background:#1a1a2efa;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;box-shadow:0 10px 30px #00000080;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{color:#fff;margin:0;font-size:1.5rem;font-weight:600}.modal-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:5px;border-radius:5px;transition:background .2s ease}.modal-close:hover{background:#ffffff1a}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#fff;font-weight:500;margin-bottom:8px}.location-input{width:100%;padding:12px 15px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem;transition:all .2s ease}.location-input:focus{outline:none;border-color:#06c;background:#ffffff26}.location-input::placeholder{color:#ffffff80}.quick-locations{margin-top:20px}.quick-locations p{color:#ffffffb3;font-size:.875rem;margin-bottom:10px}.quick-location-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.quick-location-buttons button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.875rem}.quick-location-buttons button:hover{background:#fff3;transform:translateY(-1px)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid rgba(255,255,255,.1)}.search-container{position:relative;flex:1;max-width:400px;margin:0 20px}.search-form{width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:25px;overflow:hidden;transition:all .3s ease}.search-input-wrapper:hover{background:#ffffff26;border-color:#ffffff4d}.search-input-wrapper:focus-within{background:#ffffff26;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.search-input{flex:1;background:none;border:none;padding:12px 20px;font-size:.95rem;color:#fff;outline:none;width:100%}.search-input::placeholder{color:#fff9}.search-btn{background:none;border:none;padding:12px 15px;font-size:1.1rem;cursor:pointer;color:#fffc;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.search-btn:hover{color:#fff;background:#ffffff1a}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#1a1a2ef2;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:15px;margin-top:8px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 10px 30px #0000004d;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid rgba(255,255,255,.1)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#ffffff1a}.suggestion-icon{font-size:.9rem;opacity:.7}.suggestion-text{color:#fff;font-size:.95rem;font-weight:500}.search-suggestions::-webkit-scrollbar{width:6px}.search-suggestions::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.search-suggestions::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px;transition:background .2s ease}.search-suggestions::-webkit-scrollbar-thumb:hover{background:#ffffff80}.header-center{display:flex;align-items:center;gap:1.5rem;flex:1 1 auto;justify-content:center;max-width:600px}.header-right{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.header-nav{display:flex;align-items:center;gap:.75rem}.locate-me-btn,.location-btn,.menu-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 16px;border-radius:25px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:flex;align-items:center;gap:6px;text-decoration:none;min-height:40px}.locate-me-btn:before,.location-btn:before,.menu-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.locate-me-btn:hover:before,.location-btn:hover:before,.menu-toggle:hover:before{left:100%}.locate-me-btn:hover,.location-btn:hover,.menu-toggle:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#ffffff4d;color:#fff;text-decoration:none}.locate-me-btn.locating{animation:pulse 1.5s infinite;background:#3498db4d;border-color:#3498db80}.menu-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 16px;border-radius:25px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;text-decoration:none;min-height:40px;min-width:40px}.menu-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.menu-toggle:hover:before{left:100%}.menu-toggle:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#ffffff4d;color:#fff;text-decoration:none}.menu-icon{font-size:1.2rem;line-height:1}.location-display{display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0}@media (max-width: 1024px){.search-container{max-width:300px;margin:0 15px}.search-input{padding:10px 15px;font-size:.9rem}.search-btn{padding:10px 12px;font-size:1rem}.suggestion-item{padding:10px 15px}.suggestion-text{font-size:.9rem}}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1a1a2efa,#0f0f1efa);backdrop-filter:blur(25px);border-top:2px solid rgba(255,255,255,.15);z-index:9999;padding:12px 0 16px;box-shadow:0 -8px 32px #00000080,0 -4px 16px #6464ff33,inset 0 1px #ffffff1a;display:flex;justify-content:space-around;align-items:center;gap:4px;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:linear-gradient(135deg,#ffffff26,#ffffff0d);border:2px solid rgba(255,255,255,.25);color:#fff;padding:10px 6px;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);font-size:.7rem;border-radius:16px;flex:1;max-width:60px;position:relative;overflow:hidden;text-decoration:none;text-shadow:0 1px 2px rgba(0,0,0,.3);min-height:60px;min-width:50px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-nav-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),rgba(100,200,255,.2),transparent);transition:left .6s ease}.mobile-nav-btn:hover:before{left:100%}.mobile-nav-btn:hover,.mobile-nav-btn:active{background:linear-gradient(135deg,#ffffff40,#ffffff26);transform:translateY(-4px) scale(1.02);box-shadow:0 6px 20px #0006,0 0 15px #64c8ff4d,inset 0 1px #fff3;border-color:#fff6;color:#fff;text-decoration:none}.mobile-nav-btn:active{transform:translateY(-2px) scale(1.01);box-shadow:0 3px 12px #0000004d,0 0 10px #64c8ff33}.mobile-nav-btn.locating{animation:mobilePulse 2s ease-in-out infinite;background:linear-gradient(135deg,#3498db66,#2980b94d);border-color:#3498db99;box-shadow:0 0 20px #3498db66,inset 0 0 12px #3498db33}.mobile-nav-icon{font-size:1.3rem;line-height:1;transition:all .3s cubic-bezier(.175,.885,.32,1.275);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.mobile-nav-btn:hover .mobile-nav-icon{transform:scale(1.2) rotate(3deg);filter:drop-shadow(0 3px 6px rgba(0,0,0,.4))}.mobile-nav-label{font-size:.6rem;font-weight:700;text-align:center;line-height:1;text-transform:uppercase;letter-spacing:.6px;opacity:.9;transition:all .3s ease}.mobile-nav-btn:hover .mobile-nav-label{opacity:1;transform:translateY(-1px)}@keyframes mobilePulse{0%,to{transform:scale(1);box-shadow:0 0 20px #3498db66,inset 0 0 12px #3498db33}50%{transform:scale(1.05);box-shadow:0 0 30px #3498db99,inset 0 0 16px #3498db4d}}.mobile-nav-btn.active{background:linear-gradient(135deg,#3498db66,#2980b94d);border-color:#3498db99;box-shadow:0 0 18px #3498db4d,inset 0 0 10px #3498db33}.location-search-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.location-search-modal{background:linear-gradient(135deg,#1a1a2efa,#0f0f1efa);backdrop-filter:blur(25px);border:2px solid rgba(255,255,255,.15);border-radius:20px;padding:2rem;max-width:500px;width:100%;box-shadow:0 20px 60px #00000080,0 0 40px #6464ff33,inset 0 1px #ffffff1a;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.location-search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;color:#fff}.location-search-header h3{margin:0;font-size:1.5rem;font-weight:600}.close-search-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.2rem}.close-search-btn:hover{background:#fff3;transform:scale(1.1)}.location-search-content{color:#fff}.location-search-message{margin-bottom:1.5rem;opacity:.9;line-height:1.5}.location-search-form{margin-bottom:1.5rem}.location-search-input-wrapper{display:flex;gap:.5rem}.location-search-input{flex:1;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;padding:12px 16px;border-radius:12px;font-size:1rem;transition:all .3s ease}.location-search-input::placeholder{color:#fff9}.location-search-input:focus{outline:none;border-color:#3498db99;background:#ffffff26;box-shadow:0 0 20px #3498db4d}.location-search-submit-btn{background:linear-gradient(135deg,#3498db66,#2980b94d);border:2px solid rgba(52,152,219,.6);color:#fff;padding:12px 16px;border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:1.2rem;min-width:50px}.location-search-submit-btn:hover{background:linear-gradient(135deg,#3498db99,#2980b980);transform:translateY(-2px);box-shadow:0 4px 15px #3498db66}.location-search-suggestions{margin-top:1.5rem}.suggestions-title{margin:0 0 1rem;font-size:.9rem;opacity:.8;font-weight:600}.quick-city-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.quick-city-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.85rem;text-align:center}.quick-city-btn:hover{background:#fff3;transform:translateY(-1px);border-color:#ffffff4d}@media (max-width: 768px){.location-search-modal{padding:1.5rem;margin:20px}.location-search-header h3{font-size:1.25rem}.quick-city-buttons{grid-template-columns:repeat(2,1fr)}.quick-city-btn{font-size:.8rem;padding:10px 8px}}.mobile-nav-btn.active{background:linear-gradient(135deg,#3498db66,#2980b94d);border-color:#3498db99;box-shadow:0 0 20px #3498db4d,inset 0 0 10px #3498db33}@media (min-width: 1025px){.header-nav{display:flex}.mobile-bottom-nav{display:none}.header-right{display:flex}}@media (max-width: 1024px){.weather-header{display:none}.mobile-bottom-nav{display:flex;justify-content:space-around;align-items:center}.header-right{display:none}.search-container{width:100%;max-width:250px}.search-suggestions{max-height:150px}.location-display{font-size:.8rem;padding:6px 10px}.logo-text{font-size:1.125rem}.location-icon{font-size:1rem}.menu-sidebar{width:280px}.menu-item{padding:14px 16px;font-size:14px}.modal-content{width:95%;max-width:400px}}@media (max-width: 480px){.weather-header{padding:3px 0}.header-nav,.header-right{gap:6px}.mobile-bottom-nav{display:flex;justify-content:space-around;align-items:center}.mobile-nav-btn{padding:10px 6px;max-width:60px;border-radius:16px}.mobile-nav-icon{font-size:1.2rem}.mobile-nav-label{font-size:.6rem}.search-container{max-width:250px}.search-suggestions{max-height:150px}.location-display{font-size:.8rem;padding:6px 10px}.logo-text{font-size:1.125rem}.location-icon{font-size:1rem}.menu-sidebar{width:260px}.menu-item{padding:12px 14px;font-size:13px}.modal-content{width:98%;max-width:350px}.modal-header h3{font-size:1.25rem}.modal-body{padding:15px}.quick-location-buttons{grid-template-columns:repeat(2,1fr);gap:8px}}@media (min-width: 769px){.mobile-app-nav{display:none!important}.desktop-nav{display:flex;justify-content:center;gap:2rem;background:#ffffff0d;backdrop-filter:blur(10px);border-radius:15px;max-width:600px;margin:0 auto;padding:1rem 0}.desktop-nav-item{display:flex;flex-direction:column;align-items:center;gap:8px;color:#fffc;padding:12px 16px;border-radius:16px;backdrop-filter:blur(10px);border:1px solid transparent;font-weight:500;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;text-decoration:none}.desktop-nav-item:hover{color:#fff;transform:translateY(-6px) scale(1.08);background:#ffffff1a;border-color:#fff3;box-shadow:0 12px 35px #0006}.desktop-nav-item.active{color:#3498db;background:#3498db26;border-color:#3498db4d;box-shadow:0 8px 25px #3498db4d}.desktop-nav-icon{font-size:2rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.desktop-nav-item:hover .desktop-nav-icon{transform:scale(1.3) rotate(15deg)}.desktop-nav-item.active .desktop-nav-icon{animation:desktopIconBounce 2s ease-in-out infinite}.desktop-nav-label{font-size:.85rem;font-weight:500;opacity:.9;transition:opacity .3s ease}.desktop-nav-item:hover .desktop-nav-label{opacity:1}.desktop-nav-item .shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .8s ease}.desktop-nav-item:hover .shimmer{left:100%}.desktop-nav-item .glow{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at center,rgba(52,152,219,.2) 0%,transparent 70%);opacity:0;transition:opacity .3s ease;border-radius:16px}.desktop-nav-item:hover .glow{opacity:1}.desktop-nav-item.active .glow{background:radial-gradient(circle at center,rgba(52,152,219,.3) 0%,transparent 60%);opacity:1}@keyframes desktopIconBounce{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-8px) scale(1.15)}50%{transform:translateY(-4px) scale(1.08)}75%{transform:translateY(-8px) scale(1.15)}}.desktop-nav-item:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(52,152,219,.6) 0%,rgba(52,152,219,.3) 50%,transparent 100%);border-radius:50%;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease,opacity .6s ease;opacity:0}.desktop-nav-item:active:after{width:100px;height:100px;opacity:1}.desktop-nav-item:active{transform:scale(.95)}.mobile-menu-btn{display:none}}.weather-app{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed;overflow-x:hidden}.weather-content{position:relative;min-height:calc(100vh - 40px);padding:2rem;padding-bottom:100px;max-width:100%;overflow-x:hidden}@media (max-width: 1024px){.weather-content{padding:.5rem;padding-bottom:80px;min-height:100vh}.weather-content>*{max-width:100%;overflow-x:hidden}}@media (max-width: 480px){.weather-content{padding:.25rem;padding-bottom:70px}.weather-content{font-size:12px}input,select,textarea{font-size:16px}}@media (max-width: 360px){.weather-content{padding:.1rem;padding-bottom:65px}}.spc-outlook{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border-radius:12px;padding:1.5rem;margin:1.5rem 0;box-shadow:0 8px 32px #0006;border:1px solid rgba(255,255,255,.1);max-width:100%;overflow:hidden}@media (max-width: 1024px){.spc-outlook{padding:1rem;margin:1rem 0;border-radius:8px}}@media (max-width: 480px){.spc-outlook{padding:.75rem;margin:.75rem 0;border-radius:6px}}.spc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.15);backdrop-filter:blur(10px)}.spc-header h2{color:#fff;font-size:1.8rem;margin:0;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.spc-header .data-source{color:#64b5f6;font-size:.85rem;margin:0;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.spc-content{display:flex;flex-direction:column;gap:1.5rem}.spc-risk-levels{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.risk-category{text-align:center;padding:1rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.08);transition:all .3s ease}.risk-category:hover{background:#ffffff0f;transform:translateY(-1px)}.risk-category h3{color:#b3b3b3;font-size:.9rem;margin:0 0 .8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.risk-indicator-container{position:relative;width:80px;height:80px;margin:0 auto;display:flex;align-items:center;justify-content:center}.risk-circle{width:100%;height:100%;transform:rotate(-90deg)}.risk-progress{transition:stroke-dasharray .5s ease;animation:fillProgress 1s ease-out}.risk-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.6px;color:#fff;text-align:center;line-height:1.1;text-shadow:0 1px 2px rgba(0,0,0,.5);pointer-events:none}.risk-indicator-container:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 5px 15px #0000004d;transition:all .3s ease}@keyframes fillProgress{0%{stroke-dasharray:0 565}to{stroke-dasharray:inherit}}.spc-details{display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:start}.spc-forecast{background:#ffffff08;padding:1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.spc-forecast h4{color:#fff;font-size:1.2rem;margin:0 0 .8rem;font-weight:600}.spc-forecast p{color:#ccc;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.spc-updated{text-align:right;margin-top:.8rem}.spc-updated small{color:#888;font-size:.75rem;opacity:.8;font-weight:500}.spc-map-link{display:flex;justify-content:center;align-items:center}.spc-link-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;text-decoration:none;padding:.8rem 1.5rem;border-radius:6px;font-weight:600;font-size:.9rem;transition:all .3s ease;box-shadow:0 3px 10px #1976d24d;border:1px solid rgba(255,255,255,.1)}.spc-link-btn:hover{background:linear-gradient(135deg,#1565c0,#0d47a1);transform:translateY(-1px);box-shadow:0 5px 15px #1976d266;color:#fff;text-decoration:none}.loading-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-content{text-align:center;color:#fff;background:#1a1a2ef2;padding:3rem;border-radius:20px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 60px #0000004d}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.forecast-section{background:#ffffff0d;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:2rem;margin:2rem 0}.forecast-section h3{color:#fff;margin:0 0 1.5rem;font-size:1.8rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.forecast-item{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.forecast-item:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003;background:#ffffff26}.forecast-period{color:#ffffffe6;font-weight:600;font-size:.9rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.forecast-icon{font-size:2.5rem;margin:.5rem 0;line-height:1}.forecast-temp{color:#fff;font-weight:700;font-size:1.5rem;margin:.5rem 0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.forecast-high{font-size:1.8rem}.forecast-unit{font-size:1rem;color:#fffc;margin-left:.25rem}.forecast-desc{color:#fffc;font-size:.85rem;margin-top:.5rem;line-height:1.4}@media (max-width: 768px){.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.forecast-item{padding:1rem}.forecast-temp{font-size:1.3rem}.forecast-high{font-size:1.5rem}}@media (max-width: 480px){.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.forecast-item{padding:.75rem}.forecast-icon{font-size:2rem}.forecast-temp{font-size:1.2rem}.forecast-high{font-size:1.4rem}}.error-notification{position:fixed;top:100px;right:20px;background:#e74c3cf2;color:#fff;padding:1.5rem;border-radius:15px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 10px 30px #e74c3c4d;z-index:1001;max-width:400px}.error-content{display:flex;align-items:flex-start;gap:1rem}.error-icon{font-size:2rem;flex-shrink:0}.error-message h4{margin:0 0 .5rem;font-size:1.1rem}.error-message p{margin:0 0 1rem;line-height:1.5}.retry-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #3498db66}.nws-weather-display{max-width:1200px;margin:0 auto}.nws-header{text-align:center;margin-bottom:2rem;background:#ffffff1a;backdrop-filter:blur(10px);padding:2rem;border-radius:20px;border:1px solid rgba(255,255,255,.2)}.nws-header h2{color:#fff;margin:0 0 .5rem;font-size:2rem;font-weight:700}.data-source{color:#fffc;font-size:1.1rem;margin:0}.current-weather{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:2rem;margin-bottom:2rem}.current-weather-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.current-weather-header h3{color:#fff;margin:0;font-size:1.5rem;font-weight:600;flex:1}.weather-icon-large{font-size:4rem;text-align:center;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));color:#ffffffe6}.weather-main{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:2rem}.temperature{text-align:center;flex:1;min-width:200px}.temp-value{display:block;font-size:3rem;font-weight:700;line-height:1;text-shadow:0 4px 20px rgba(0,0,0,.3);transition:color .3s ease}.temp-desc{display:block;color:#ffffffe6;font-size:1.2rem;margin-top:.5rem;text-transform:capitalize}.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;flex:2}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.detail-item:hover{background:#ffffff1a;transform:translateY(-2px)}.detail-label{color:#ffffffb3;font-weight:600;font-size:.9rem}.detail-value{color:#fff;font-weight:700;font-size:1rem}.nws-info{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:2rem;margin-bottom:2rem}.nws-info h4,.forecast-section h4,.alerts-section h4{color:#fff;margin:0 0 1.5rem;font-size:1.3rem;font-weight:600}.office-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.office-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.office-item:hover{background:#ffffff1a}.office-label{color:#ffffffb3;font-weight:600;font-size:.9rem}.office-value{color:#fff;font-weight:700;font-size:1rem;text-transform:uppercase}.forecast-section{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:2rem;margin-bottom:2rem}.forecast-section h4{color:#fff;margin:0 0 1.5rem;font-size:1.3rem;font-weight:600}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.forecast-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem 1rem;text-align:center;transition:all .3s ease}.forecast-item:hover{background:#ffffff1a;transform:translateY(-2px)}.forecast-period{color:#ffffffe6;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.forecast-icon{font-size:2rem;margin:.5rem 0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));color:#ffffffe6}.forecast-temp{margin:.5rem 0}.forecast-high{color:#fff;font-size:1.5rem;font-weight:700}.forecast-unit{color:#ffffffb3;font-size:.9rem;margin-left:.25rem}.forecast-desc{color:#fffc;font-size:.8rem;line-height:1.3;margin-top:.5rem}.alerts-section{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px #0000004d}.alerts-header{margin-bottom:2rem}.alerts-header h4{color:#fff;margin:0 0 1rem;font-size:1.3rem;font-weight:600;flex-wrap:wrap}.alert-summary{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.alert-count{background:#fff3;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;border:1px solid rgba(255,255,255,.3)}.alert-count.extreme{background:#dc2626cc;border-color:#dc262680;animation:pulse 2s ease-in-out infinite}.alert-count.severe{background:#ea580ccc;border-color:#ea580c80}.alert-count.moderate{background:#f59e0bcc;border-color:#f59e0b80}.alert-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.alert-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0003}.alert-item.expired{opacity:.6;background:#ffffff05}.alert-item.expired:before{content:"EXPIRED";position:absolute;top:1rem;right:1rem;background:#6c757dcc;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase}.alert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.alert-title{display:flex;align-items:flex-start;gap:.5rem;flex:1}.alert-title-text{display:flex;flex-direction:column;gap:.25rem}.alert-icon{font-size:1.5rem;flex-shrink:0;color:#ffffffe6;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.alert-event{color:#fff;font-weight:700;font-size:1.1rem;line-height:1.3}.alert-urgency{color:#ffffffb3;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05rem}.alert-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.alert-severity{color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.05rem;box-shadow:0 2px 8px #0003}.alert-expires{color:#ffffffb3;font-size:.8rem;font-style:italic}.alert-expires.expired{color:#fff6;text-decoration:line-through}.alert-description{color:#ffffffe6;line-height:1.6;margin-bottom:1rem;font-size:.95rem}.alert-details{display:grid;grid-template-columns:1fr;gap:.75rem;margin-top:1rem}.alert-areas,.alert-instructions,.alert-contact,.alert-web{color:#fffc;font-size:.9rem;line-height:1.4}.alert-areas strong,.alert-instructions strong,.alert-contact strong,.alert-web strong{color:#fff;margin-right:.5rem}.alert-instructions{background:#3498db1a;border:1px solid rgba(52,152,219,.3);border-radius:8px;padding:1rem;margin-top:.5rem}.alert-instructions strong{color:#3498db}.alert-contact{display:flex;align-items:center;gap:.5rem}.alert-web a{color:#3498db;text-decoration:none;font-weight:600;transition:all .3s ease}.alert-web a:hover{color:#2980b9;text-decoration:underline}.update-info{text-align:center;color:#ffffffb3;font-size:.9rem;padding:1.5rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.update-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.update-time,.data-source{color:#fffc}.update-actions{display:flex;justify-content:center}.refresh-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem}.refresh-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #3498db66}@media (max-width: 768px){.weather-content{padding:1rem}.loading-content{padding:2rem;margin:1rem}.error-notification{right:10px;left:10px;max-width:none;top:60px}.nws-header{padding:1.5rem}.nws-header h2{font-size:1.5rem}.current-weather,.nws-info,.alerts-section,.forecast-section{padding:1.5rem;margin-bottom:1.5rem}.current-weather-header,.weather-main{flex-direction:column;text-align:center}.temp-value{font-size:2.5rem}.weather-details,.office-details{grid-template-columns:1fr}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.alert-header{flex-direction:column;align-items:flex-start}.update-header{flex-direction:column;text-align:center}}@media (max-width: 480px){.weather-content{padding:.5rem}.loading-content{padding:1.5rem}.nws-header,.current-weather,.nws-info,.alerts-section,.forecast-section{padding:1rem}.temp-value{font-size:2rem}.temp-desc{font-size:1rem}.detail-item,.office-item{padding:.75rem}.forecast-item{padding:1rem .75rem}.forecast-icon{font-size:1.5rem}.alert-item{padding:1rem}}.connection-status{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem 1rem;background:#ffffff1a;border-radius:20px;font-size:.875rem}.status-indicator{width:8px;height:8px;border-radius:50%;background:#666;animation:pulse 2s infinite}.status-indicator.connecting{background:#f59e0b;animation:pulse 1s infinite}.status-indicator.connected{background:#10b981;animation:none}.status-indicator.locating{background:#3b82f6;animation:pulse 1.5s infinite}.status-indicator.error{background:#ef4444;animation:pulse 1s infinite}.status-indicator.checking{background:#8b5cf6;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-notification{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:1rem;border-radius:12px;margin:1rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 20px #ef44444d;animation:slideInDown .3s ease-out}.error-content h4{margin:0 0 .5rem;font-size:1rem;font-weight:600}.error-content p{margin:0 0 1rem;font-size:.875rem;opacity:.9}.error-actions{display:flex;gap:.5rem}.btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:#fff3;color:#fff}.btn-primary:hover{background:#ffffff4d;transform:translateY(-1px)}.btn-secondary{background:#ffffff1a;color:#fff}.btn-secondary:hover{background:#fff3}.notification-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.notification-close:hover{background:#ffffff1a}.weather-alerts{margin:1rem;display:flex;flex-direction:column;gap:.5rem}.alert-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;animation:slideInDown .3s ease-out}.alert-high{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.alert-medium{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.alert-low{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.alert-message{flex:1;font-size:.875rem;font-weight:500}.alert-close{background:none;border:none;color:currentColor;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease;opacity:.7}.alert-close:hover{opacity:1;background:#ffffff1a}.simulated-data-banner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;margin:1rem;border-radius:12px;box-shadow:0 4px 20px #f59e0b4d;animation:slideInDown .3s ease-out}.banner-content{display:flex;align-items:center;justify-content:space-between;padding:1rem}.banner-icon{font-size:1.2rem;margin-right:.5rem}.banner-text{flex:1;font-weight:500}.banner-retry-btn{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.banner-retry-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.weather-status-bar{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:12px;margin:1rem;backdrop-filter:blur(10px)}.status-left{display:flex;align-items:center;gap:1rem}.data-quality{font-size:.875rem;font-weight:500;color:#10b981}.last-update{font-size:.875rem;color:#6b7280}.status-right{display:flex;align-items:center;gap:.5rem}.auto-refresh-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.auto-refresh-toggle.active{background:#10b98133;border-color:#10b98180;color:#10b981}.auto-refresh-toggle:hover{background:#fff3;transform:translateY(-1px)}.refresh-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.refresh-btn:hover{background:#fff3;transform:translateY(-1px)}.refresh-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:#ffffff0d;border-radius:8px;margin:1rem;color:#6b7280;font-size:.875rem}.refresh-spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes slideInDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.weather-status-bar{flex-direction:column;gap:1rem;align-items:stretch}.status-left,.status-right{justify-content:center}.error-notification,.alert-banner,.simulated-data-banner{margin:.5rem}.banner-content{flex-direction:column;gap:.75rem;text-align:center}.error-actions{justify-content:center}}@media (prefers-color-scheme: dark){.weather-status-bar{background:#0000004d}.last-update{color:#9ca3af}.refresh-indicator{background:#0003;color:#9ca3af}}.loading-overlay{background:#000c;backdrop-filter:blur(10px)}.loading-content{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000004d}.loading-progress{margin-top:1rem;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:2px;transition:width .3s ease}.weather-alerts,.weather-status-bar,.error-notification{transform:translateZ(0);will-change:transform}.weather-app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed}.loading-container{text-align:center;color:#fff;max-width:400px;padding:40px}.loading-icon{font-size:4rem;margin-bottom:20px;animation:spin 2s linear infinite}.loading-container h2{font-size:2rem;margin-bottom:30px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;margin:0 auto 20px;animation:spin 1s linear infinite}.loading-container p{color:#fffc;font-size:1.1rem}.weather-app-error{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#2c3e50,#34495e);background-attachment:fixed}.error-container{text-align:center;color:#fff;max-width:400px;padding:40px;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:20px;border:1px solid rgba(255,255,255,.2)}.error-icon{font-size:4rem;margin-bottom:20px}.error-container h2{font-size:1.8rem;margin-bottom:15px;font-weight:600}.error-container p{color:#fffc;margin-bottom:25px;line-height:1.6}.retry-button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 30px;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #3498db4d}.retry-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.retry-button:active{transform:translateY(0)}.refresh-indicator{position:fixed;top:80px;right:20px;background:#000c;color:#fff;padding:12px 20px;border-radius:25px;display:flex;align-items:center;gap:10px;z-index:1000;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);animation:slideInRight .3s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.refresh-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.refresh-indicator span{font-size:.9rem;font-weight:500}.weather-footer{background:#0000004d;backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.1);padding:40px 0 20px;margin-top:60px}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-bottom:30px}.footer-section h4{color:#fff;font-size:1.1rem;font-weight:600;margin-bottom:15px;text-transform:uppercase;letter-spacing:1px}.footer-section p{color:#ffffffb3;font-size:.9rem;line-height:1.6;margin-bottom:8px}.refresh-link{background:none;border:none;color:#3498db;font-size:.9rem;cursor:pointer;text-decoration:underline;transition:color .3s ease}.refresh-link:hover{color:#2980b9}.footer-bottom{padding-top:20px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.footer-bottom p{color:#fff9;font-size:.8rem;margin:5px 0}.weather-app{animation:fadeIn .5s ease}@media (max-width: 768px){.loading-container,.error-container{padding:30px 20px;margin:20px}.loading-icon,.error-icon{font-size:3rem}.loading-container h2,.error-container h2{font-size:1.5rem}.refresh-indicator{top:70px;right:10px;padding:10px 15px}.footer-content{grid-template-columns:1fr;gap:30px}.weather-footer{padding:30px 0 15px;margin-top:40px}}@media (max-width: 480px){.loading-container,.error-container{padding:20px 15px;margin:10px}.loading-icon,.error-icon{font-size:2.5rem}.loading-container h2,.error-container h2{font-size:1.3rem}.loading-spinner{width:40px;height:40px}.refresh-indicator{top:60px;right:5px;padding:8px 12px;font-size:.8rem}.refresh-spinner{width:16px;height:16px}.weather-footer{padding:20px 0 10px;margin-top:30px}.footer-section h4{font-size:1rem}.footer-section p{font-size:.8rem}}.notification-controls{margin:1rem 0;padding:0 1rem}.notification-status{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;text-align:center;white-space:nowrap}.status-badge.granted{background:#22c55e33;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.status-badge.denied{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.status-badge.default{background:#fbbf2433;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.enable-notifications-btn,.test-notification-btn,.clear-notifications-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .3s ease;white-space:nowrap}.enable-notifications-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f64d}.enable-notifications-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.notification-actions{display:flex;gap:.5rem;align-items:center}.test-notification-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.test-notification-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.clear-notifications-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.clear-notifications-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.active-alerts-indicator{margin-left:auto}.alert-count{background:#ef444433;color:#fca5a5;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;border:1px solid rgba(239,68,68,.3);animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@media (max-width: 768px){.notification-controls{margin:.5rem 0;padding:0 .5rem}.notification-status{flex-direction:column;align-items:stretch;gap:.75rem}.notification-actions{justify-content:center;flex-wrap:wrap;gap:.5rem}.active-alerts-indicator{margin-left:0;text-align:center}.enable-notifications-btn,.test-notification-btn,.clear-notifications-btn{justify-content:center;flex:1;min-width:120px}}@media (max-width: 480px){.notification-status{padding:.75rem}.enable-notifications-btn,.test-notification-btn,.clear-notifications-btn{padding:.4rem .8rem}.enable-notifications-btn,.test-notification-btn,.clear-notifications-btn{font-size:.8rem;padding:.4rem .8rem}.error-notification{top:50px;right:5px;left:5px;padding:.75rem}.error-content h4{font-size:.9rem}.error-content p{font-size:.8rem}.alert-count{font-size:.8rem;padding:.4rem .8rem}}.home-page{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed;overflow-x:hidden}.hero-section{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem;padding-bottom:120px}.hero-content{max-width:800px;max-width:100%;overflow-x:hidden}.hero-title{font-size:4rem;font-weight:700;color:#fff;margin-bottom:1rem;text-shadow:0 4px 8px rgba(0,0,0,.3);font-size:clamp(2rem,8vw,4rem);line-height:1.1}.hero-subtitle{font-size:1.5rem;color:#ffffffe6;margin-bottom:2rem;font-size:clamp(1rem,4vw,1.5rem)}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;flex-direction:row;gap:.75rem}.hero-btn{padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .3s ease;display:inline-block;min-height:48px;min-width:120px;-webkit-tap-highlight-color:transparent;padding:.875rem 1.5rem;font-size:clamp(.9rem,3vw,1.1rem)}.hero-btn.primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;box-shadow:0 4px 15px #3498db4d}.hero-btn.primary:hover,.hero-btn.primary:active{transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.hero-btn.secondary{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3);backdrop-filter:blur(10px)}.hero-btn.secondary:hover,.hero-btn.secondary:active{background:#fff3;transform:translateY(-2px)}.features-section{padding:4rem 2rem;background:#ffffff0d;backdrop-filter:blur(10px);padding:3rem 1rem;padding-bottom:120px}.section-title{text-align:center;font-size:2.5rem;color:#fff;margin-bottom:3rem;text-shadow:0 2px 4px rgba(0,0,0,.3);font-size:clamp(1.5rem,6vw,2.5rem);margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;padding:0 1rem}.feature-card{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);padding:2rem;text-align:center;transition:all .3s ease;padding:1.5rem;border-radius:12px;-webkit-tap-highlight-color:transparent}.feature-card:hover,.feature-card:active{transform:translateY(-5px);box-shadow:0 10px 30px #0003;background:#ffffff26}.feature-icon{font-size:3rem;margin-bottom:1rem;font-size:clamp(2rem,6vw,3rem)}.feature-card h3{color:#fff;font-size:1.5rem;margin-bottom:1rem;font-size:clamp(1.1rem,4vw,1.5rem)}.feature-card p{color:#fffc;line-height:1.6;font-size:clamp(.9rem,3vw,1rem)}.cta-section{padding:4rem 2rem;text-align:center;background:#ffffff0d;padding:3rem 1rem;padding-bottom:120px}.cta-section h2{color:#fff;font-size:2rem;margin-bottom:2rem;font-size:clamp(1.3rem,5vw,2rem);margin-bottom:1.5rem}.cta-btn{display:inline-block;padding:1rem 3rem;background:linear-gradient(135deg,#27ae60,#229954);color:#fff;text-decoration:none;border-radius:50px;font-weight:600;font-size:1.1rem;transition:all .3s ease;box-shadow:0 4px 15px #27ae604d;min-height:48px;-webkit-tap-highlight-color:transparent;padding:.875rem 2rem;font-size:clamp(.9rem,3vw,1.1rem)}.cta-btn:hover,.cta-btn:active{transform:translateY(-2px);box-shadow:0 6px 20px #27ae6066}@media (max-width: 1024px){.hero-section{padding:1.5rem;padding-bottom:120px}.hero-buttons{gap:.75rem}.features-section,.cta-section{padding:2.5rem 1rem;padding-bottom:120px}}@media (max-width: 768px){.hero-section{padding:1rem;padding-bottom:100px;min-height:50vh}.hero-buttons{flex-direction:column;align-items:center;gap:1rem}.hero-btn{width:200px;max-width:90%}.features-grid{grid-template-columns:1fr;gap:1.25rem;padding:0 .5rem}.feature-card{padding:1.25rem}.features-section,.cta-section{padding:2rem .75rem;padding-bottom:100px}}@media (max-width: 480px){.hero-section{padding:.75rem;padding-bottom:90px;min-height:45vh}.hero-buttons{gap:.75rem}.hero-btn{width:180px;padding:.75rem 1.25rem}.features-grid{gap:1rem;padding:0 .25rem}.feature-card{padding:1rem}.features-section,.cta-section{padding:1.5rem .5rem;padding-bottom:90px}.cta-btn{width:180px;padding:.75rem 1.5rem}}@media (max-width: 360px){.hero-section{padding:.5rem;padding-bottom:85px}.hero-btn{width:160px;padding:.625rem 1rem}.feature-card{padding:.875rem}.cta-btn{width:160px;padding:.625rem 1.25rem}}.hourly-forecast{padding:30px 0}.hourly-header{text-align:center;margin-bottom:30px}.hourly-subtitle{color:#ffffffb3;font-size:1rem;font-weight:400}.hourly-scroll-container{position:relative;margin:0 -20px;padding:0 20px}.hourly-scroll{overflow-x:auto;padding:10px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) rgba(255,255,255,.1)}.hourly-items{display:flex;gap:16px;min-width:max-content;padding:0 10px}.hourly-item{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:16px;padding:20px;text-align:center;min-width:140px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.hourly-item:hover{background:#ffffff26;transform:translateY(-4px);box-shadow:0 12px 30px #0003}.hourly-item.current-hour{background:#ffa50033;border-color:#ffa50066;box-shadow:0 0 20px #ffa5004d}.hourly-item.selected{background:#0066cc4d;border-color:#0066cc80;transform:translateY(-4px);box-shadow:0 12px 30px #0066cc4d}.now-badge{position:absolute;top:8px;right:8px;background:#ffa500e6;color:#fff;font-size:.7rem;font-weight:600;padding:4px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.hourly-time{font-size:1rem;color:#ffffffe6;margin-bottom:12px;font-weight:600}.hourly-icon{font-size:2.5rem;margin:12px 0;animation:float 3s ease-in-out infinite}.hourly-temp{font-size:1.5rem;font-weight:600;color:#fff;margin:12px 0;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.hourly-condition{font-size:.875rem;color:#fffc;margin:8px 0;text-transform:capitalize;font-weight:500}.hourly-details{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.hourly-rain,.hourly-wind{font-size:.75rem;color:#ffffffb3;display:flex;align-items:center;justify-content:center;gap:4px}.hourly-expanded{position:absolute;top:100%;left:0;right:0;background:#0066ccf2;backdrop-filter:blur(10px);border-radius:0 0 16px 16px;padding:20px;margin-top:2px;z-index:10;box-shadow:0 8px 25px #0000004d;border:1px solid rgba(0,102,204,.5);border-top:none}.expanded-details{text-align:left}.expanded-details .detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.875rem;color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.expanded-details .detail-row:last-child{border-bottom:none}.selected-hour-summary{background:#06c3;backdrop-filter:blur(10px);border-radius:16px;padding:20px;margin-top:30px;border:1px solid rgba(0,102,204,.3)}.summary-content h3{color:#fff;font-size:1.25rem;font-weight:600;margin-bottom:12px}.summary-content p{color:#ffffffe6;line-height:1.6;font-size:1rem}.hourly-scroll::-webkit-scrollbar{height:8px}.hourly-scroll::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.hourly-scroll::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px;transition:background .2s ease}.hourly-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff80}.weather-alert-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(5px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.weather-alert-popup{background:#1a1a2ef2;backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 60px #00000080;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.alert-popup-header{display:flex;justify-content:space-between;align-items:center;padding:25px 30px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.alert-popup-header h3{color:#fff;font-size:1.5rem;font-weight:600;margin:0}.alert-popup-close{background:none;border:none;color:#ffffffb3;font-size:1.5rem;cursor:pointer;padding:5px;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.alert-popup-close:hover{background:#ffffff1a;color:#fff}.alert-popup-content{padding:20px 30px;max-height:50vh;overflow-y:auto}.alert-item{display:flex;align-items:flex-start;gap:20px;padding:20px;margin-bottom:15px;border-radius:15px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.alert-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.alert-item.alert-extreme{background:#ef535033;border-color:#ef535080}.alert-item.alert-high{background:#ff8a6533;border-color:#ff8a6580}.alert-item.alert-moderate{background:#ffb74d33;border-color:#ffb74d80}.alert-icon-large{font-size:3rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:15px;flex-shrink:0}.alert-content{flex:1}.alert-title{color:#fff;font-size:1.2rem;font-weight:600;margin:0 0 10px}.alert-message{color:#ffffffe6;font-size:1rem;line-height:1.5;margin:0 0 10px}.alert-severity{color:#ffffffb3;font-size:.9rem;font-weight:500}.severity-extreme{color:#ef5350;font-weight:600}.severity-high{color:#ff8a65;font-weight:600}.severity-moderate{color:#ffb74d;font-weight:600}.no-alerts{text-align:center;padding:40px 20px;color:#fffc}.no-alerts-icon{font-size:4rem;margin-bottom:15px;opacity:.7}.no-alerts h4{color:#fff;font-size:1.3rem;margin:0 0 10px}.no-alerts p{color:#ffffffb3;font-size:1rem;margin:0}.alert-popup-footer{padding:20px 30px 25px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.alert-popup-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;border:none;padding:12px 30px;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2196f34d}.alert-popup-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2196f366}.alert-popup-btn:active{transform:translateY(0)}@media (max-width: 768px){.weather-alert-popup{width:95%;max-height:90vh;margin:20px}.alert-popup-header{padding:20px}.alert-popup-header h3{font-size:1.3rem}.alert-popup-content{padding:15px 20px}.alert-item{padding:15px;gap:15px}.alert-icon-large{font-size:2.5rem;width:50px;height:50px}.alert-title{font-size:1.1rem}.alert-message{font-size:.95rem}.alert-popup-footer{padding:15px 20px}}@media (max-width: 480px){.weather-alert-popup{width:98%;margin:10px}.alert-popup-header{padding:15px}.alert-popup-header h3{font-size:1.2rem}.alert-popup-content{padding:10px 15px}.alert-item{padding:12px;gap:12px;flex-direction:column;text-align:center}.alert-icon-large{font-size:2rem;width:40px;height:40px;margin:0 auto}.alert-title{font-size:1rem}.alert-message{font-size:.9rem}.alert-popup-footer{padding:10px 15px}.alert-popup-btn{padding:10px 20px;font-size:.9rem}}@media (max-width: 768px){.hourly-forecast{padding:20px 0}.section-title{font-size:1.5rem}.hourly-subtitle{font-size:.875rem}.hourly-items{gap:12px;padding:0 8px}.hourly-item{min-width:120px;padding:16px}.hourly-icon{font-size:2rem}.hourly-temp{font-size:1.25rem}.hourly-time{font-size:.875rem}.hourly-condition{font-size:.75rem}.hourly-expanded{padding:16px}.selected-hour-summary{padding:16px;margin-top:20px}}@media (max-width: 480px){.hourly-items{gap:8px;padding:0 4px}.hourly-item{min-width:100px;padding:12px}.hourly-icon{font-size:1.5rem}.hourly-temp{font-size:1.125rem}.hourly-time{font-size:.8rem}.hourly-condition{font-size:.7rem}.hourly-details{gap:4px;margin-top:8px;padding-top:8px}.hourly-rain,.hourly-wind{font-size:.65rem}.now-badge{font-size:.6rem;padding:3px 6px}.hourly-expanded{padding:12px}.expanded-details .detail-row{font-size:.75rem}}.weather-icon-svg{display:flex;align-items:center;justify-content:center}.weather-icon-svg svg{width:100%;height:100%;display:block}.ten-day-forecast{padding:30px 0}.forecast-header{text-align:center;margin-bottom:30px}.section-title{color:#fff;font-size:2rem;font-weight:600;margin-bottom:8px}.forecast-subtitle{color:#ffffffb3;font-size:1rem;font-weight:400}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin-top:20px}.forecast-day{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:16px;padding:20px;text-align:center;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;min-height:280px}.forecast-day:hover{background:#ffffff26;transform:translateY(-4px);box-shadow:0 12px 30px #0003}.forecast-day.today{background:#ffa50026;border-color:#ffa5004d;box-shadow:0 0 20px #ffa50033}.forecast-day.tomorrow{background:#0066cc26;border-color:#0066cc4d}.forecast-day.selected{background:#0066cc4d;border-color:#0066cc80;transform:translateY(-4px);box-shadow:0 12px 30px #0066cc4d}.forecast-day.narrow{border-left:4px solid #4caf50}.forecast-day.moderate{border-left:4px solid #ff9800}.forecast-day.wide{border-left:4px solid #f44336}.forecast-date{font-size:1rem;font-weight:600;color:#fff;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.forecast-day.today .forecast-date{color:gold}.forecast-day.tomorrow .forecast-date{color:#87ceeb}.forecast-icon{font-size:3rem;margin:16px 0;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.forecast-condition{font-size:.875rem;color:#ffffffe6;margin:8px 0;text-transform:capitalize;font-weight:500;flex-grow:1}.forecast-temps{display:flex;justify-content:center;gap:12px;margin:12px 0;padding:8px 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}.temp-high{font-size:1.25rem;font-weight:600;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.temp-low{font-size:1rem;color:#ffffffb3;font-weight:500}.forecast-details{display:flex;flex-direction:column;gap:6px;margin-top:12px}.forecast-rain,.forecast-humidity,.forecast-wind{font-size:.75rem;color:#ffffffb3;display:flex;align-items:center;justify-content:center;gap:4px}.forecast-expanded{position:absolute;top:100%;left:0;right:0;background:#0066ccf2;backdrop-filter:blur(10px);border-radius:0 0 16px 16px;padding:20px;margin-top:2px;z-index:10;box-shadow:0 8px 25px #0000004d;border:1px solid rgba(0,102,204,.5);border-top:none}.expanded-details h4{color:#fff;font-size:1.125rem;font-weight:600;margin-bottom:16px;text-align:center}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff1a;border-radius:8px;font-size:.875rem}.detail-label{color:#fffc;font-weight:500}.detail-value{color:#fff;font-weight:600}.day-summary{padding-top:12px;border-top:1px solid rgba(255,255,255,.2)}.day-summary p{color:#ffffffe6;line-height:1.5;font-size:.875rem;text-align:center}.selected-day-summary{background:#06c3;backdrop-filter:blur(10px);border-radius:16px;padding:24px;margin-top:30px;border:1px solid rgba(0,102,204,.3)}.summary-content h3{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:16px;text-align:center}.summary-content p{color:#ffffffe6;line-height:1.6;font-size:1.1rem;text-align:center}@media (max-width: 768px){.ten-day-forecast{padding:20px 0}.section-title{font-size:1.5rem}.forecast-subtitle{font-size:.875rem}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.forecast-day{padding:16px;min-height:240px}.forecast-icon{font-size:2.5rem}.forecast-date{font-size:.875rem}.forecast-condition{font-size:.8rem}.temp-high{font-size:1.125rem}.temp-low{font-size:.875rem}.forecast-expanded{padding:16px}.expanded-details h4{font-size:1rem}.detail-grid{grid-template-columns:1fr;gap:8px}.detail-item{font-size:.8rem;padding:6px 10px}.selected-day-summary{padding:20px;margin-top:20px}.summary-content h3{font-size:1.25rem}.summary-content p{font-size:1rem}}@media (max-width: 480px){.forecast-grid{grid-template-columns:repeat(2,1fr);gap:12px}.forecast-day{padding:12px;min-height:200px}.forecast-icon{font-size:2rem}.forecast-date{font-size:.75rem}.forecast-condition{font-size:.7rem}.temp-high{font-size:1rem}.temp-low{font-size:.75rem}.forecast-details{gap:4px;margin-top:8px}.forecast-rain,.forecast-humidity,.forecast-wind{font-size:.65rem}.forecast-expanded{padding:12px}.expanded-details h4{font-size:.875rem}.detail-item{font-size:.75rem;padding:4px 8px}.day-summary p{font-size:.8rem}.selected-day-summary{padding:16px;margin-top:16px}.summary-content h3{font-size:1.125rem}.summary-content p{font-size:.875rem}}.forecast-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:2rem;color:#fff}.notifications-container{position:fixed;top:80px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:.5rem}.notification{background:#000c;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem;min-width:250px;animation:slideInRight .3s ease-out}.notification.success{border-left:4px solid #4CAF50}.notification.error{border-left:4px solid #F44336}.notification.warning{border-left:4px solid #FF9800}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.forecast-header{background:#0000004d;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:1rem 0;margin-bottom:2rem}.header-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.back-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:#fff;padding:.75rem 1.25rem;border-radius:8px;background:#ffffff1a;transition:all .3s ease;font-weight:500}.back-link:hover{background:#fff3;transform:translateY(-2px)}.forecast-title{flex:1;text-align:center}.forecast-title h1{font-size:2.5rem;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3);background:linear-gradient(45deg,#fff,#e0e0e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.location-name{font-size:1.2rem;opacity:.9;margin:.5rem 0}.header-meta{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.last-updated{font-size:.9rem;opacity:.7;margin:0}.data-quality{display:flex;align-items:center}.quality-indicator{font-size:.8rem;padding:.25rem .5rem;border-radius:12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.quality-indicator.excellent{background:#4caf5033;border-color:#4caf5080}.quality-indicator.cached{background:#ffc10733;border-color:#ffc10780}.quality-indicator.fallback{background:#ff980033;border-color:#ff980080}.quality-indicator.estimated{background:#f4433633;border-color:#f4433680}.quality-indicator.offline{background:#9c27b033;border-color:#9c27b080}.header-actions{display:flex;gap:.5rem;align-items:center}.favorite-btn,.share-btn,.export-btn,.animation-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;padding:.5rem .75rem;cursor:pointer;transition:all .3s ease;font-size:1rem}.favorite-btn:hover,.share-btn:hover,.export-btn:hover,.animation-btn:hover{background:#fff3;transform:translateY(-2px)}.favorite-btn.active{background:#f443364d;border-color:#f4433680}.weather-alerts{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:#ff572233;border:1px solid rgba(255,87,34,.5);border-radius:8px;backdrop-filter:blur(10px)}.alert-badge{display:flex;align-items:center;gap:.5rem;font-weight:700}.alert-icon{font-size:1.2rem}.alert-count{background:#ff5722cc;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem}.alert-summary{font-size:.9rem;opacity:.9}.forecast-tabs{display:flex;gap:.5rem;max-width:1400px;margin:0 auto 2rem;padding:0 2rem;flex-wrap:wrap}.tab-btn{padding:.75rem 1.5rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:1rem;position:relative;overflow:hidden}.tab-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.tab-btn:hover:before{left:100%}.tab-btn:hover{background:#fff3;transform:translateY(-2px)}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#ffffff80;box-shadow:0 4px 12px #667eea66}.forecast-content{max-width:1400px;margin:0 auto;padding:0 2rem}.forecast-loading{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.2);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.loading-progress{margin-top:2rem}.progress-bar{width:100%;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);animation:progress 2s ease-in-out infinite}@keyframes progress{0%{width:0%}50%{width:70%}to{width:100%}}.forecast-error{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.error-icon{font-size:4rem;margin-bottom:1rem}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.retry-btn,.offline-btn,.back-btn{display:inline-block;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease}.retry-btn:hover,.offline-btn:hover,.back-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.offline-btn{background:linear-gradient(135deg,#9c27b0,#673ab7)}.offline-notice{margin-top:2rem;padding:1rem;background:#9c27b033;border:1px solid rgba(156,39,176,.5);border-radius:8px}.today-forecast{display:grid;gap:2rem}.current-conditions{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.current-weather-card{background:#0000004d;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;text-align:center;box-shadow:0 8px 32px #0003;transition:all .3s ease}.current-weather-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px #0000004d}.current-temp{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:1rem}.temp-value{font-size:4rem;font-weight:700;background:linear-gradient(45deg,#fff,#e0e0e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.temp-unit{font-size:2rem;opacity:.8}.feels-like{font-size:1rem;opacity:.7;display:block;margin-top:.5rem}.current-condition{font-size:1.3rem;margin-bottom:2rem;opacity:.9}.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;text-align:left}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.detail-label{font-weight:500;opacity:.8}.detail-value{font-weight:700;color:#4fc3f7}.sun-moon-card{background:#0000004d;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;text-align:center}.sun-info{display:flex;justify-content:space-around;align-items:center}.sun-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.sun-icon{font-size:2rem}.sun-label{font-size:.9rem;opacity:.8;font-weight:500}.sun-time{font-size:1.1rem;font-weight:700}.air-quality-card{background:#0000004d;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem}.air-quality-card h3{text-align:center;margin-bottom:1.5rem;color:#fff}.aqi-display{display:flex;align-items:center;gap:2rem;margin-bottom:2rem}.aqi-value{font-size:3rem;font-weight:700;padding:1rem;border-radius:50%;min-width:100px;height:100px;display:flex;align-items:center;justify-content:center;flex-direction:column}.aqi-value.good{background:#4caf504d;border:2px solid #4CAF50}.aqi-value.moderate{background:#ffc1074d;border:2px solid #FFC107}.aqi-value.unhealthy_sensitive{background:#ff98004d;border:2px solid #FF9800}.aqi-value.unhealthy{background:#f443364d;border:2px solid #F44336}.aqi-value.very_unhealthy{background:#9c27b04d;border:2px solid #9C27B0}.aqi-value.hazardous{background:#8b45134d;border:2px solid #8B4513}.aqi-info{flex:1}.aqi-level{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.aqi-description{opacity:.9;line-height:1.4}.pollutants{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.pollutant{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#ffffff0d;border-radius:6px}.pollutant-name{font-size:.9rem;opacity:.8}.hourly-forecast-section,.ten-day-forecast-section,.charts-section,.air-quality-section,.analysis-section{background:#0000004d;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.section-header h2{font-size:1.8rem;margin:0;color:#fff}.section-header p{opacity:.8;margin:0}.header-controls{display:flex;gap:1rem;align-items:center}.expand-btn,.refresh-btn{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.expand-btn:hover,.refresh-btn:hover{background:#fff3}.chart-controls{margin-bottom:2rem}.control-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-selector,.time-range-selector,.chart-type-selector{display:flex;align-items:center;gap:1rem}.metric-selector label,.time-range-selector label,.chart-type-selector label{font-weight:500;color:#fff;min-width:80px}.metric-selector select,.time-range-selector select,.chart-type-selector select{padding:.5rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;font-size:1rem;flex:1}.metric-selector select option,.time-range-selector select option,.chart-type-selector select option{background:#333;color:#fff}.chart-actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap}.comparison-btn,.download-btn{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.comparison-btn:hover,.download-btn:hover{background:#fff3}.chart-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.chart-container h3{margin-top:0;margin-bottom:1.5rem;color:#fff;text-align:center}.chart-wrapper{height:400px;position:relative}.air-quality-details{display:grid;gap:2rem}.aqi-main{display:flex;align-items:center;gap:2rem;padding:2rem;background:#ffffff0d;border-radius:12px}.aqi-circle{width:120px;height:120px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;border:3px solid}.aqi-circle.good{background:#4caf504d;border-color:#4caf50}.aqi-circle.moderate{background:#ffc1074d;border-color:#ffc107}.aqi-circle.unhealthy_sensitive{background:#ff98004d;border-color:#ff9800}.aqi-circle.unhealthy{background:#f443364d;border-color:#f44336}.aqi-circle.very_unhealthy{background:#9c27b04d;border-color:#9c27b0}.aqi-circle.hazardous{background:#8b45134d;border-color:#8b4513}.aqi-number{font-size:2rem}.aqi-label{font-size:.9rem;opacity:.8}.aqi-info h3{margin:0 0 .5rem;color:#fff}.health-recommendations p{margin:.5rem 0;padding:.5rem;background:#ffffff0d;border-radius:6px;border-left:3px solid #4CAF50}.pollutants-grid{margin-top:2rem}.pollutants-grid h3{text-align:center;margin-bottom:1.5rem;color:#fff}.pollutant-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.pollutant-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem}.pollutant-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.pollutant-name{font-weight:500}.pollutant-value{font-weight:700;color:#4fc3f7}.pollutant-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.pollutant-fill{height:100%;background:linear-gradient(90deg,#4fc3f7,#2196f3);transition:width .5s ease}.uv-index-section{margin-top:2rem}.uv-index-section h3{text-align:center;margin-bottom:1.5rem;color:#fff}.uv-display{display:flex;align-items:center;gap:2rem;padding:2rem;background:#ffffff0d;border-radius:12px}.uv-circle{width:100px;height:100px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;border:3px solid}.uv-circle.low{background:#4caf504d;border-color:#4caf50}.uv-circle.moderate{background:#ffc1074d;border-color:#ffc107}.uv-circle.high{background:#ff98004d;border-color:#ff9800}.uv-circle.very_high{background:#f443364d;border-color:#f44336}.uv-circle.extreme{background:#9c27b04d;border-color:#9c27b0}.uv-number{font-size:1.5rem}.uv-label{font-size:.8rem;opacity:.8}.uv-info h4{margin:0 0 .5rem;color:#fff}.uv-recommendations p{margin:.5rem 0;padding:.5rem;background:#ffffff0d;border-radius:6px;border-left:3px solid #4CAF50}.analysis-section{background:#0000004d;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.analysis-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.analysis-card h3{margin:0 0 1rem;color:#fff}.alerts-section{max-width:1400px;margin:2rem auto;padding:0 2rem}.alerts-section h3{font-size:1.5rem;margin-bottom:1.5rem;color:#fff}.alerts-list{display:grid;gap:1rem}.alert-item{background:#ff572233;border:1px solid rgba(255,87,34,.5);border-radius:12px;padding:1.5rem;backdrop-filter:blur(10px)}.alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.alert-title{font-weight:700;font-size:1.1rem}.alert-severity{padding:.25rem .75rem;background:#ff5722cc;color:#fff;border-radius:20px;font-size:.8rem;font-weight:500}.alert-description{opacity:.9;line-height:1.5;margin-bottom:1rem}.alert-actions{display:flex;gap:1rem}.alert-dismiss,.alert-details{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.alert-dismiss:hover,.alert-details:hover{background:#fff3}@media (max-width: 768px){.header-content{flex-direction:column;text-align:center;gap:1rem}.forecast-title{order:-1}.forecast-title h1{font-size:2rem}.forecast-tabs{padding:0 1rem}.tab-btn{padding:.6rem 1rem;font-size:.9rem}.forecast-content{padding:0 1rem}.current-conditions{grid-template-columns:1fr}.current-temp .temp-value{font-size:3rem}.weather-details,.period-forecast{grid-template-columns:1fr}.section-header{flex-direction:column;text-align:center}.chart-wrapper{height:300px}.control-group{grid-template-columns:1fr}.chart-actions{justify-content:center}.aqi-main,.uv-display{flex-direction:column;text-align:center}.analysis-grid{grid-template-columns:1fr}.alert-header{flex-direction:column;text-align:center}.notifications-container{right:10px;left:10px}}@media (max-width: 480px){.forecast-title h1{font-size:1.8rem}.forecast-tabs{gap:.25rem}.tab-btn{padding:.5rem .8rem;font-size:.85rem}.current-weather-card{padding:1.5rem}.current-temp .temp-value{font-size:2.5rem}.period-card{padding:1rem}.chart-wrapper{height:250px}.header-actions{flex-wrap:wrap;justify-content:center}}.fade-in{animation:fadeIn .5s ease-in}.slide-in{animation:slideIn .5s ease-out}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@media print{.forecast-page{background:#fff;color:#000}.forecast-header,.forecast-tabs,.header-actions,.notifications-container{display:none}.forecast-content>div{background:#fff;border:1px solid #ccc;color:#000}}.weather-map-radar{display:flex;flex-direction:column;height:100%;width:100%;background:transparent;border-radius:0;overflow:hidden;position:relative;min-height:400px;flex:1}.map-container{flex:1;position:relative;height:100%;width:100%;min-height:400px;overflow:hidden}.simple-weather-map{display:flex;flex-direction:column;height:100%;width:100%;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative;overflow:hidden}.map-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#0000004d;backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1)}.map-title{font-size:1.2rem;font-weight:600;color:#fff}.map-status{font-size:.9rem;color:#22c55e;background:#22c55e33;padding:.25rem .75rem;border-radius:12px;border:1px solid rgba(34,197,94,.3)}.map-display{flex:1;position:relative;display:flex;flex-direction:column;overflow:hidden}.radar-animation{flex:1;position:relative;display:flex;align-items:center;justify-content:center;min-height:300px;background:radial-gradient(circle at center,#3498db1a,#0000004d,#00000080)}.radar-sweep{position:absolute;width:80%;height:80%;border:3px solid rgba(52,152,219,.3);border-radius:50%;animation:radar-sweep 4s linear infinite}.radar-sweep:before{content:"";position:absolute;top:50%;left:50%;width:2px;height:60%;background:linear-gradient(to top,transparent,rgba(52,152,219,.8));transform-origin:bottom;transform:translate(-50%) translateY(-100%) rotate(0);animation:sweep 2s linear infinite}.radar-center{position:absolute;width:20px;height:20px;background:#3498db;border-radius:50%;box-shadow:0 0 20px #3498dbcc;animation:pulse 2s ease-in-out infinite}.weather-layers{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:2rem}.layer{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;cursor:pointer;min-width:80px}.layer:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.layer.active{background:#3498db4d;border-color:#3498db80;box-shadow:0 0 20px #3498db66}.layer-icon{font-size:2rem;margin-bottom:.5rem}.layer-name{font-size:.8rem;font-weight:600;text-align:center;color:#ffffffe6}.map-controls{background:#0000004d;backdrop-filter:blur(10px);padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.control-group{margin-bottom:1rem}.control-group:last-child{margin-bottom:0}.control-title{font-size:.9rem;font-weight:600;margin-bottom:.5rem;color:#ffffffe6}.base-map-options,.layer-options{display:flex;flex-wrap:wrap;gap:.5rem}.base-map-btn,.layer-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .3s ease;display:flex;align-items:center;gap:.25rem}.base-map-btn:hover,.layer-btn:hover{background:#fff3;transform:translateY(-1px)}.base-map-btn.active,.layer-btn.active{background:#3498db4d;border-color:#3498db80;box-shadow:0 0 10px #3498db66}.location-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.current-location{font-size:.9rem;color:#fffc;background:#ffffff1a;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.location-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .3s ease;display:flex;align-items:center;gap:.25rem}.location-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.map-legend{background:#0000004d;backdrop-filter:blur(10px);padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.legend-title{font-size:.9rem;font-weight:600;margin-bottom:.5rem;color:#ffffffe6}.legend-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.legend-label{font-size:.8rem;color:#fffc}.map-info{background:#0000004d;backdrop-filter:blur(10px);padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-section{background:#ffffff0d;padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.info-section h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:#fff}.info-section ul{list-style:none;padding:0;margin:0}.info-section li{font-size:.8rem;color:#fffc;margin-bottom:.25rem}.info-section p{font-size:.8rem;color:#fffc;margin:.25rem 0}.weather-map-loading,.weather-map-error{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative;min-height:400px;text-align:center;padding:2rem}.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.weather-map-error h3{font-size:1.5rem;margin-bottom:.5rem}.weather-map-error p{font-size:1rem;margin-bottom:1.5rem;opacity:.8}.retry-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease}.retry-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}@keyframes radar-sweep{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes sweep{0%{transform:translate(-50%) translateY(-100%) rotate(0)}to{transform:translate(-50%) translateY(-100%) rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@media (max-width: 768px){.weather-map-radar{min-height:300px}.map-header{padding:.75rem;flex-direction:column;gap:.5rem;text-align:center}.map-title{font-size:1rem}.map-status{font-size:.8rem;padding:.2rem .5rem}.weather-layers{grid-template-columns:repeat(2,1fr);gap:.5rem;padding:1rem}.layer{padding:.75rem;min-width:60px}.layer-icon{font-size:1.5rem;margin-bottom:.25rem}.layer-name{font-size:.7rem}.map-controls{padding:.75rem}.base-map-options,.layer-options{gap:.25rem}.base-map-btn,.layer-btn{padding:.4rem .8rem;font-size:.7rem}.location-info{flex-direction:column;gap:.5rem;text-align:center}.current-location{font-size:.8rem;padding:.4rem .8rem}.location-btn{padding:.4rem .8rem;font-size:.7rem}.map-legend{padding:.75rem}.legend-items{grid-template-columns:1fr;gap:.25rem}.legend-item{font-size:.7rem}.map-info{grid-template-columns:1fr;gap:.75rem;padding:.75rem}.info-section{padding:.75rem}.info-section h3{font-size:.9rem}.info-section li,.info-section p{font-size:.7rem}}@media (max-width: 480px){.weather-map-radar{min-height:250px}.weather-layers{grid-template-columns:repeat(2,1fr);gap:.25rem;padding:.5rem}.layer{padding:.5rem;min-width:50px}.layer-icon{font-size:1.2rem}.layer-name{font-size:.6rem}.map-controls{padding:.5rem}.control-group{margin-bottom:.5rem}.base-map-options,.layer-options{gap:.2rem}.base-map-btn,.layer-btn{padding:.3rem .6rem;font-size:.6rem}.map-legend{padding:.5rem}.legend-color{width:16px;height:16px}.map-info,.info-section{padding:.5rem}.info-section h3{font-size:.8rem}.info-section li,.info-section p{font-size:.6rem}}.weather-map-section{padding:0;height:100%;display:flex;flex-direction:column;flex:1;min-height:0}.map-display{position:relative;width:100%;height:100%;min-height:400px;background:transparent;border-radius:0;overflow:hidden;flex:1}.map-container{background:transparent;backdrop-filter:none;border-radius:0;padding:0;position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column;height:100%;min-height:0}.weather-layer{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;object-fit:cover!important;opacity:1!important;z-index:1000!important;border-radius:0!important;pointer-events:none!important;border:none!important;box-sizing:border-box!important}.map-loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000080;color:#fff;z-index:10}.map-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000b3;color:#fff;z-index:10;text-align:center;padding:2rem}.error-icon{font-size:3rem;margin-bottom:1rem}.retry-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;margin-top:1rem;transition:all .2s ease}.retry-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.map-overlay{position:absolute;top:10px;right:10px;background:#000000b3;padding:.5rem 1rem;border-radius:20px;color:#fff;font-size:.8rem;z-index:2000}.map-info{display:flex;gap:1rem;align-items:center}.map-type{font-weight:600}.map-update{opacity:.8;font-size:.7rem}.weather-layer{transition:opacity .3s ease}.map-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem}.map-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.location-controls{display:flex;gap:.5rem}.locate-btn{display:flex;align-items:center;gap:.5rem;background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3);padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem;font-weight:600}.locate-btn:hover:not(:disabled){background:#3b82f64d;transform:translateY(-1px)}.locate-btn:disabled{opacity:.6;cursor:not-allowed}.locate-btn.locating{background:#3b82f64d;animation:locate-pulse 1.5s infinite}@keyframes locate-pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.locate-icon{font-size:1rem;transition:transform .3s ease}.locate-btn.locating .locate-icon{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.locate-text{font-size:.8rem}.map-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.map-btn:hover{background:#fff3;transform:translateY(-1px)}.map-btn.active{background:#3b82f64d;border-color:#3b82f680;color:#3b82f6}.btn-text{font-weight:500}.map-info-panel{background:#ffffff0d;border-radius:8px;padding:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.info-item:last-child{border-bottom:none}.info-label{color:#ffffffb3;font-size:.9rem}.info-value{color:#fff;font-weight:600;font-size:.9rem}@media (max-width: 768px){.map-display{height:300px}.map-buttons{flex-direction:column}.map-btn{justify-content:center}.location-controls{width:100%;justify-content:center}.locate-btn{flex:1;max-width:200px;justify-content:center}.info-grid{grid-template-columns:1fr}.map-overlay{top:5px;right:5px;padding:.25rem .5rem;font-size:.7rem}.map-info{flex-direction:column;gap:.25rem}}.map-placeholder{text-align:center;padding:3rem 2rem;color:#fff}.map-placeholder h3{margin-bottom:1rem;font-size:1.5rem}.map-placeholder p{margin-bottom:2rem;opacity:.8}.map-controls{display:flex;gap:12px;justify-content:center;margin:20px 0;flex-wrap:wrap}.map-controls .btn{padding:8px 16px;font-size:.875rem;display:flex;align-items:center;gap:6px}.btn-icon{font-size:1rem}.map-info{margin-top:20px;padding:16px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.map-info p{color:#ffffffe6;font-size:.95rem;line-height:1.5;margin:0}@media (max-width: 768px){.weather-map-section{padding:20px 0}.map-container{padding:16px;min-height:300px}.map-icon{font-size:3rem}.map-placeholder h3{font-size:1.25rem}.map-placeholder p{font-size:.875rem}.map-controls{gap:8px}.map-controls .btn{padding:6px 12px;font-size:.8rem}.map-info{padding:12px;margin-top:16px}.map-info p{font-size:.85rem}}@media (max-width: 480px){.map-container{padding:12px;min-height:250px}.map-icon{font-size:2.5rem}.map-placeholder h3{font-size:1.125rem}.map-placeholder p{font-size:.8rem}.map-controls{gap:6px}.map-controls .btn{padding:5px 10px;font-size:.75rem}.map-info{padding:10px;margin-top:12px}.map-info p{font-size:.8rem}}.map-page{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed;overflow:hidden}.map-content{padding:0;max-width:100%;margin:0;height:100vh;min-height:100vh;display:flex;flex-direction:column}.map-header{margin-bottom:0;flex-shrink:0}.map-nav{display:flex;align-items:center;justify-content:space-between;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:0;padding:.75rem;border:none}.header-content{flex:1;text-align:center;color:#fff}.header-content h1{margin:0 0 .5rem;font-size:2rem;font-weight:600}.header-content p{margin:0;opacity:.9;font-size:1.1rem}.info-toggle{display:flex;align-items:center;gap:.5rem;background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3);padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .3s ease}.info-toggle:hover{background:#3b82f64d;transform:translateY(-1px)}.info-icon{font-size:1.2rem}.map-info-panel{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:2rem;margin-bottom:2rem;border:1px solid rgba(255,255,255,.2);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;color:#fff}.info-header h3{margin:0;font-size:1.5rem}.close-info{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.close-info:hover{background:#fff3}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem}.feature-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.feature-card:hover{background:#ffffff1a;transform:translateY(-2px)}.feature-icon{font-size:2rem;flex-shrink:0}.feature-content h4{margin:0 0 .25rem;color:#fff;font-size:1rem}.feature-content p{margin:0;color:#ffffffb3;font-size:.9rem}.map-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff0d;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.stat-label{color:#ffffffb3;font-size:.9rem}.stat-value{color:#fff;font-weight:600;font-size:.9rem}.map-container.enhanced{display:grid;grid-template-columns:1fr;gap:0;flex:1;min-height:0;height:calc(100vh - 50px);background:transparent;border-radius:0;padding:0;border:none;overflow:hidden}.external-map-controls{position:absolute;top:1rem;left:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:180px;opacity:.9;transition:opacity .3s ease}.external-map-controls:hover{opacity:1}.control-section{background:#ffffff14;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.75rem}.control-section h4{color:#fff;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.layer-buttons,.basemap-buttons{display:grid;grid-template-columns:1fr;gap:.25rem}.layer-btn,.basemap-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.4rem;border-radius:6px;font-size:.7rem;cursor:pointer;transition:all .3s ease}.layer-btn:hover,.basemap-btn:hover{background:#ffffff26;transform:translateY(-1px)}.layer-btn.active,.basemap-btn.active{background:#3498db4d;border-color:#3498db80;color:#3498db}.leaflet-control-layers{display:none!important}.map-sidebar{display:none}.location-display{display:flex;justify-content:space-between;align-items:center}.location-name{color:#fff;font-weight:600}.location-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.location-btn:hover{background:#fff3}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.action-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.75rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.action-btn:hover{background:#fff3;transform:translateY(-1px)}.action-btn.primary{background:#3b82f633;border-color:#3b82f64d;color:#3b82f6}.action-btn.primary:hover{background:#3b82f64d}.tips-list{list-style:none;padding:0;margin:0;color:#fffc;font-size:.9rem}.tips-list li{padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.tips-list li:last-child{border-bottom:none}.map-main{display:flex;flex-direction:column;gap:0;height:100%;min-height:0;background:transparent;border:none;border-radius:0;padding:0}.map-wrapper{flex:1;height:100%;min-height:0;position:relative;background:transparent;border-radius:0;overflow:hidden;display:flex;flex-direction:column}.map-wrapper .weather-layer{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;object-fit:cover!important;border-radius:12px}.map-footer{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.footer-info{display:flex;align-items:center;gap:2rem}.data-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.status-indicator.live{background:#10b981}@keyframes pulse{0%{box-shadow:0 0 #10b981b3}70%{box-shadow:0 0 0 10px #10b98100}to{box-shadow:0 0 #10b98100}}.status-text,.last-update{color:#fffc;font-size:.9rem}.footer-actions{display:flex;gap:.5rem}.footer-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.footer-btn:hover{background:#fff3}.map-legend-bar{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.2);margin-top:2rem}.legend-section h4{margin:0 0 1rem;color:#fff;font-size:1.1rem}.intensity-scale{display:flex;gap:2rem;align-items:center}.scale-item{display:flex;align-items:center;gap:.5rem}.scale-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(255,255,255,.3)}.scale-item.light .scale-color{background:#22c55e99}.scale-item.moderate .scale-color{background:#facc1599}.scale-item.heavy .scale-color{background:#f9731699}.scale-item.severe .scale-color{background:#ef444499}.scale-item span{color:#fff;font-size:.9rem}@media (max-width: 600px){.map-content{padding:1rem;height:calc(100vh - 80px);min-height:calc(100vh - 80px)}.header-content h1{font-size:1.5rem}.action-buttons{grid-template-columns:1fr}.footer-info{flex-direction:column;gap:1rem;align-items:flex-start}.intensity-scale{flex-wrap:wrap;gap:1rem}}.back-link:hover{background:#fff3}.map-nav h1{color:#fff;font-size:2.5rem;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.map-controls{display:flex;gap:.5rem}.control-btn{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.control-btn:hover{background:#fff3}.map-container{display:grid;grid-template-columns:300px 1fr;gap:2rem;min-height:600px}.map-sidebar{background:#ffffff0d;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:1.5rem;height:fit-content}.map-sidebar h3{color:#fff;font-size:1.3rem;margin-bottom:1rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.layer-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.layer-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:left}.layer-btn:hover{background:#ffffff1a}.layer-btn.active{background:#3498dbcc;border-color:#3498db80}.layer-icon{font-size:1.2rem}.layer-name{font-weight:500}.map-options{margin-bottom:2rem}.option-group{display:flex;flex-direction:column;gap:.75rem}.option-group label{display:flex;align-items:center;gap:.5rem;color:#ffffffe6;cursor:pointer;font-size:.9rem}.option-group input[type=checkbox]{width:16px;height:16px}.map-legend{margin-bottom:1rem}.legend-items{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;color:#ffffffe6;font-size:.9rem}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(255,255,255,.3)}.map-main{background:#ffffff0d;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:15px;overflow:hidden;position:relative}.map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:600px;color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.map-display{height:600px;position:relative}.map-placeholder{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center}.map-icon{font-size:4rem;margin-bottom:1rem}.map-placeholder h3{font-size:1.5rem;margin-bottom:.5rem}.map-demo{position:relative;width:100%;height:400px;background:#ffffff0d;border-radius:10px;margin-top:2rem;overflow:hidden}.demo-overlay{position:relative;width:100%;height:100%;background:linear-gradient(45deg,#0064c81a,#00c8641a)}.demo-marker{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%,-50%)}.marker-icon{font-size:2rem;margin-bottom:.25rem}.marker-label{background:#000000b3;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;white-space:nowrap}.map-footer{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding:1rem;background:#ffffff0d;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:10px;flex-wrap:wrap;gap:1rem}.map-info{color:#fffc;font-size:.9rem}.map-actions{display:flex;gap:.5rem}.action-btn{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.action-btn:hover{background:#fff3}@media (max-width: 768px){.map-content{padding:.25rem;height:calc(100vh - 80px);min-height:calc(100vh - 80px)}.map-nav{flex-direction:column;gap:.5rem;padding:.5rem}.header-content{text-align:center}.header-content h1{font-size:1.25rem}.map-container.enhanced{grid-template-columns:1fr;gap:.25rem;padding:.25rem;height:calc(100vh - 160px)}.map-sidebar{display:none}.map-main{order:1;height:calc(100vh - 140px);min-height:300px;padding:.25rem}.map-wrapper{height:calc(100vh - 160px);min-height:250px}.map-footer{flex-direction:column;gap:.5rem;padding:.5rem}.footer-actions{display:flex;gap:.5rem}.footer-btn{flex:1;padding:.5rem;font-size:.8rem}.map-legend-bar{display:none}.external-map-controls{position:absolute;top:.5rem;left:.5rem;max-width:140px;opacity:.8;gap:.25rem}.control-section{padding:.5rem;border-radius:6px}.control-section h4{font-size:.7rem;margin-bottom:.25rem}.layer-buttons,.basemap-buttons{gap:.15rem}.layer-btn,.basemap-btn{padding:.3rem;font-size:.6rem;border-radius:4px}}.weather-alerts-section{padding:30px 0;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed;min-height:100vh}.alert-modal-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.alert-modal-container{background:#fff;border-radius:16px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.alert-modal-header{background:#dc2626;color:#fff;padding:1.5rem;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.modal-header-content{display:flex;align-items:center;gap:1rem}.modal-alert-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.modal-alert-title{font-size:1.5rem;font-weight:700;margin:0;flex:1}.modal-alert-severity{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;letter-spacing:.5px}.modal-close-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.alert-modal-body{padding:2rem}.modal-alert-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.meta-item{display:flex;flex-direction:column;gap:.5rem}.meta-label{font-size:.875rem;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.meta-value{font-size:1rem;font-weight:500;color:#212529}.urgency-badge,.severity-badge{padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;display:inline-block}.modal-alert-description{margin-bottom:2rem}.modal-alert-description h3{color:#212529;font-size:1.25rem;font-weight:600;margin-bottom:1rem;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.modal-alert-description p{color:#495057;font-size:1rem;line-height:1.6;margin:0}.modal-alert-instructions{background:#fff3cd;border:1px solid #ffeaa7;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.modal-alert-instructions h3{color:#856404;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.modal-alert-instructions p{color:#856404;font-size:1rem;line-height:1.6;margin:0}.modal-alert-actions{display:flex;gap:1rem;justify-content:center;align-items:center;padding-top:1rem;border-top:1px solid #e9ecef}.modal-alert-link{background:#007bff;color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;transition:all .2s ease}.modal-alert-link:hover{background:#0056b3;transform:translateY(-2px)}.modal-dismiss-btn{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-dismiss-btn:hover{background:#5a6268;transform:translateY(-2px)}.alerts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.2)}.section-title{margin:0;color:#fff;font-size:2rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.alert-icon{font-size:2.5rem;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.alerts-controls{display:flex;align-items:center;gap:1rem}.refresh-btn{display:flex;align-items:center;gap:.5rem;background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3);padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem}.refresh-btn:hover:not(:disabled){background:#3b82f64d;transform:translateY(-1px)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{font-size:1rem;transition:transform .3s ease}.refresh-btn:hover:not(:disabled) .refresh-icon{transform:rotate(180deg)}.alert-count{background:#ffffff1a;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600}.alerts-loading,.alerts-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);text-align:center}.alerts-loading p,.alerts-error p{margin-top:1rem;color:#fffc;font-size:1.1rem}.no-alerts{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);text-align:center}.no-alerts-icon{font-size:4rem;margin-bottom:1rem}.no-alerts h3{color:#fff;margin:0 0 1rem;font-size:1.5rem}.no-alerts p{color:#ffffffb3;font-size:1.1rem;margin:0}.alerts-list{display:flex;flex-direction:column;gap:1rem}.alert-card{background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);overflow:hidden;transition:all .3s ease;cursor:pointer}.alert-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0003}.alert-card.extreme{border-left:5px solid #dc2626;background:#dc26261a}.alert-card.severe{border-left:5px solid #f59e0b;background:#f59e0b1a}.alert-card.moderate{border-left:5px solid #eab308;background:#eab3081a}.alert-card.minor{border-left:5px solid #3b82f6;background:#3b82f61a}.alert-card.unknown{border-left:5px solid #6b7280;background:#6b72801a}.alert-header{padding:1.5rem 1.5rem 1rem}.alert-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.alert-severity-icon{font-size:1.5rem;flex-shrink:0}.alert-title{color:#fff;margin:0;font-size:1.3rem;font-weight:600;flex:1}.alert-severity{background:#fff3;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase}.alert-meta{display:flex;gap:1rem;align-items:center}.alert-event{color:#fffc;font-size:.9rem}.alert-urgency{background:#ffffff1a;color:#ffffffe6;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600;text-transform:capitalize}.alert-summary{padding:0 1.5rem 1.5rem}.alert-description{color:#ffffffe6;font-size:1rem;line-height:1.5;margin:0 0 1rem}.alert-areas{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.areas-label{color:#ffffffb3;font-size:.9rem;font-weight:600}.areas-list{color:#ffffffe6;font-size:.9rem}.alert-details{border-top:1px solid rgba(255,255,255,.1);background:#0000001a;padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section:last-child{margin-bottom:0}.detail-section h4{color:#fff;margin:0 0 .75rem;font-size:1.1rem;font-weight:600}.detail-section p{color:#fffc;font-size:1rem;line-height:1.6;margin:0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{color:#fff9;font-size:.85rem;font-weight:600;text-transform:uppercase}.detail-value{color:#ffffffe6;font-size:.95rem}.alert-actions{display:flex;justify-content:center}.alert-link{display:inline-flex;align-items:center;gap:.5rem;background:#3b82f633;color:#3b82f6;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;border:1px solid rgba(59,130,246,.3);font-weight:600;transition:all .3s ease}.alert-link:hover{background:#3b82f64d;transform:translateY(-1px)}.alert-card.immediate{animation:urgent-pulse 1s infinite}@keyframes urgent-pulse{0%{box-shadow:0 0 #f59e0bb3}70%{box-shadow:0 0 0 10px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}@media (max-width: 768px){.alerts-header{flex-direction:column;gap:1rem;text-align:center}.section-title{font-size:1.5rem}.alert-title-row{flex-direction:column;align-items:flex-start;gap:.5rem}.alert-title{font-size:1.1rem}.detail-grid{grid-template-columns:1fr}.no-alerts{padding:2rem 1rem}.no-alerts-icon{font-size:3rem}}.alerts-page{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#1e3c72);background-attachment:fixed;padding:2rem}.alerts-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.2)}.back-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;padding:.75rem 1rem;border-radius:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.back-link:hover{background:#fff3;transform:translate(-2px)}.back-icon{font-size:1.2rem}.page-title{flex:1;text-align:center;color:#fff}.page-title h1{margin:0 0 .5rem;font-size:2rem;font-weight:600}.page-title p{margin:0;opacity:.9;font-size:1.1rem}.header-actions{display:flex;gap:1rem}.map-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;padding:.75rem 1rem;border-radius:8px;background:#3b82f633;border:1px solid rgba(59,130,246,.3);transition:all .3s ease}.map-link:hover{background:#3b82f64d;transform:translateY(-1px)}.map-icon{font-size:1rem}@media (max-width: 768px){.alerts-page{padding:1rem}.alerts-page-header{flex-direction:column;gap:1rem;text-align:center}.page-title{order:-1}.back-link{align-self:flex-start}.header-actions{align-self:flex-end}.page-title h1{font-size:1.5rem}}.settings-page{min-height:100vh;background:var(--bg-primary);background-attachment:fixed;transition:background .3s ease}.settings-content{padding:2rem;max-width:800px;margin:0 auto}.settings-header{margin-bottom:2rem}.settings-nav{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.back-link{color:var(--text-primary);text-decoration:none;font-size:1.1rem;padding:.5rem 1rem;border-radius:8px;background:var(--bg-secondary);transition:all .3s ease;border:1px solid var(--border-color)}.back-link:hover{background:var(--bg-tertiary)}.settings-nav h1{color:var(--text-primary);font-size:2.5rem;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.save-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#27ae60,#229954);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #27ae604d}.save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #27ae6066}.save-btn.saved{background:linear-gradient(135deg,#27ae60,#229954);animation:pulse .5s ease}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.settings-sections{display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--bg-secondary);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:15px;padding:2rem;transition:background .3s ease,border-color .3s ease}.settings-section h2{color:var(--text-primary);font-size:1.8rem;margin-bottom:1.5rem;text-shadow:0 1px 2px rgba(0,0,0,.3);padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.setting-group{display:flex;flex-direction:column;gap:1.5rem}.setting-item{display:flex;flex-direction:column;gap:.5rem}.setting-label{color:var(--text-primary);font-weight:600;font-size:1.1rem}.setting-select{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.setting-select:focus{outline:none;border-color:var(--bg-tertiary);box-shadow:0 0 0 2px #3498db33}.setting-select option{background:var(--bg-primary);color:var(--text-primary)}.setting-select:disabled{opacity:.5;cursor:not-allowed}.setting-description{color:var(--text-muted);font-size:.9rem;line-height:1.4}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.toggle-switch{position:relative;width:60px;height:30px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#fff3;border:1px solid rgba(255,255,255,.3);transition:.3s;border-radius:30px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:4px;background:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:#27ae60cc;border-color:#27ae6080}.toggle-switch input:checked+.toggle-slider:before{transform:translate(30px)}.about-info{color:var(--text-primary)}.about-info h3{font-size:1.5rem;margin-bottom:.5rem}.about-info p{color:var(--text-secondary);margin-bottom:1rem}.about-links{display:flex;gap:1rem;flex-wrap:wrap}.about-link{color:#3498db;text-decoration:none;padding:.5rem 1rem;border:1px solid rgba(52,152,219,.3);border-radius:6px;transition:all .3s ease}.about-link:hover{background:#3498db1a;border-color:#3498db80}.reset-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #e74c3c4d}.reset-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c66}@media (max-width: 768px){.settings-content{padding:1rem}.settings-nav{flex-direction:column;text-align:center}.settings-nav h1{font-size:2rem}.settings-section{padding:1.5rem}.settings-section h2{font-size:1.5rem}.setting-select{padding:.6rem;font-size:.9rem}.about-links{justify-content:center}.toggle-switch{width:50px;height:25px}.toggle-slider:before{height:18px;width:18px;left:3.5px;bottom:3.5px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(25px)}}:root{--bg-primary: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--bg-secondary: rgba(255, 255, 255, .1);--bg-tertiary: rgba(0, 102, 204, .9);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .9);--text-muted: rgba(255, 255, 255, .7);--border-color: rgba(255, 255, 255, .1);--error-bg: rgba(255, 0, 0, .1);--error-border: rgba(255, 0, 0, .3);--error-text: #ffcdd2;--success-bg: rgba(76, 175, 80, .1);--success-border: rgba(76, 175, 80, .3);--success-text: #c8e6c9;--warning-bg: rgba(255, 193, 7, .1);--warning-border: rgba(255, 193, 7, .3);--warning-text: #fff3cd}.light-theme{--bg-primary: linear-gradient(135deg, #87ceeb 0%, #4682b4 100%);--bg-secondary: rgba(0, 0, 0, .05);--bg-tertiary: rgba(70, 130, 180, .9);--text-primary: #333333;--text-secondary: #555555;--text-muted: #777777;--border-color: rgba(0, 0, 0, .1);--error-bg: rgba(220, 53, 69, .1);--error-border: rgba(220, 53, 69, .3);--error-text: #721c24}.App{width:100vw!important;height:100vh!important;margin:0!important;padding:0!important;overflow:auto!important;position:relative!important;background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease;box-sizing:border-box!important;min-width:100vw!important;min-height:100vh!important}body{overflow:auto!important;margin:0!important;padding:0!important;width:100vw!important;height:100vh!important;background:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.error-boundary-container{background:#0000004d;padding:2rem;border-radius:15px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);max-width:500px;text-align:left;box-shadow:0 8px 32px #0000004d}.error-boundary h2{margin:0 0 1rem;color:#ff6b6b;font-size:1.5rem;font-weight:600}.error-boundary p{margin:.5rem 0;opacity:.8;line-height:1.5}.error-boundary details{white-space:pre-wrap;background:#0003;padding:1rem;border-radius:8px;margin:1rem 0;font-size:.9rem;border:1px solid rgba(255,255,255,.1)}.error-boundary summary{cursor:pointer;font-weight:700;margin-bottom:.5rem;color:#4fc3f7;transition:color .3s ease}.error-boundary summary:hover{color:#29b6f6}.error-boundary pre{font-size:.7rem;overflow:auto;max-height:200px;background:#0000001a;padding:.5rem;border-radius:4px;margin-top:.5rem;border:1px solid rgba(255,255,255,.05)}.error-boundary-buttons{display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem}.error-boundary button{background:#4fc3f7;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;font-weight:700;transition:all .3s ease;box-shadow:0 4px 12px #0003}.error-boundary button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.error-boundary button.primary{background:#4fc3f7}.error-boundary button.primary:hover{background:#29b6f6}.error-boundary button.secondary{background:#ff6b6b}.error-boundary button.secondary:hover{background:#e55555}.offline-indicator{position:fixed;top:10px;right:10px;background:#ff6b6b;color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:700;z-index:9999;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease-out;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading{position:relative;overflow:hidden}.loading:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}@media (max-width: 768px){.error-boundary-container{margin:1rem;padding:1.5rem}.error-boundary h2{font-size:1.25rem}.error-boundary-buttons{flex-direction:column}.error-boundary button{width:100%}.offline-indicator{top:5px;right:5px;font-size:.75rem;padding:.4rem .8rem}}@media (max-width: 480px){.error-boundary-container{margin:.5rem;padding:1rem}.error-boundary h2{font-size:1.1rem}.error-boundary details{font-size:.8rem}.error-boundary pre{font-size:.6rem}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.error-boundary-container,.error-boundary button{border:2px solid white}}.error-boundary button:focus,.error-boundary summary:focus{outline:2px solid #4fc3f7;outline-offset:2px}@media (prefers-color-scheme: dark){.error-boundary{background:linear-gradient(135deg,#1a1a2e,#16213e)}.error-boundary-container{background:#00000080;border:1px solid rgba(255,255,255,.2)}}.error-boundary-container,.error-boundary button{will-change:transform;transform:translateZ(0)}@media print{.error-boundary{background:#fff;color:#000}.error-boundary-container{background:#fff;border:1px solid black;box-shadow:none}.error-boundary-buttons,.offline-indicator{display:none}}*{box-sizing:border-box}html{overflow:auto!important;margin:0!important;padding:0!important;width:100vw!important;height:100vh!important;min-height:100vh!important;box-sizing:border-box!important}@media (max-width: 1024px){.mobile-bottom-nav{z-index:9999!important;position:fixed!important}.leaflet-control-container,.leaflet-top,.leaflet-bottom{z-index:999!important}}.map-container{width:100vw!important;height:100vh!important;position:fixed!important;inset:0!important;z-index:1;margin:0!important;padding:0!important;border:none!important;box-sizing:border-box!important;overflow:hidden!important}.map-wrapper{width:100%!important;height:100%!important;position:relative!important;margin:0!important;padding:0!important;box-sizing:border-box!important;overflow:hidden!important}.leaflet-container{width:100%!important;height:100%!important;position:absolute!important;inset:0!important;margin:0!important;padding:0!important;border:none!important;box-sizing:border-box!important}.leaflet-control-container{position:relative!important}.weather-header{background:var(--bg-tertiary);backdrop-filter:blur(10px);padding:16px 0;border-bottom:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.main-weather{padding:40px 0;text-align:center}.temperature-display{font-size:4rem;font-weight:300;line-height:1;margin:20px 0}.weather-condition{font-size:1.5rem;font-weight:500;margin:10px 0;color:var(--text-secondary)}.hourly-forecast,.ten-day-forecast{background:var(--bg-secondary);backdrop-filter:blur(10px);border-radius:12px;padding:20px;margin:20px 0;border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.weather-indicators{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin:20px 0}.indicator{background:var(--bg-secondary);backdrop-filter:blur(10px);border-radius:8px;padding:12px 20px;text-align:center;min-width:120px;border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.indicator-value{font-size:1.25rem;font-weight:600;margin:4px 0}.indicator-label{font-size:.875rem;color:var(--text-muted)}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.error{background:var(--error-bg);border:1px solid var(--error-border);border-radius:8px;padding:16px;margin:20px 0;text-align:center;color:var(--error-text);transition:background .3s ease,border-color .3s ease,color .3s ease}@media (max-width: 768px){.temperature-display{font-size:2.5rem}.weather-condition{font-size:1rem}.weather-indicators{gap:8px}.indicator{min-width:80px;padding:6px 12px}}@media (max-width: 480px){.temperature-display{font-size:2rem}.weather-condition{font-size:.9rem}.weather-indicators{gap:6px}.indicator{min-width:70px;padding:4px 8px}}@media (max-width: 360px){.temperature-display{font-size:1.8rem}.weather-condition{font-size:.85rem}.weather-indicators{gap:4px}.indicator{min-width:60px;padding:3px 6px}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;color:#333;background:linear-gradient(135deg,#1e3c72,#2a5298);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}:root{--primary-blue: #0066cc;--secondary-blue: #004499;--light-blue: #e6f2ff;--dark-blue: #003366;--accent-orange: #ff6600;--text-primary: #333;--text-secondary: #666;--text-light: #fff;--bg-primary: #fff;--bg-secondary: #f5f5f5;--border-color: #ddd;--shadow-sm: 0 2px 4px rgba(0,0,0,.1);--shadow-md: 0 4px 8px rgba(0,0,0,.15);--shadow-lg: 0 8px 16px rgba(0,0,0,.2)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.flex{display:flex}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.card{background:var(--bg-primary);border-radius:12px;padding:20px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);transition:all .3s ease}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--primary-blue);color:var(--text-light)}.btn-primary:hover{background:var(--secondary-blue);transform:translateY(-1px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}@media (max-width: 768px){body{font-size:14px}.container{padding:0 16px}.card{padding:16px;margin:8px}}@media (max-width: 480px){body{font-size:12px}.container{padding:0 12px}.card{padding:12px;margin:4px}}
