*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,Arial,sans-serif;background:linear-gradient(135deg,#0f2027 0%,#203a43 50%,#2c5364 100%);min-height:100vh;color:#fff;display:flex;align-items:center;justify-content:center}#root{width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center}.container{max-width:1200px;margin:0 auto;padding:0 20px}.card{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:16px}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.input{width:100%;padding:14px 16px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px;transition:all .3s ease;background:white}.input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#fee;color:#c53030;padding:1rem;border-radius:12px;border:1px solid #feb2b2;margin:1rem 0}.weather-main-card{background:#fff;color:#222;border-radius:22px;box-shadow:0 8px 32px #0000002e;width:320px;padding:2.2rem 1.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;position:relative}.weather-main-card .top-row{width:100%;display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.weather-main-card .city{font-size:1.1rem;font-weight:600;letter-spacing:1px;display:flex;align-items:center;gap:.4rem}.weather-main-card .search-btn{background:#f3f6fa;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.weather-main-card .search-btn:hover{background:#e2e8f0}.weather-main-card .weather-icon{width:90px;height:90px;margin:.5rem 0 1.2rem}.weather-main-card .temp{font-size:2.8rem;font-weight:700;margin-bottom:.2rem;letter-spacing:-2px}.weather-main-card .desc{font-size:1.1rem;color:#444;margin-bottom:1.2rem;font-weight:500}.weather-main-card .bottom-row{width:100%;display:flex;justify-content:space-between;margin-top:1.2rem}.weather-main-card .info-block{display:flex;flex-direction:column;align-items:center;font-size:.98rem;color:#444}.weather-main-card .info-block .icon{margin-bottom:.2rem}@media (max-width: 400px){.weather-main-card{width:98vw;padding:1.2rem .5rem 1rem}}.weather-card{background:rgba(255,255,255,.98);border-radius:20px;padding:2.5rem;box-shadow:0 10px 40px #0000001a}.temperature-display{font-size:4rem;font-weight:700;color:#2d3748}.weather-icon{transition:transform .3s ease}.weather-icon:hover{transform:scale(1.05)}.forecast-item{background:#f8fafc;border-radius:12px;padding:1.5rem;transition:all .3s ease;border:1px solid #e2e8f0}.forecast-item:hover{background:#f1f5f9;transform:translateY(-2px);box-shadow:0 4px 20px #0000001a}.hourly-forecast{background:#f8fafc;border-radius:12px;padding:1.5rem;transition:all .3s ease;border:1px solid #e2e8f0}.hourly-forecast:hover{background:#f1f5f9;transform:translateY(-2px)}.sunrise-sunset{background:linear-gradient(135deg,#fef3c7 0%,#fed7aa 100%);border-radius:12px;padding:1.5rem;border:1px solid #fbbf24}.sunset-card{background:linear-gradient(135deg,#e9d5ff 0%,#fce7f3 100%);border-radius:12px;padding:1.5rem;border:1px solid #c084fc}.glass{background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px}@media (max-width: 768px){.container{padding:0 16px}.card{padding:1.5rem;margin:1rem 0}.weather-card{padding:2rem}.temperature-display{font-size:3rem}.btn{padding:12px 20px;font-size:14px}.input{padding:12px 14px;font-size:14px}}
