.card{border:1px solid #e2e8f0;border-radius:8px;padding:16px;background:#f7fafc}
.weather-main{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center}
.weather-icon{font-size:80px;text-align:center}
.weather-temp{font-size:48px;font-weight:700;color:#2d3748}
.weather-desc{font-size:18px;color:#718096;margin-top:8px}
.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:16px}
.detail-item{text-align:center;padding:12px;background:#fff;border-radius:8px;border:1px solid #e2e8f0}
.detail-label{font-size:12px;color:#718096;margin-bottom:4px}
.detail-value{font-size:20px;font-weight:600;color:#2d3748}
.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.forecast-item{text-align:center;padding:12px;background:#fff;border-radius:8px;border:1px solid #e2e8f0}
.forecast-date{font-size:13px;color:#718096;margin-bottom:8px}
.forecast-icon{font-size:32px;margin:8px 0}
.forecast-temp{font-size:14px;color:#2d3748}
.city-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.city-tag{padding:6px 12px;background:#edf2f7;border-radius:999px;cursor:pointer;font-size:13px;color:#4a5568;transition:all 0.2s}
.city-tag:hover{background:#667eea;color:#fff}
.alert{padding:12px;border-radius:8px;background:#fff3cd;border:1px solid #ffc107;color:#856404;margin-bottom:12px}