:root {
    --bg: #0b0c10;
    --panel: #11131a;
    --panel-2: #181b25;
    --ink: #e6e8ef;
    --ink-dim: #99a0b0;
    --accent: #ff4d6d;
    --accent-2: #ffd166;
    --line: #252834;
}

[data-theme="light"] {
    --bg: #f7f7fb;
    --panel: #fff;
    --panel-2: #f1f2f7;
    --ink: #181b25;
    --ink-dim: #505463;
    --accent: #d11a2a;
    --accent-2: #8a5a00;
    --line: #e4e6ee;
}

[data-theme="haunted"] {
    --bg: #07060c;
    --panel: #10081c;
    --panel-2: #170c27;
    --ink: #ead7ff;
    --ink-dim: #a48ec7;
    --accent: #b14dff;
    --accent-2: #6be3ff;
    --line: #2a1543;
}

* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; }
body {
    font: 14px/1.4 -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang HK", "Noto Sans TC", sans-serif;
    color: var(--ink); background: var(--bg);
    display: grid; grid-template-columns: 360px 1fr; min-height: 100vh;
}
@media (max-width: 760px) { body { grid-template-columns: 1fr; grid-template-rows: auto 1fr; } #map { min-height: 60vh; } }

aside#sidebar { background: var(--panel); border-right: 1px solid var(--line); padding: 16px; overflow-y: auto; max-height: 100vh; }
aside header h1 { font-size: 18px; margin: 0 0 4px; display: flex; align-items: center; gap: 6px; }
aside header .ghost { filter: drop-shadow(0 0 6px var(--accent)); }
aside header .subtitle { margin: 0 0 16px; color: var(--ink-dim); font-size: 12px; }

.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-bottom: 14px; }
.stat { background: var(--panel-2); padding: 8px; border-radius: 8px; display: flex; flex-direction: column; text-align: center; }
.stat .num { font-size: 18px; font-weight: 700; color: var(--accent); }
.stat .lbl { font-size: 10px; color: var(--ink-dim); text-transform: uppercase; letter-spacing: 0.05em; }

.controls .field { border: 0; margin: 0 0 14px; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.controls .field legend { font-size: 11px; color: var(--ink-dim); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.controls .field > span { font-size: 11px; color: var(--ink-dim); text-transform: uppercase; letter-spacing: 0.06em; }
.controls label { display: flex; align-items: center; gap: 6px; font-size: 13px; }
.controls input[type=search], .controls input[type=date] {
    background: var(--panel-2); color: var(--ink); border: 1px solid var(--line); border-radius: 6px; padding: 6px 8px; font-size: 13px;
}
.controls input[type=search]:focus, .controls input[type=date]:focus { outline: 2px solid var(--accent); outline-offset: 0; }
.date-row { flex-direction: column; }
.chips { display: flex; gap: 4px; margin-top: 4px; flex-wrap: wrap; }
.chips button { background: var(--panel-2); color: var(--ink); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; font-size: 12px; cursor: pointer; }
.chips button.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.actions { display: flex; gap: 8px; }
.actions button {
    flex: 1; background: var(--panel-2); border: 1px solid var(--line); color: var(--ink);
    padding: 8px; border-radius: 6px; font-size: 12px; cursor: pointer;
}
.actions button:hover { border-color: var(--accent); }

.panel { background: var(--panel-2); border-radius: 8px; padding: 12px 14px; margin-bottom: 14px; position: relative; }
.panel h2 { margin: 0 0 8px; font-size: 14px; }
.panel dl { margin: 0; display: grid; grid-template-columns: max-content 1fr; gap: 4px 10px; font-size: 12px; }
.panel dt { color: var(--ink-dim); }
.panel a { display: inline-block; margin-top: 10px; font-size: 12px; color: var(--accent-2); }
.panel .close { position: absolute; top: 6px; right: 8px; background: none; color: var(--ink-dim); border: 0; font-size: 18px; cursor: pointer; }

footer { margin-top: 20px; border-top: 1px solid var(--line); padding-top: 12px; font-size: 12px; color: var(--ink-dim); }
footer details { margin-bottom: 8px; }
footer summary { cursor: pointer; }
#district-list { padding-left: 1.2em; margin: 8px 0; }
#district-list li { margin: 2px 0; }
#year-spark { height: 40px; margin-top: 6px; }
#year-spark rect { fill: var(--accent); opacity: 0.7; }
.fineprint { font-size: 11px; color: var(--ink-dim); }

#map-wrap { position: relative; }
#map { width: 100%; height: 100vh; }
@media (max-width: 760px) { #map { height: 100%; } }

#toast {
    position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
    background: rgba(0,0,0,.7); color: #fff; padding: 6px 12px; border-radius: 999px; font-size: 12px;
    opacity: 0; pointer-events: none; transition: opacity .2s;
}
#toast.on { opacity: 1; }

.legend { position: absolute; bottom: 24px; left: 10px; background: var(--panel); color: var(--ink); padding: 8px 10px; border-radius: 6px; font-size: 11px; box-shadow: 0 2px 12px rgba(0,0,0,.3); border: 1px solid var(--line); }
.legend-title { font-weight: 700; margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-dim); }
.legend .dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }

.banner {
    position: absolute; top: 10px; left: 10px; right: 10px; z-index: 500;
    background: rgba(255,77,109,0.92); color: #fff; padding: 8px 12px;
    border-radius: 8px; font-size: 12px; display: flex; gap: 8px; align-items: center;
    box-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.banner code { background: rgba(0,0,0,0.3); padding: 1px 6px; border-radius: 4px; font-size: 11px; }
.banner button { background: transparent; color: #fff; border: 0; font-size: 16px; cursor: pointer; margin-left: auto; }

/* Leaflet popup tweaks to match our look */
.leaflet-popup-content-wrapper { background: var(--panel); color: var(--ink); border: 1px solid var(--line); }
.leaflet-popup-tip { background: var(--panel); }
.leaflet-popup-content { margin: 10px 12px; }
.leaflet-popup-close-button { color: var(--ink-dim) !important; }

.infowin h3 { margin: 0 0 4px; font-size: 14px; }
.infowin .row { font-size: 12px; margin: 2px 0; }
.infowin .src { display: inline-block; padding: 1px 6px; border-radius: 999px; font-size: 10px; color: #000; margin-right: 4px; }
