:root{--bg-overlay:rgba(255,255,255,0.8);--card:rgba(255,255,255,0.9);--card-item:#ffffff;--accent:#0077ff;--text:#222;--subtext:#555;--radius:1.2rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;color:var(--text);display:flex;flex-direction:column;align-items:center;min-height:100vh;overflow-x:hidden;position:relative;background:linear-gradient(180deg,#6fb8f3 0,#cde8ff 100%);transition:background 0s}body::before{content:"";position:absolute;inset:0;background:var(--bg-overlay);z-index:0;opacity:1;transition:opacity .6s ease;will-change:opacity}footer,header,main{z-index:1;width:100%;max-width:900px;padding:1.5rem}header{text-align:center;margin-top:.3rem;margin-bottom:.2rem}h1{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-size:2.4rem;font-weight:700;color:var(--h1-color);letter-spacing:.5px;text-transform:uppercase;margin-bottom:.4rem;text-shadow:0 2px 6px var(--h1-shadow);-webkit-text-stroke:1px var(--h1-stroke);transition:opacity .4s ease,transform .4s ease}h1::after{content:"";display:block;width:60px;height:3px;margin:.5rem auto 0;border-radius:2px;background:linear-gradient(90deg,rgba(100,100,100,.4),transparent)}h2{color:var(--h2-color)}h3{font-family:Montserrat,sans-serif;color:var(--h3-color);font-weight:600;font-size:1.2rem;margin-bottom:.5rem;letter-spacing:.3px;transition:opacity .4s ease,transform .4s ease}p{color:var(--subtext);transition:opacity .4s ease,transform .4s ease}.forecast-daily,.forecast-hourly,.weather-now{background:var(--card);border-radius:var(--radius);box-shadow:0 6px 20px rgba(0,0,0,.1);margin:1rem 0;padding:1.5rem;text-align:center;transition:opacity .4s ease,transform .4s ease}.weather-now img{width:130px;height:130px}.weather-tip{margin-top:1.2rem;padding-top:.8rem;border-top:1px solid rgba(0,0,0,.1);font-size:.95rem;color:var(--subtext);font-style:italic;opacity:.9;transition:all .6s ease,border-color .6s ease}.weather-tip strong{font-weight:600;color:var(--accent);font-style:normal}.temperature{font-size:3rem;font-weight:600;color:var(--accent);transition:opacity .4s ease,transform .4s ease}.forecast-daily,.forecast-hourly{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.forecast-item{background:var(--card-item);border-radius:var(--radius);padding:1rem;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:opacity .4s ease,transform .4s ease}.forecast-item img{width:50px;height:50px;margin-bottom:.3rem}.forecast-item small{display:block;margin-top:.2rem;font-size:.8rem}.forecast-daily,.forecast-hourly,.weather-now{position:relative;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .8s ease,transform .6s ease,visibility 0s linear .8s;width:100%;left:0}.forecast-daily.visible,.forecast-hourly.visible,.weather-now.visible{opacity:1;visibility:visible;transform:translateY(0);transition-delay:0s}.loader{margin:.5rem auto;border:3px solid rgba(200,200,200,.3);border-top:3px solid var(--accent);border-radius:50%;width:18px;height:18px;animation:spin .8s linear infinite;opacity:.6}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}footer{text-align:center;color:var(--subtext);font-size:.85rem;margin-top:auto;transition:opacity .4s ease,transform .4s ease}footer a{color:var(--accent);text-decoration:none}.current-top{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.current-info{display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.current-desc{color:var(--subtext);font-weight:500;margin-top:.2rem}.current-extra{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;margin-top:1.5rem;text-align:center}.current-extra div{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--card-item);border-radius:var(--radius);padding:.8rem .5rem;max-width:120px;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:opacity .4s ease,transform .4s ease}.current-extra div:hover{transform:translateY(-3px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.extra-label{font-size:1rem;font-weight:600;color:var(--accent);margin-bottom:.3rem}.current-extra .mini-icon{width:26px;height:26px;margin-bottom:.25rem;opacity:.95;transform:none;transition:transform .25s ease,opacity .25s ease}.current-extra div:hover .mini-icon{transform:scale(1.05);opacity:1}.current-extra p{font-size:.95rem;font-weight:500;color:var(--text);margin:0;line-height:1.2}#currentWeather,#forecastDaily,#forecastHourly{min-height:180px}#weatherTip{min-height:40px;display:block}.climate-default,.forecast-daily,.forecast-hourly,.intro,.promo-card,.weather-now{will-change:transform,opacity}@media (max-width:600px){h1{font-size:1.6rem}.temperature{font-size:2.5rem}.current-extra{grid-template-columns:repeat(2,1fr);gap:.8rem}.current-extra div{padding:.7rem .4rem;max-width:110px}.extra-label{font-size:.9rem}.current-extra .mini-icon{width:22px;height:22px}.current-extra p{font-size:.9rem}}.intro{text-align:center;background:var(--card);border-radius:var(--radius);box-shadow:0 4px 12px rgba(0,0,0,.08);padding:1.5rem;margin:1rem 0 2rem;margin-top:.5rem;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:opacity .4s ease,transform .4s ease}.intro h2{font-family:Montserrat,sans-serif;font-size:1.6rem;color:var(--accent);margin-bottom:.6rem;letter-spacing:.4px;transition:opacity .4s ease,transform .4s ease}.intro p{font-family:Poppins,sans-serif;font-size:1rem;color:var(--text);opacity:.85;line-height:1.6;max-width:700px;margin:0 auto;transition:opacity .4s ease,transform .4s ease}.climate-default{background:var(--card);border-radius:var(--radius);box-shadow:0 4px 14px rgba(0,0,0,.08);text-align:center;padding:1.8rem 1rem 2rem;margin:1.5rem auto 2rem;max-width:950px;transition:opacity .4s ease,transform .4s ease}.climate-default h2{color:var(--accent);font-family:Montserrat,sans-serif;font-size:1.5rem;margin-bottom:1.4rem;letter-spacing:.4px}.season-temps{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.2rem;justify-items:center;align-items:stretch}.season{display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--card-item);border-radius:var(--radius);padding:1.3rem 1rem;width:100%;max-width:200px;box-shadow:0 2px 10px rgba(0,0,0,.06);transition:transform .3s ease,box-shadow .3s ease}.season:hover{transform:translateY(-4px);box-shadow:0 4px 14px rgba(0,0,0,.1)}.season-icon{width:45px;height:45px;margin-bottom:.5rem;opacity:.95}.season span{font-weight:600;color:var(--accent);font-size:1rem;margin-bottom:.25rem;letter-spacing:.3px}.season p{color:var(--text);font-size:.95rem;font-weight:500;margin:0}.promo-rrss{width:100%;max-width:900px;margin:2rem auto 1.5rem;display:flex;justify-content:center}.promo-card{display:flex;align-items:center;gap:1.2rem;background:var(--card);border-radius:var(--radius);box-shadow:0 6px 18px rgba(0,0,0,.08);padding:1rem 1.5rem;transition:transform .3s ease,box-shadow .3s ease}.promo-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,.12)}.promo-icon{width:50px;height:50px;flex-shrink:0}.promo-text h3{font-family:Montserrat,sans-serif;color:var(--accent);font-size:1.2rem;margin-bottom:.2rem}.promo-text p{font-size:.95rem;color:var(--subtext);margin-bottom:.6rem}.promo-btn{background:var(--accent);color:#fff;padding:.4rem 1rem;border-radius:20px;font-weight:600;text-decoration:none;transition:opacity .4s ease,transform .4s ease}.promo-btn:hover{background:#005fcc;transform:translateY(-1px)}.tiktok-embed-section{text-align:center;background:var(--card);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.08);padding:1.5rem;margin:2rem auto;max-width:500px}.tiktok-embed-section h3{font-family:Montserrat,sans-serif;color:var(--accent);margin-bottom:1rem;font-size:1.2rem}.load-more-wrapper{text-align:center;margin-top:.8rem;margin-bottom:1.2rem}.load-more-wrapper .promo-btn{padding:.5rem 1.2rem;border-radius:25px;font-size:.95rem;font-weight:600;background:var(--accent);color:#fff;box-shadow:0 3px 10px rgba(0,0,0,.08);transition:all .25s ease}.load-more-wrapper .promo-btn:hover{background:#005fcc;transform:translateY(-2px)}