@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap";html,body{width:100%;min-height:100vh;margin:0;padding:0}#root{width:100%;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}.app{background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);justify-content:center;align-items:flex-start;min-height:100vh;padding:20px;font-family:Nunito,sans-serif;transition:background 1.2s;display:flex;position:relative;overflow-x:hidden}.orb{filter:blur(60px);pointer-events:none;z-index:0;border-radius:50%;position:absolute}.orb-1{background:#6366f14d;width:300px;height:300px;animation:8s ease-in-out infinite float;top:-80px;left:-80px}.orb-2{background:#ec489933;width:250px;height:250px;animation:10s ease-in-out 2s infinite float;bottom:10%;right:-60px}.orb-3{background:#06b6d433;width:200px;height:200px;animation:7s ease-in-out 4s infinite float;top:45%;left:55%}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-25px)scale(1.05)}}.particle{pointer-events:none;z-index:0;background:#ffffff26;border-radius:50%;animation:12s ease-in-out infinite drift;position:absolute}.p-1{width:8px;height:8px;animation-delay:0s;top:20%;left:15%}.p-2{width:5px;height:5px;animation-delay:2s;top:60%;left:80%}.p-3{width:10px;height:10px;animation-delay:4s;top:80%;left:25%}.p-4{width:6px;height:6px;animation-delay:6s;top:15%;left:70%}.p-5{width:8px;height:8px;animation-delay:1s;top:45%;left:5%}.p-6{width:4px;height:4px;animation-delay:3s;top:35%;left:90%}@keyframes drift{0%,to{transform:translate(0)}25%{transform:translate(15px,-20px)}50%{transform:translate(-10px,-35px)}75%{transform:translate(20px,-15px)}}.container{z-index:2;width:100%;max-width:480px;position:relative}.header{text-align:center;margin-bottom:28px;animation:.6s both fadeDown}@keyframes fadeDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.app-title{color:#fff;letter-spacing:1.5px;justify-content:center;align-items:center;gap:10px;font-size:2.2rem;font-weight:900;display:flex}.title-icon{font-size:2rem;animation:3s ease-in-out infinite wobble}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.greeting{color:#fff9;margin-top:5px;font-size:.95rem;font-weight:600}.search-wrapper{gap:10px;margin-bottom:20px;animation:.6s .1s both fadeDown;display:flex}.search-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1.5px solid #fff3;border-radius:50px;flex:1;align-items:center;padding:0 16px;transition:border-color .3s,box-shadow .3s;display:flex}.search-box:focus-within{border-color:#818cf8cc;box-shadow:0 0 20px #818cf840}.search-icon{margin-right:8px;font-size:14px}.search-input{color:#fff;background:0 0;border:none;outline:none;flex:1;padding:13px 0;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:600}.search-input::placeholder{color:#fff6;font-weight:500}.search-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#818cf8,#ec4899);border:none;border-radius:50px;justify-content:center;align-items:center;min-width:90px;padding:13px 24px;font-family:Nunito,sans-serif;font-size:.9rem;font-weight:700;transition:transform .2s,box-shadow .2s,opacity .2s;display:flex}.search-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #818cf866}.search-btn:active{transform:scale(.97)}.search-btn.loading{opacity:.7;cursor:not-allowed}.spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error-card{color:#fca5a5;text-align:center;background:#ef444426;border:1px solid #ef444466;border-radius:12px;margin-bottom:16px;padding:12px 18px;font-size:.9rem;font-weight:600;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.loading-container{text-align:center;padding:30px}.loading-dots{justify-content:center;gap:8px;margin-bottom:12px;display:flex}.loading-dots span{background:#fff9;border-radius:50%;width:10px;height:10px;animation:1.2s infinite bounce}.loading-dots span:first-child{animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1.2)}}.loading-text{color:#fff9;font-size:.9rem;font-weight:600}.weather-card{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#ffffff14;border:1.5px solid #ffffff26;border-radius:24px;padding:24px;animation:.5s cubic-bezier(.34,1.56,.64,1) both slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.live-badge{color:#86efac;letter-spacing:1.5px;background:#22c55e26;border:1px solid #22c55e59;border-radius:50px;align-items:center;gap:6px;margin-bottom:14px;padding:4px 10px;font-size:.7rem;font-weight:800;display:inline-flex}.live-dot{background:#22c55e;border-radius:50%;width:7px;height:7px;animation:2s infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #22c55e80}50%{box-shadow:0 0 0 6px #22c55e00}}.location-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.city{color:#fff;font-size:1.8rem;font-weight:800;line-height:1.1}.country{color:#ffffff8c;margin-top:4px;font-size:.85rem;font-weight:600}.weather-icon{filter:drop-shadow(0 0 12px #ffffff4d);width:85px;height:85px;animation:4s ease-in-out infinite iconFloat}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.temp-row{align-items:flex-end;gap:12px;margin-bottom:6px;display:flex}.temp-display{align-items:flex-start;line-height:1;display:flex}.temp-number{color:#fff;font-size:5rem;font-weight:900;line-height:.9}.temp-unit{color:#fff9;margin-top:8px;font-size:1.6rem;font-weight:700}.temp-range{flex-direction:column;gap:4px;padding-bottom:8px;display:flex}.temp-max{color:#f87171;font-size:.9rem;font-weight:700}.temp-min{color:#93c5fd;font-size:.9rem;font-weight:700}.weather-desc{color:#ffffffa6;letter-spacing:.5px;margin-bottom:18px;font-size:1rem;font-weight:700}.divider{background:#ffffff1f;height:1px;margin:16px 0}.details-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.detail-card{background:#ffffff12;border:1px solid #ffffff1a;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;transition:background .2s,transform .2s;display:flex}.detail-card:hover{background:#ffffff21;transform:translateY(-2px)}.detail-icon{font-size:1.3rem}.detail-value{color:#fff;font-size:.9rem;font-weight:800}.detail-label{color:#ffffff73;font-size:.7rem;font-weight:600}.sun-row{background:#ffffff0f;border:1px solid #ffffff14;border-radius:14px;align-items:center;padding:14px 18px;display:flex}.sun-item{flex:1;align-items:center;gap:10px;display:flex}.sun-icon{font-size:1.6rem}.sun-label{color:#ffffff73;font-size:.7rem;font-weight:600}.sun-time{color:#fff;font-size:1rem;font-weight:800}.sun-divider{background:#ffffff26;width:1px;height:40px;margin:0 16px}.placeholder{text-align:center;padding:50px 20px;animation:.6s .2s both fadeDown}.placeholder-icon{margin-bottom:16px;font-size:4rem;animation:4s ease-in-out infinite float}.placeholder-text{color:#ffffffb3;margin-bottom:8px;font-size:1rem;font-weight:700}.placeholder-sub{color:#ffffff59;font-size:.85rem;font-weight:600}@media (width<=480px){.app{padding:16px}.app-title{font-size:1.8rem}.city{font-size:1.5rem}.temp-number{font-size:4rem}.weather-icon{width:70px;height:70px}.details-grid{grid-template-columns:repeat(2,1fr)}}
