*{box-sizing:border-box;font-family:Segoe UI,Roboto,Arial,sans-serif;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--primary-color:#3498db;--secondary-color:#2980b9;--accent-color:#e74c3c;--text-color:#333;--light-text:#f8f9fa;--dark-text:#343a40;--background-light:#f8f9fa;--card-background:hsla(0,0%,100%,.85);--shadow-color:rgba(0,0,0,.1);--header-height:70px;--footer-height:60px;--transition-speed:0.3s;--border-radius:15px;--main-padding:20px}html{touch-action:manipulation;-webkit-tap-highlight-color:transparent;height:100%}body,html{height:100%;margin:0;max-width:100%;overscroll-behavior:none;padding:0}body{background-attachment:fixed;background-image:url(https://images.unsplash.com/photo-1534088568595-a066f410bcda);background-position:50%;background-size:cover;color:var(--text-color);display:block;transition:background-image 1s ease}body.dark-mode{--text-color:#f8f9fa;--light-text:#f8f9fa;--dark-text:#f8f9fa;--card-background:rgba(33,37,41,.85);--shadow-color:rgba(0,0,0,.3);--background-light:#212529}::-webkit-scrollbar{height:0;width:0}.app-header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(33,37,41,.8);box-shadow:0 2px 15px rgba(0,0,0,.2);color:#fff;height:var(--header-height);justify-content:space-between;padding:0 30px;position:sticky;top:0;z-index:100}.app-header,.app-header .logo{align-items:center;display:flex}.app-header .logo{font-size:24px;font-weight:700}.app-header .logo i{color:var(--primary-color);font-size:28px;margin-right:10px}.app-header .nav-links{display:flex;gap:20px}.app-header .nav-links a{color:var(--light-text);font-weight:500;text-decoration:none;transition:color var(--transition-speed)}.app-header .nav-links a:hover{color:var(--primary-color)}.main-content{margin:0;overflow-y:auto;padding:var(--main-padding);-webkit-overflow-scrolling:touch}.weather-container{margin:0 auto;max-width:900px;padding:15px 0;position:relative;width:100%}.theme-toggle{align-items:center;background-color:var(--card-background);border-radius:50%;box-shadow:0 3px 15px var(--shadow-color);cursor:pointer;display:flex;height:45px;justify-content:center;position:absolute;right:20px;top:20px;transition:all var(--transition-speed);width:45px;z-index:10}.theme-toggle:hover{transform:rotate(15deg)}.theme-toggle i{color:var(--text-color);font-size:20px}.weather-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:0 10px 30px var(--shadow-color);overflow:hidden;padding:30px;position:relative;transition:all var(--transition-speed);width:100%}.header{margin-bottom:25px}.search-box{display:flex;margin-bottom:20px;width:100%}.search-box input{background-color:hsla(0,0%,100%,.2);border:none;border-radius:30px 0 0 30px;color:var(--text-color);flex:1;font-size:16px;outline:none;padding:12px 20px;transition:all var(--transition-speed)}.search-box input::placeholder{color:rgba(0,0,0,.4)}body.dark-mode .search-box input::placeholder{color:hsla(0,0%,100%,.4)}.search-box input:focus{background-color:hsla(0,0%,100%,.3)}.search-box button{align-items:center;background-color:var(--primary-color);border:none;border-radius:0 30px 30px 0;color:#fff;cursor:pointer;display:flex;justify-content:center;transition:background-color var(--transition-speed);width:50px}.search-box button:hover{background-color:var(--secondary-color)}.city-info{align-items:center;display:flex;justify-content:space-between}.city-name{font-size:24px;font-weight:600;margin-bottom:5px}.city-name,.date-time{color:var(--text-color)}.date-time{font-size:14px;opacity:.8}.location-icon{color:var(--primary-color);font-size:24px}.weather-animation{height:120px;margin:20px 0;overflow:hidden;position:relative}.sun{background:radial-gradient(circle,#ff9500 0,#fc0 100%);box-shadow:0 0 40px rgba(255,204,0,.7);height:60px;left:50%;opacity:.2;top:20px;transform:translateX(-50%);width:60px}.cloud,.sun{border-radius:50%;position:absolute;transition:opacity 1s ease}.cloud{background-color:hsla(0,0%,100%,.9);box-shadow:0 5px 15px rgba(0,0,0,.1);height:40px;opacity:.5;width:40px}.cloud-1{animation:floatCloud 15s ease-in-out infinite;left:30%;top:30px}.cloud-2{animation:floatCloud 20s ease-in-out infinite reverse;height:50px;left:60%;top:50px;width:50px}@keyframes floatCloud{0%,to{transform:translateX(0)}50%{transform:translateX(20px)}}.rain{display:none;height:100%;width:100%}.rain,.raindrop{position:absolute}.raindrop{animation:rainfall 1s linear infinite;background:rgba(174,194,224,.6);border-radius:50%;width:2px}@keyframes rainfall{0%{opacity:.8;transform:translateY(0)}80%{opacity:.5}to{opacity:0;transform:translateY(100px)}}.current-weather{align-items:center;border-bottom:1px solid rgba(0,0,0,.1);border-top:1px solid rgba(0,0,0,.1);display:flex;justify-content:space-between;margin-bottom:25px;padding:15px 0}body.dark-mode .current-weather{border-color:hsla(0,0%,100%,.1)}.temp-section{flex:1}.temperature{color:var(--text-color);cursor:pointer;font-size:48px;font-weight:700;transition:transform var(--transition-speed)}.temperature:hover{transform:scale(1.05)}.weather-description{color:var(--text-color);font-size:18px;opacity:.8;text-transform:capitalize}.weather-icon{filter:drop-shadow(0 3px 5px rgba(0,0,0,.2));height:100px;transition:transform var(--transition-speed);width:100px}.weather-icon:hover{transform:scale(1.1) rotate(5deg)}.weather-details{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:25px;padding:10px 0}.weather-detail{align-items:center;background-color:hsla(0,0%,100%,.2);border-radius:12px;display:flex;flex:1;flex-direction:column;min-width:120px;padding:15px;transition:transform var(--transition-speed)}.weather-detail:hover{transform:translateY(-5px)}.weather-detail i{color:var(--primary-color);font-size:24px;margin-bottom:10px}.detail-value{color:var(--text-color);font-size:20px;font-weight:600}.detail-label{color:var(--text-color);font-size:12px;margin-top:5px;opacity:.7}.forecast{padding-top:10px}.forecast-title{color:var(--text-color);font-size:18px;font-weight:600;margin-bottom:15px}.forecast-container{display:flex;gap:15px;overflow-x:auto;padding:5px 0 15px;-ms-overflow-style:none;scrollbar-width:none}.forecast-container::-webkit-scrollbar{display:none}.forecast-item{align-items:center;background-color:hsla(0,0%,100%,.2);border-radius:12px;display:flex;flex-direction:column;min-width:120px;padding:15px 10px;transition:transform var(--transition-speed)}.forecast-item:hover{transform:translateY(-5px)}.forecast-day{color:var(--text-color);font-size:14px;font-weight:600;margin-bottom:5px}.forecast-icon{height:50px;margin:5px 0;width:50px}.forecast-temp{color:var(--text-color);font-size:18px;font-weight:600}.forecast-desc{color:var(--text-color);font-size:12px;margin-top:5px;opacity:.8;text-align:center;text-transform:capitalize}.error-message,.loading{align-items:center;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background-color:var(--card-background);border-radius:var(--border-radius);display:none;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:100}.loader{animation:spin 1s linear infinite;border:5px solid rgba(0,0,0,.1);border-radius:50%;border-top:5px solid var(--primary-color);height:50px;margin-bottom:15px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.error-message i{color:var(--accent-color);font-size:40px;margin-bottom:15px}.app-footer{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(33,37,41,.8);box-shadow:0 -2px 15px rgba(0,0,0,.1);color:#fff;display:flex;font-size:14px;height:var(--footer-height);justify-content:space-between;margin-top:20px;padding:0 30px}.app-footer .footer-links{display:flex;gap:20px}.app-footer .footer-links a{color:var(--light-text);text-decoration:none;transition:color var(--transition-speed)}.app-footer .footer-links a:hover{color:var(--primary-color)}@media (max-width:768px){.app-footer,.app-header{padding:0 15px}.weather-card{padding:20px}.city-name{font-size:20px}.temperature{font-size:40px}.weather-details{flex-direction:column}.weather-detail{margin-bottom:10px;width:100%}.nav-links{display:none}.mobile-menu-icon{display:block}}@media (max-width:576px){:root{--main-padding:10px}.app-header .logo span{display:none}.app-header .logo i{margin-right:0}.temperature{font-size:36px}.weather-icon{height:80px;width:80px}.forecast-item{min-width:100px}.app-footer{flex-direction:column;font-size:12px;gap:5px;height:auto;justify-content:center;padding:10px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.weather-card{animation:fadeIn .5s ease-out}.mobile-menu-icon{cursor:pointer;display:none;font-size:24px}.mobile-menu{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(33,37,41,.95);display:flex;flex-direction:column;left:0;position:fixed;top:var(--header-height);transform:translateY(-100%);transition:transform .3s ease;width:100%;z-index:99}.mobile-menu.open{transform:translateY(0)}.mobile-menu a{border-bottom:1px solid hsla(0,0%,100%,.1);color:#fff;padding:15px 30px;text-decoration:none;transition:background-color .3s}.mobile-menu a:hover{background-color:hsla(0,0%,100%,.1)}@media (max-width:768px){.mobile-menu-icon{display:block}}.page-container{animation:fadeIn .5s ease-out;margin:0 auto;max-width:1200px;overflow-y:auto;padding:20px;width:100%;-ms-overflow-style:none;scrollbar-width:none}.page-container::-webkit-scrollbar{display:none}.content-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:var(--card-background);box-shadow:0 10px 30px var(--shadow-color);padding:30px}.content-card,.map-container{border-radius:var(--border-radius)}.map-container{height:600px;margin:20px 0;overflow:hidden;position:relative}#weather-map{height:100%;width:100%;z-index:1}.map-controls{background:var(--card-background);border-radius:30px;bottom:20px;box-shadow:0 2px 10px var(--shadow-color);display:flex;gap:10px;left:50%;padding:10px;position:absolute;transform:translateX(-50%);z-index:1000}.map-button{background:transparent;border:2px solid var(--primary-color);border-radius:20px;color:var(--text-color);cursor:pointer;font-weight:500;padding:8px 16px;transition:all var(--transition-speed)}.map-button.active,.map-button:hover{background-color:var(--primary-color);color:#fff}.extended-forecast{margin-top:20px}.forecast-filters{display:flex;gap:10px;margin-bottom:20px}.forecast-filter{background:transparent;border:2px solid var(--primary-color);border-radius:20px;color:var(--text-color);cursor:pointer;padding:8px 16px;transition:all var(--transition-speed)}.forecast-filter.active{background-color:var(--primary-color);color:#fff}#forecast-chart{background:hsla(0,0%,100%,.05);border-radius:var(--border-radius);height:400px!important;padding:20px;width:100%!important}body.dark-mode .map-button{color:var(--light-text)}body.dark-mode #forecast-chart{background:rgba(0,0,0,.2)}body.dark-mode .leaflet-control-attribution{background:hsla(0,0%,100%,.8)!important;color:#333!important}.about-content{padding:20px 0;text-align:center}.about-content p{font-size:1.1em;line-height:1.6;margin-bottom:30px}.features-grid{display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:40px}.feature{background-color:hsla(0,0%,100%,.1);border-radius:var(--border-radius);padding:20px;text-align:center;transition:transform var(--transition-speed)}.feature:hover{transform:translateY(-5px)}.feature i{color:var(--primary-color);font-size:2em;margin-bottom:15px}.feature h3{color:var(--text-color);margin-bottom:10px}.policy-content,.terms-content{line-height:1.6}.policy-content h3,.terms-content h3{color:var(--text-color);margin:25px 0 15px}.policy-content ul{margin:15px 0;padding-left:20px}.policy-content li{margin-bottom:10px}.contact-form{margin:0 auto;max-width:600px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-color);display:block;margin-bottom:5px}.form-group input,.form-group textarea{background-color:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:var(--border-radius);color:var(--text-color);padding:10px;width:100%}.form-group textarea{height:150px;resize:vertical}.submit-button{background-color:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-size:1.1em;padding:12px;transition:background-color var(--transition-speed);width:100%}.submit-button:hover{background-color:var(--secondary-color)}.form-notification{align-items:center;animation:fadeIn .3s ease-out;border-radius:var(--border-radius);display:flex;gap:10px;margin-top:20px;padding:15px}.form-notification.success{background-color:rgba(46,204,113,.2);border:1px solid #2ecc71}.form-notification.error{background-color:rgba(231,76,60,.2);border:1px solid #e74c3c}.form-notification i{font-size:20px}.form-notification.success i{color:#2ecc71}.form-notification.error i{color:#e74c3c}.form-notification p{color:var(--text-color);margin:0}@media (max-width:768px){.page-container{padding:10px}.map-container{height:400px}.map-controls{bottom:10px;flex-wrap:wrap;justify-content:center;max-width:300px;width:90%}#forecast-chart{height:300px!important;padding:10px}.features-grid{grid-template-columns:1fr}}