body{margin:0}.weather-card{--bg-from:#e0f2fe;--bg-to:#fff;--accent:#0284c7;background:linear-gradient(160deg, var(--bg-from), var(--bg-to));color:#0f172a;box-sizing:border-box;border-radius:16px;width:100%;max-width:320px;padding:1.25rem 1.25rem .75rem;font-family:system-ui,sans-serif;box-shadow:0 1px 2px #0f172a0f,0 8px 24px #0f172a14}.weather-tone-sun{--bg-from:#fef9c3;--accent:#ca8a04}.weather-tone-cloud{--bg-from:#e2e8f0;--accent:#475569}.weather-tone-rain{--bg-from:#dbeafe;--accent:#1d4ed8}.weather-tone-snow{--bg-from:#f1f5f9;--accent:#64748b}.weather-tone-storm{--bg-from:#ddd6fe;--accent:#6d28d9}.weather-tone-fog{--bg-from:#e2e8f0;--accent:#64748b}.weather-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.weather-location{letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin:0;font-size:.8rem;font-weight:600}.weather-date{color:#334155;margin:.1rem 0 0;font-size:.95rem}.weather-refresh{width:28px;height:28px;color:var(--accent);cursor:pointer;background:#fff9;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background-color .12s;display:inline-flex}.weather-refresh:hover:not(:disabled){background:#fffffff2}.weather-refresh:disabled{cursor:progress;opacity:.7}@keyframes weather-spin{to{transform:rotate(360deg)}}.weather-refresh .spin{animation:.9s linear infinite weather-spin}.weather-main{align-items:center;gap:1rem;margin:1rem 0 .75rem;display:flex}.weather-main-icon{color:var(--accent);flex-shrink:0}.weather-condition{color:#0f172a;margin:0;font-size:1.05rem;font-weight:600}.weather-temps{color:#0f172a;letter-spacing:-.01em;margin:.15rem 0 0;font-size:1.5rem;font-weight:600}.weather-temp-low,.weather-temp-sep{color:#64748b;font-weight:500}.weather-temp-unit{color:#64748b;margin-left:.15rem;font-size:.95rem;font-weight:500}.weather-stats{border-top:1px solid #0f172a14;grid-template-columns:1fr 1fr;gap:.5rem .75rem;margin:0;padding:.5rem 0;display:grid}.weather-stat dt{text-transform:uppercase;letter-spacing:.04em;color:#64748b;align-items:center;gap:.3rem;margin:0;font-size:.75rem;display:inline-flex}.weather-stat dd{color:#0f172a;margin:.1rem 0 0;font-size:.95rem;font-weight:600}.weather-muted{color:#64748b;font-size:.85rem;font-weight:500}.weather-error{color:#991b1b;background:#fee2e2;border-radius:8px;margin:.75rem 0;padding:.5rem .75rem;font-size:.85rem}.weather-loading{color:#64748b;margin:1rem 0;font-size:.9rem}.weather-footer{color:#64748b;text-align:right;border-top:1px solid #0f172a0f;margin-top:.25rem;padding-top:.4rem;font-size:.7rem}.weather-footer a{color:inherit}
