:root{--bg:#f8fafc;--card:#fff;--ink:#0f172a;--muted:#64748b;--primary:#0ea5e9;--border:#e2e8f0}
*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}
a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}
.wrap{max-width:1180px;margin:0 auto;padding:16px}
header{background:linear-gradient(180deg,#e0f2fe,#f8fafc);border-bottom:1px solid var(--border)}
nav{margin-top:8px;display:flex;gap:12px;flex-wrap:wrap}
nav a{padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px}
.grid{display:grid;gap:16px}
@media(min-width:900px){.grid.cols-2{grid-template-columns:2fr 1fr}}
.muted{color:var(--muted)}
.kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi .item{padding:12px;border:1px solid var(--border);border-radius:12px;text-align:center;background:#fff}
.kpi .big{font-size:1.6rem;font-weight:700}
.badge{display:inline-block;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:.8rem;color:var(--muted)}
.month-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
footer{border-top:1px solid var(--border);background:#fff;margin-top:24px}
.map-wrap{position:relative}
.map-toolbar{display:flex;gap:8px;align-items:center;margin:8px 0}
.map-toolbar select{padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:#fff}
.windy{width:100%;height:620px;border:1px solid var(--border);border-radius:12px}
details>summary{cursor:pointer;font-weight:600}
details>p{margin:8px 0 0 8px}