*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--primary:#6C63FF;--primary-light:#8B85FF;--accent:#00D4AA;--accent2:#FF6B6B;--glass:rgba(255,255,255,0.08);--glass-border:rgba(255,255,255,0.12);--glass-strong:rgba(255,255,255,0.14);--text:#FFF;--text-dim:rgba(255,255,255,0.6);--text-dimmer:rgba(255,255,255,0.35);--radius:20px;--radius-sm:12px;--radius-xs:8px;--transition:0.3s cubic-bezier(0.4,0,0.2,1)}
html{scroll-behavior:smooth}body{font-family:'Inter',sans-serif;background:#0a0a1a;color:var(--text);overflow-x:hidden;min-height:100vh}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-0.02em}
a{color:var(--accent);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-light)}
.bg-gradient{position:fixed;inset:0;z-index:0;transition:background 2s ease}
.orb{position:fixed;border-radius:50%;filter:blur(80px);opacity:.3;animation:orbF 20s infinite ease-in-out;pointer-events:none;z-index:0}
.orb-1{width:600px;height:600px;background:var(--primary);top:-200px;left:-200px}
.orb-2{width:500px;height:500px;background:var(--accent);bottom:-150px;right:-150px;animation-delay:-7s}
.orb-3{width:400px;height:400px;background:var(--accent2);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}
@keyframes orbF{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(50px,-80px) scale(1.1)}50%{transform:translate(-30px,60px) scale(.9)}75%{transform:translate(70px,40px) scale(1.05)}}
.particle{position:fixed;border-radius:50%;pointer-events:none;z-index:0}
.particle.rain{animation:rainF linear infinite;height:15px;width:1.5px;border-radius:0;background:linear-gradient(transparent,rgba(174,194,224,.5))}
.particle.snow{animation:snowF linear infinite;width:4px;height:4px;background:rgba(255,255,255,.8);border-radius:50%}
@keyframes rainF{0%{transform:translateY(-100vh);opacity:1}100%{transform:translateY(100vh) translateX(-20px);opacity:.3}}
@keyframes snowF{0%{transform:translateY(-100vh) rotate(0deg);opacity:1}100%{transform:translateY(100vh) translateX(50px) rotate(360deg);opacity:.2}}
.app{position:relative;z-index:1;min-height:100vh}.container{max-width:1400px;margin:0 auto;padding:0 24px}
.page{display:none;animation:fadeI .5s ease}.page.active{display:block}
@keyframes fadeI{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:var(--transition)}
.navbar.scrolled{background:rgba(10,10,26,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 24px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:700;cursor:pointer}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:1.2rem;animation:logoP 3s infinite ease-in-out}
@keyframes logoP{0%,100%{box-shadow:0 0 20px rgba(108,99,255,.3)}50%{box-shadow:0 0 40px rgba(0,212,170,.4)}}
.nav-links{display:flex;gap:8px;align-items:center}
.nav-link{padding:8px 18px;border-radius:var(--radius-xs);color:var(--text-dim);font-size:.9rem;font-weight:500;transition:var(--transition);cursor:pointer;border:none;background:none;font-family:inherit}
.nav-link:hover,.nav-link.active{color:var(--text);background:var(--glass)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition)}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(10,10,26,.98);backdrop-filter:blur(20px);z-index:200;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-menu.open{display:flex}.mobile-menu .nav-link{font-size:1.3rem;padding:12px 30px}
.close-menu{position:absolute;top:20px;right:24px;font-size:2rem;cursor:pointer;color:var(--text);background:none;border:none}
.hero{padding:140px 0 60px;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:50px;background:var(--glass);border:1px solid var(--glass-border);font-size:.8rem;color:var(--text-dim);margin-bottom:24px;animation:fadeI 1s ease .2s both}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.1;margin-bottom:16px;animation:fadeI 1s ease .4s both}
.gradient-text{background:linear-gradient(135deg,var(--primary-light),var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:1.15rem;color:var(--text-dim);max-width:500px;margin:0 auto 40px;animation:fadeI 1s ease .6s both}
.search-box{max-width:600px;margin:0 auto;position:relative;animation:fadeI 1s ease .8s both}
.search-input{width:100%;padding:20px 60px 20px 24px;border-radius:60px;border:1px solid var(--glass-border);background:var(--glass-strong);backdrop-filter:blur(20px);color:var(--text);font-size:1rem;font-family:inherit;outline:none;transition:var(--transition)}
.search-input::placeholder{color:var(--text-dimmer)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 30px rgba(108,99,255,.2)}
.search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-size:1.2rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.search-btn:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 4px 20px rgba(108,99,255,.4)}
.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:rgba(20,20,40,.95);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;display:none;z-index:50;max-height:300px;overflow-y:auto}
.search-suggestions.show{display:block}
.suggestion-item{padding:14px 20px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.05)}
.suggestion-item:hover{background:var(--glass)}.suggestion-item .icon{font-size:1.2rem;opacity:.5}
.weather-display{display:none;padding:20px 0 60px;animation:fadeI .6s ease}.weather-display.show{display:block}
.weather-main{display:grid;grid-template-columns:1.2fr 1fr;gap:30px;margin-bottom:30px}
.current-card{background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius);padding:40px;position:relative;overflow:hidden}
.current-card::before{content:'';position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,rgba(108,99,255,.15),transparent 70%);pointer-events:none}
.current-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}
.location-info h2{font-size:1.5rem;margin-bottom:4px}.location-info .coords{font-size:.8rem;color:var(--text-dim)}
.live-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:50px;background:rgba(0,212,170,.15);color:var(--accent);font-size:.75rem;font-weight:600}
.live-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:liveP 1.5s infinite}
@keyframes liveP{0%{box-shadow:0 0 0 0 rgba(0,212,170,.5)}70%{box-shadow:0 0 0 10px rgba(0,212,170,0)}100%{box-shadow:0 0 0 0 rgba(0,212,170,0)}}
.weather-visual{display:flex;align-items:center;gap:30px;margin-bottom:30px}
.weather-icon-large{font-size:6rem;animation:iconB 4s infinite ease-in-out}
@keyframes iconB{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.temp-section .temp{font-size:5rem;font-weight:800;line-height:1;letter-spacing:-.04em}
.temp-section .feels-like{font-size:.9rem;color:var(--text-dim);margin-top:4px}
.condition-text{font-size:1.2rem;font-weight:600;margin-bottom:8px;text-transform:capitalize}
.condition-desc{font-size:.85rem;color:var(--text-dim)}
.time-info{display:flex;gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid var(--glass-border)}
.time-item{font-size:.85rem;color:var(--text-dim)}.time-item span{color:var(--text);font-weight:600}
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.detail-card{background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:20px;transition:var(--transition)}
.detail-card:hover{background:var(--glass-strong);transform:translateY(-2px);border-color:rgba(108,99,255,.3)}
.detail-card .label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.detail-card .value{font-size:1.5rem;font-weight:700}.detail-card .unit{font-size:.85rem;color:var(--text-dim);font-weight:400}
.detail-card .bar{margin-top:8px;height:4px;border-radius:2px;background:rgba(255,255,255,.1);overflow:hidden}
.detail-card .bar-fill{height:100%;border-radius:2px;transition:width 1s ease}
.bar-uv{background:linear-gradient(90deg,#4CAF50,#FFEB3B,#F44336)}.bar-humidity{background:linear-gradient(90deg,var(--primary),var(--accent))}.bar-wind{background:linear-gradient(90deg,var(--accent),var(--accent2))}
.section-title{font-size:1.3rem;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.section-title .line{flex:1;height:1px;background:var(--glass-border)}
.hourly-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;scrollbar-width:thin;scrollbar-color:var(--glass-border) transparent}
.hourly-scroll::-webkit-scrollbar{height:6px}.hourly-scroll::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}
.hourly-item{flex:0 0 90px;background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px 12px;text-align:center;transition:var(--transition);cursor:default}
.hourly-item:hover{background:var(--glass-strong);transform:translateY(-4px);border-color:var(--primary)}
.hourly-item.now{background:linear-gradient(135deg,rgba(108,99,255,.2),rgba(0,212,170,.15));border-color:var(--primary)}
.hourly-item .time{font-size:.75rem;color:var(--text-dim);margin-bottom:8px}.hourly-item .h-icon{font-size:1.5rem;margin-bottom:8px}.hourly-item .h-temp{font-size:1rem;font-weight:700}.hourly-item .h-precip{font-size:.7rem;color:var(--accent);margin-top:4px}
.forecast-grid{display:grid;gap:12px}
.forecast-row{display:grid;grid-template-columns:120px 50px 1fr 80px 80px;align-items:center;gap:16px;background:var(--glass);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px 20px;transition:var(--transition)}
.forecast-row:hover{background:var(--glass-strong);transform:translateX(4px);border-color:rgba(108,99,255,.3)}
.forecast-row .day{font-weight:600;font-size:.95rem}.forecast-row .day .date{font-size:.75rem;color:var(--text-dim);font-weight:400}
.forecast-row .f-icon{font-size:1.5rem;text-align:center}
.temp-range{display:flex;align-items:center;gap:8px}
.temp-bar{flex:1;height:6px;border-radius:3px;background:rgba(255,255,255,.08);position:relative;overflow:hidden}
.temp-bar-fill{position:absolute;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary),var(--accent2));transition:width 1s ease,left 1s ease}
.forecast-row .lo{font-size:.85rem;color:var(--text-dim);min-width:36px;text-align:right}
.forecast-row .hi{font-size:.95rem;font-weight:700;min-width:36px;text-align:right}
.forecast-row .f-precip{font-size:.8rem;color:var(--accent);text-align:right}
.map-section{margin-top:30px}.map-container{width:100%;height:350px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--glass-border);position:relative;background:var(--glass)}
.map-iframe{width:100%;height:100%;border:none;filter:invert(.9) hue-rotate(180deg) saturate(.5) brightness(.7)}
.map-overlay{position:absolute;bottom:16px;left:16px;padding:10px 18px;background:rgba(10,10,26,.8);backdrop-filter:blur(10px);border-radius:var(--radius-xs);font-size:.8rem;color:var(--text-dim)}
.loading{display:none;justify-content:center;align-items:center;flex-direction:column;gap:20px;padding:80px 0}.loading.show{display:flex}
.loader{width:60px;height:60px;border-radius:50%;border:3px solid var(--glass-border);border-top-color:var(--primary);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:var(--text-dim);font-size:.9rem;animation:pulse 1s ease infinite alternate}
@keyframes pulse{from{opacity:.5}to{opacity:1}}
.footer{padding:60px 0 30px;border-top:1px solid var(--glass-border);margin-top:60px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand .logo{margin-bottom:12px}.footer-brand p{font-size:.85rem;color:var(--text-dim);max-width:280px;line-height:1.6}
.footer h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:16px}
.footer ul{list-style:none}.footer li{margin-bottom:10px}.footer li a{color:var(--text-dim);font-size:.9rem;transition:var(--transition)}.footer li a:hover{color:var(--text)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--glass-border);font-size:.8rem;color:var(--text-dim)}
.legal-page{max-width:800px;margin:0 auto;padding:140px 24px 60px}
.legal-page h1{font-size:2.2rem;margin-bottom:8px}.legal-page .updated{color:var(--text-dim);font-size:.85rem;margin-bottom:40px}
.legal-page h2{font-size:1.3rem;margin:32px 0 12px;color:var(--primary-light)}
.legal-page p{color:var(--text-dim);line-height:1.8;margin-bottom:16px}
.legal-page ul{color:var(--text-dim);padding-left:24px;margin-bottom:16px;line-height:1.8}
.about-hero{text-align:center;padding:140px 0 60px}.about-hero h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:16px}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:20px 0 60px}
.feature-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:32px;transition:var(--transition)}
.feature-card:hover{transform:translateY(-4px);border-color:var(--primary);background:var(--glass-strong)}
.feature-card .f-emoji{font-size:2.5rem;margin-bottom:16px}.feature-card h3{font-size:1.1rem;margin-bottom:8px}.feature-card p{font-size:.9rem;color:var(--text-dim);line-height:1.6}
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);padding:14px 28px;background:rgba(20,20,40,.95);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xs);font-size:.9rem;z-index:300;transition:.4s ease;opacity:0}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}.toast.error{border-color:var(--accent2)}
.ad-slot{background:var(--glass);border:1px dashed var(--glass-border);border-radius:var(--radius-xs);padding:16px;text-align:center;color:var(--text-dimmer);font-size:.75rem;margin:24px 0;min-height:90px;display:flex;align-items:center;justify-content:center}
@media(max-width:1024px){.weather-main{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}.hero{padding:120px 0 40px}.hero h1{font-size:2.2rem}.weather-visual{flex-direction:column;text-align:center;gap:16px}.temp-section .temp{font-size:3.5rem}.details-grid{grid-template-columns:1fr 1fr}.forecast-row{grid-template-columns:80px 40px 1fr 60px;font-size:.85rem;gap:8px;padding:12px}.forecast-row .f-precip:last-child{display:none}.footer-grid{grid-template-columns:1fr;gap:24px}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.current-card{padding:24px}.time-info{flex-direction:column;gap:8px}}
@media(max-width:480px){.details-grid{grid-template-columns:1fr}.weather-icon-large{font-size:4rem}.temp-section .temp{font-size:3rem}}
