*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg: #1a1a1a;--text: #e0e0e0;--text-heading: #fff;--text-sub: #aaa;--text-muted: #888;--text-dim: #666;--text-faint: #555;--text-faintest: #444;--seat-empty: #3a3a3a;--border: #333;--border-faint: rgba(255, 255, 255, .03);--hover: rgba(255, 255, 255, .06);--selected: rgba(255, 255, 255, .1);--seat-stroke: rgba(255, 255, 255, .2);--turnout: #ccc;--prc: #999;--manjka: #e8a735;--manjka-header: #a08030;--manjka-dim: #886830;--coalition: #4caf50;--banner-bg: #2a2a2a;--banner-border: #444;--banner-text: #ccc;--toggle-bg: transparent;--toggle-text: #888}[data-theme=light]{--bg: #f5f5f5;--text: #1a1a1a;--text-heading: #111;--text-sub: #555;--text-muted: #777;--text-dim: #999;--text-faint: #aaa;--text-faintest: #bbb;--seat-empty: #d5d5d5;--border: #ddd;--border-faint: rgba(0, 0, 0, .05);--hover: rgba(0, 0, 0, .04);--selected: rgba(0, 0, 0, .08);--seat-stroke: rgba(0, 0, 0, .15);--turnout: #333;--prc: #666;--manjka: #b5850a;--manjka-header: #8a6a10;--manjka-dim: #a08030;--coalition: #2e7d32;--banner-bg: #e8e8e8;--banner-border: #ccc;--banner-text: #333;--toggle-bg: transparent;--toggle-text: #555}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh}.app{max-width:960px;margin:0 auto;padding:1.5rem 1rem;position:relative}.theme-toggle{position:absolute;top:1rem;right:1rem;background:var(--toggle-bg);border:1px solid var(--border);color:var(--toggle-text);font-size:1.2rem;width:2.2rem;height:2.2rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.theme-toggle:hover{opacity:.7}.layout{display:flex;gap:2rem;align-items:flex-start}.chart-section{flex:0 0 40%}.chart-header{margin-bottom:.75rem}.chart-header h1{font-size:1.5rem;font-weight:700;color:var(--text-heading);line-height:1.3}.subtitle{font-size:.95rem;color:var(--text-sub);margin-top:.1rem}.data-time{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.parliament-svg{width:100%;height:auto;display:block}.seat-filled{stroke:var(--seat-stroke);stroke-width:.5}.seat-empty{stroke:none}.chart-footer{text-align:center;margin-top:.5rem}.turnout{font-size:1.1rem;color:var(--turnout)}.turnout strong{color:var(--text-heading);font-size:1.3rem}.turnout-detail{font-size:.82rem;color:var(--text-muted);margin-top:.15rem}.seat-count{font-size:.9rem;font-weight:600;color:var(--text-dim);margin-top:.5rem;font-variant-numeric:tabular-nums}.table-section{flex:1 1 auto;overflow:hidden}.table-section h2{font-size:1rem;font-weight:600;color:var(--turnout);margin-bottom:.35rem}.table-info{font-size:.75rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.4}table{width:100%;border-collapse:collapse;table-layout:auto}thead th{padding:.35rem .4rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:normal;line-height:1.3;vertical-align:bottom}.th-name{text-align:left}.th-num{text-align:right}.th-manjka{color:var(--manjka-header)}tbody tr{cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-faint)}tbody tr:hover{background:var(--hover)}tbody tr.selected{background:var(--selected)}tbody tr.below-threshold td{color:var(--text-faint)}tbody tr.below-threshold .td-man{color:var(--text-faintest)}td{padding:.35rem .4rem}.td-color{width:1rem;padding-right:0}.color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle}.td-name{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:12rem}.td-num{text-align:right;font-variant-numeric:tabular-nums;font-size:.8rem;white-space:nowrap}.td-man{font-weight:700;font-size:.95rem}.td-prc{color:var(--prc);font-size:.75rem}.td-manjka{font-size:.75rem;color:var(--manjka)}.below-threshold .td-manjka{color:var(--manjka-dim)}.coalition{margin-top:.4rem;font-size:1rem;font-weight:700;color:var(--coalition)}.error{color:#e74c3c;margin-bottom:1rem}.loading{color:var(--text-dim)}footer{margin-top:2rem;font-size:.75rem;color:var(--text-faint)}.analytics-banner{position:fixed;bottom:0;left:0;right:0;background:var(--banner-bg);color:var(--banner-text);font-size:.8rem;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:1rem;z-index:100;border-top:1px solid var(--banner-border)}.analytics-banner button{background:#4caf50;color:#fff;border:none;padding:.3rem 1rem;border-radius:4px;cursor:pointer;font-size:.8rem;white-space:nowrap}.analytics-banner button:hover{background:#43a047}@media(max-width:640px){.app{padding:1rem 4px}.layout{flex-direction:column;gap:1rem}.chart-section{flex:none;width:100%;max-width:400px;margin:0 auto}.chart-header{text-align:center}.chart-header h1{font-size:1.1rem}.theme-toggle{top:.5rem;right:.5rem;width:2rem;height:2rem;font-size:1rem}.table-section{width:100%}.table-section h2,.table-info{padding:0 .25rem}table{width:100%}.td-name{max-width:7rem;font-size:.75rem}td,thead th{padding:.25rem}.td-num{font-size:.72rem}.td-man{font-size:.85rem}.td-manjka{font-size:.68rem}.hide-mobile{display:none}footer{padding:0 .25rem}}
