.detailed-view-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.detailed-view{background:#fff;border-radius:20px;max-height:90vh;max-width:1200px;overflow-y:auto;position:relative;width:95%}.detailed-view.loading{color:#666;padding:40px;text-align:center}.detailed-header{align-items:center;background:#fff;border-bottom:1px solid #eee;border-radius:20px 20px 0 0;display:flex;justify-content:space-between;padding:20px 30px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.detailed-header h2{color:#333;margin:0}.close-btn{align-items:center;background:none;border-radius:50%;color:#666;display:flex;font-size:2rem;height:40px;justify-content:center;padding:5px;width:40px}.close-btn:hover{background:#f5f5f5;color:#333}.detailed-content{padding:30px}.current-summary{margin-bottom:30px}.current-summary h3{color:#333;margin-bottom:15px}.summary-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{background:#f8f9fa;border-radius:10px;padding:15px;text-align:center}.summary-item span{color:#666;display:block;margin-bottom:5px}.summary-item strong{color:#333;font-size:1.5rem}.charts-section{margin-bottom:30px}.charts-section h3{color:#333;margin-bottom:20px}.charts-grid{grid-gap:30px;display:grid;gap:30px}.chart-container{background:#f8f9fa;border-radius:10px;padding:20px}.chart-container h4{color:#333;margin-bottom:15px}.charts-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.chart-wrapper{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:15px}.chart-wrapper h5{color:#666;margin-bottom:10px;text-align:center}.forecast-section{margin-bottom:30px}.forecast-section h3{color:#333;margin-bottom:20px}.forecast-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.forecast-day{background:#f8f9fa;border-radius:10px;padding:15px;text-align:center}.forecast-date{color:#333;font-weight:600;margin-bottom:10px}.forecast-temp{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:5px}.forecast-desc{color:#666;margin-bottom:10px;text-transform:capitalize}.forecast-details{color:#888;display:flex;font-size:.9rem;justify-content:space-around}.hourly-section h3{color:#333;margin-bottom:15px}.hourly-scroll{display:flex;gap:15px;overflow-x:auto;padding:10px 0}.hourly-item{background:#f8f9fa;border-radius:10px;min-width:100px;padding:15px;text-align:center}.hourly-time{color:#333;font-weight:600;margin-bottom:8px}.hourly-temp{color:#333;font-weight:700}.hourly-icon,.hourly-temp{font-size:1.2rem;margin-bottom:5px}.hourly-pop{color:#666;font-size:.9rem}@media (max-width:768px){.detailed-view{border-radius:0;max-height:100vh;width:100%}.detailed-content{padding:20px}.charts-row{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr 1fr}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.hourly-scroll{gap:10px}.hourly-item{min-width:80px;padding:10px}}.city-card{animation:fadeInCard 1s ease;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff12;border:1px solid #ffffff1f;border-radius:20px;box-shadow:0 10px 30px #00000059;cursor:pointer;overflow:hidden;padding:1.8rem 1.5rem;position:relative;transition:all .4s ease}.city-card:hover{border-color:#ffffff40;box-shadow:0 12px 40px #00000073;transform:translateY(-6px) scale(1.02)}.card-header{align-items:center;display:flex;justify-content:space-between}.card-header h3{color:#f8fafc;font-size:1.3rem;font-weight:600;letter-spacing:.3px}.card-actions{align-items:center;display:flex;gap:8px}.favorite-btn,.remove-btn{background:#ffffff1a;border:none;border-radius:8px;color:#f8fafc;cursor:pointer;font-size:1rem;padding:6px 10px;transition:all .25s ease}.favorite-btn:hover{background:#ffd70026;color:#facc15}.favorite-btn.active{background:#facc1533;color:#facc15}.remove-btn:hover{background:#ef444426;color:#ef4444}.weather-main{align-items:center;display:flex;justify-content:space-between;margin-top:1.2rem}.temperature{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-background-clip:text;font-size:3rem;font-weight:700}.weather-icon img{filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));height:70px;width:70px}.weather-description{color:#cbd5e1;font-size:1rem;letter-spacing:.3px;margin-top:.6rem;text-transform:capitalize}.weather-details{grid-gap:.8rem 1rem;color:#e2e8f0;display:grid;font-size:.95rem;gap:.8rem 1rem;grid-template-columns:repeat(2,1fr);margin-top:1.2rem}.detail-item{background:#ffffff0a;border:1px solid #ffffff0d;border-radius:8px;display:flex;justify-content:space-between;padding:6px 10px;transition:.3s ease}.detail-item:hover{background:#ffffff14}.city-card.loading{align-items:center;animation:pulse 1.8s infinite;background:#ffffff0a;border-radius:16px;display:flex;flex-direction:column;height:180px;justify-content:center}.loading-text{color:#94a3b8;font-size:.95rem}@keyframes fadeInCard{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.temperature{font-size:2.5rem}.city-card{padding:1.2rem}}.search-bar{margin:0 auto;max-width:500px}.search-bar,.search-input-container{position:relative}.search-input{background:#ffffffe6;border:none;border-radius:25px;box-shadow:0 4px 20px #0000001a;font-size:1rem;padding:15px 50px 15px 20px;transition:all .3s ease;width:100%}.search-input:focus{background:#fff;box-shadow:0 8px 30px #00000026;outline:none;transform:translateY(-2px)}.search-icon{color:#666;position:absolute;right:20px;top:50%;transform:translateY(-50%)}.suggestions-dropdown{background:#fff;border-radius:15px;box-shadow:0 8px 30px #00000026;left:0;margin-top:10px;max-height:200px;overflow:hidden;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.suggestion-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:15px 20px;transition:background-color .2s ease}.suggestion-item:hover{background:#f8f9fa}.suggestion-item:last-child{border-bottom:none}.settings-container{display:inline-block;position:relative}.settings-toggle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:12px;box-shadow:0 4px 10px #00000040;color:#f8fafc;cursor:pointer;font-size:.95rem;padding:10px 16px;transition:all .3s ease}.settings-toggle:hover{background:#fff3;box-shadow:0 6px 16px #0000004d;transform:translateY(-2px)}.settings-modal{animation:slideIn .4s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e293bbf;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 20px 40px #00000073;padding:1.2rem;position:absolute;right:0;top:120%;width:280px;z-index:20}.settings-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.4rem}.settings-header h3{color:#f1f5f9;font-size:1.1rem;font-weight:600;letter-spacing:.4px}.close-btn:hover{color:#f8fafc}.settings-group{margin-bottom:1.2rem}.settings-group h4{color:#e2e8f0;font-size:.95rem;font-weight:600;letter-spacing:.4px;margin-bottom:.5rem;text-transform:uppercase}.radio-group{display:flex;flex-direction:column;gap:8px}.radio-option{align-items:center;background:#ffffff0f;border:1px solid #ffffff0d;border-radius:8px;display:flex;gap:10px;padding:6px 10px;transition:background .3s ease}.radio-option:hover{background:#ffffff1f}.radio-option span{color:#cbd5e1;font-size:.9rem;letter-spacing:.3px}.radio-option input[type=radio]{accent-color:#38bdf8;height:16px;width:16px}.interval-select{background:#ffffff14;border:1px solid #ffffff26;border-radius:10px;color:#f1f5f9;cursor:pointer;font-size:.9rem;outline:none;padding:8px 12px;transition:all .3s ease;width:100%}.interval-select:hover{background:#ffffff26}.settings-info{border-top:1px solid #ffffff14;color:#94a3b8;font-size:.85rem;padding-top:.6rem;text-align:center}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:768px){.settings-modal{left:50%;transform:translateX(-50%);width:90vw}}.login-container{align-items:center;display:flex;justify-content:center;position:relative}.login-btn{background:linear-gradient(135deg,#2563eb,#38bdf8);border:none;border-radius:12px;box-shadow:0 6px 16px #00000040;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.4px;padding:10px 18px;transition:all .3s ease}.login-btn:hover{box-shadow:0 10px 24px #38bdf866;transform:translateY(-2px)}.login-modal{animation:fadeInUp .4s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e293bbf;border:1px solid #ffffff14;border-radius:18px;box-shadow:0 25px 50px #00000073;position:absolute;right:0;top:120%;width:320px;z-index:30}.login-content{color:#f8fafc;padding:1.6rem}.login-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.4rem}.login-header h3{font-size:1.2rem;font-weight:600;letter-spacing:.4px}.close-btn{background:#0000;border:none;color:#94a3b8;cursor:pointer;font-size:1.4rem;transition:color .3s ease}.close-btn:hover{color:#f1f5f9}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group label{color:#cbd5e1;display:block;font-size:.9rem;margin-bottom:4px}.form-group input{background:#ffffff14;border:1px solid #ffffff1f;border-radius:10px;color:#f8fafc;outline:none;padding:10px 12px;transition:all .3s ease;width:100%}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{background:#ffffff26;border-color:#38bdf8}.login-submit{background:linear-gradient(135deg,#06b6d4,#3b82f6);border:none;border-radius:10px;box-shadow:0 6px 16px #00000040;color:#fff;cursor:pointer;font-weight:600;margin-top:.5rem;padding:10px;transition:all .3s ease}.login-submit:hover{box-shadow:0 10px 22px #3b82f673;transform:translateY(-2px)}.demo-section{border-top:1px solid #ffffff14;margin-top:1.2rem;padding-top:1rem;text-align:center}.demo-section p{color:#94a3b8;font-size:.85rem;margin-bottom:.5rem}.demo-btn{background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;color:#e2e8f0;cursor:pointer;padding:8px 14px;transition:all .3s ease}.demo-btn:hover{background:#fff3;transform:scale(1.05)}.user-menu{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:14px;display:flex;gap:.8rem;padding:6px 12px;transition:background .3s ease}.user-menu:hover{background:#ffffff26}.user-avatar{border:2px solid #38bdf8;border-radius:50%;height:36px;object-fit:cover;width:36px}.user-name{color:#f1f5f9;font-size:.9rem;font-weight:500}.logout-btn{background:#ef444433;border:1px solid #ef44444d;border-radius:8px;color:#fca5a5;cursor:pointer;font-size:.8rem;padding:4px 8px;transition:all .3s ease}.logout-btn:hover{background:#ef444466;color:#fff}@media (max-width:768px){.login-modal{left:50%;transform:translateX(-50%);width:90vw}.user-menu{gap:.5rem}.user-name{display:none}}.dashboard{background:radial-gradient(circle at top left,#0a192f,#111827 70%);color:#f1f5f9;display:flex;flex-direction:column;font-family:Poppins,sans-serif;min-height:100vh;transition:all .3s ease-in-out}.dashboard-header{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff08;border-bottom:1px solid #ffffff14;padding:2rem 3rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.header-content{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between}.header-content h1{color:#60a5fa;font-size:2rem;font-weight:600;letter-spacing:.5px}.header-actions{gap:1.2rem}.header-actions,.last-updated{align-items:center;display:flex}.last-updated{color:#a5b4fc;font-size:.9rem;gap:.5rem;margin-top:.75rem;opacity:.9}.real-time-badge{animation:pulse 2s infinite;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:.4rem;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .6rem}.dashboard-main{align-items:flex-start;animation:fadeIn .6s ease-in-out;display:flex;flex:1 1;justify-content:center;padding:2.5rem 3rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cities-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));max-width:1300px;width:100%}.loading{color:#cbd5e1;font-size:1.2rem;text-align:center}.favorites-section{animation:fadeInUp .8s ease-in-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid #ffffff0d;border-radius:20px;box-shadow:0 0 40px #0003;margin:3rem 3rem 2rem;padding:2rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.favorites-section h2{color:#93c5fd;font-size:1.5rem;font-weight:500;margin-bottom:1rem}.favorites-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.analytics-section{animation:fadeInUp .8s ease-in-out;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:20px;box-shadow:inset 0 0 15px #ffffff0d;margin:2.5rem 3rem;padding:2rem}.analytics-section h2{color:#60a5fa;font-size:1.6rem;font-weight:600;margin-bottom:1rem}.chart-wrapper{background:#ffffff08;border-radius:16px;box-shadow:0 4px 40px #00000040;height:350px;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease;width:100%}.chart-wrapper:hover{box-shadow:0 8px 50px #0006;transform:translateY(-6px)}@media (max-width:768px){.dashboard-header{padding:1.5rem}.dashboard-main{padding:1rem}.analytics-section,.favorites-section{margin:1rem;padding:1rem}.cities-grid{grid-template-columns:1fr}.header-content h1{font-size:1.4rem}.dashboard-footer{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border-top:1px solid #ffffff14;color:#cbd5e1;display:flex;font-size:.95rem;justify-content:center;letter-spacing:.5px;margin-top:auto;padding:1.5rem 0;position:relative;text-align:center;width:100%;z-index:10}.dashboard-footer:before{animation:footerGlow 4s linear infinite;background:linear-gradient(90deg,#0000,#60a5fa,#0000);content:"";height:2px;left:0;opacity:.6;position:absolute;top:0;width:100%}@keyframes footerGlow{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.dashboard-footer span{color:#60a5fa;font-weight:500;transition:color .3s ease,text-shadow .3s ease}.dashboard-footer span:hover{color:#93c5fd;text-shadow:0 0 8px #60a5fa}@media (max-width:768px){.dashboard-footer{font-size:.85rem;padding:1rem 0}}}.App{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root,body{min-height:100vh}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#ffffff1a}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}
/*# sourceMappingURL=main.fda84bc4.css.map*/