:root { --brand: #7c4dff; }
body > main { padding-top: 1rem; padding-bottom: 3rem; }
nav.site-nav { padding: 0.5rem 0 1rem; border-bottom: 1px solid var(--pico-muted-border-color); margin-bottom: 1.5rem; }
nav.site-nav ul { display: flex; gap: 1rem; list-style: none; padding: 0; margin: 0; }
nav.site-nav a { text-decoration: none; }
nav.site-nav a.active { font-weight: 600; color: var(--brand); }

.forecast-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; }
.forecast-card { padding: 1rem; }
.forecast-card h3 { margin: 0 0 0.25rem; }
.forecast-card .temp { font-size: 2.5rem; font-weight: 700; color: var(--brand); line-height: 1.1; margin: 0.5rem 0; }
.forecast-card-empty .temp { color: var(--pico-muted-color); }

.skill-line { font-style: italic; color: var(--pico-muted-color); }

table td.num, table th.num { text-align: right; font-variant-numeric: tabular-nums; }
table small { color: var(--pico-muted-color); }

svg.chart { width: 100%; height: auto; max-width: 100%; background: var(--pico-card-background-color); border-radius: 4px; margin: 0.5rem 0 1.5rem; }
.chart-title { font-size: 14px; font-weight: 600; fill: var(--pico-color); }
.chart-grid { stroke: var(--pico-muted-border-color); stroke-width: 0.5; }
.chart-frame { fill: none; stroke: var(--pico-muted-border-color); stroke-width: 1; }
.chart-tick { font-size: 10px; fill: var(--pico-muted-color); font-family: ui-monospace, monospace; }
.chart-tick-mark { stroke: var(--pico-muted-border-color); stroke-width: 1; }
.chart-axis-label { font-size: 11px; fill: var(--pico-muted-color); }
.chart-legend { font-size: 11px; fill: var(--pico-color); font-family: ui-monospace, monospace; }
.chart-empty { font-size: 12px; fill: var(--pico-muted-color); font-style: italic; }

footer.site-footer { margin-top: 3rem; padding-top: 1rem; border-top: 1px solid var(--pico-muted-border-color); color: var(--pico-muted-color); font-size: 0.875rem; }