:root{--ldf:#c0392b;--udf:#2980b9;--nda:#e67e22;--radius:12px;--bg:#f8f9fa;--surface:#fff;--border:#e9ecef;--text:#495057;--text-h:#212529;--muted:#6c757d;--code-bg:#f1f3f5;--accent:#aa3bff;--shadow:#00000014 0 4px 12px;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--heading:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.01em;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--bg:#0f0f13;--surface:#1a1a22;--border:#2e2e3a;--text:#cbd5e1;--text-h:#f8fafc;--muted:#94a3b8;--code-bg:#1e1e26;--shadow:#0006 0 10px 15px -3px}}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;margin:0 auto;display:flex}body{background:var(--bg);color:var(--text);margin:0}h1,h2,h3{font-family:var(--heading);color:var(--text-h);font-weight:700;line-height:1.2}h1{margin:1.5rem 0;font-size:2.5rem}h2{margin-bottom:.5rem;font-size:1.5rem}p{margin:0}code{font-family:var(--mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:.2em .4em;font-size:.85em}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.app{flex-direction:column;width:100%;min-width:320px;max-width:420px;min-height:100svh;margin:0 auto;display:flex}button{cursor:pointer;font-family:inherit}.splash-screen{background:linear-gradient(160deg, var(--surface) 0%, var(--bg) 100%);flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.splash-content{text-align:center}.splash-flag{margin-bottom:1.5rem;font-size:4rem}.splash-title{color:var(--text-h);margin-bottom:.75rem;font-size:2rem;font-weight:700;line-height:1.2}.splash-date{color:var(--muted);margin-bottom:2rem;font-size:.95rem}.splash-tap{color:var(--muted);font-size:.85rem;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.instructions-screen{flex-direction:column;flex:1;gap:1.5rem;padding:2rem 1.5rem;display:flex}.instructions-screen h2{color:var(--text-h);font-size:1.5rem}.steps-list{flex-direction:column;gap:1rem;list-style:none;display:flex}.step-item{align-items:center;gap:1rem;display:flex}.step-num{background:var(--surface);border:2px solid var(--border);width:2rem;height:2rem;color:var(--text-h);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.step-text{color:var(--text);font-size:1rem}.awareness-note{color:var(--muted);border-left:3px solid var(--udf);margin-top:auto;padding-left:.75rem;font-size:.85rem}.start-btn{background:var(--udf);color:#fff;border-radius:var(--radius);border:none;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600}.start-btn:disabled{opacity:.4;cursor:not-allowed}.home-screen{flex-direction:column;flex:1;gap:1.25rem;padding:2rem 1.5rem;display:flex}.home-screen h1{color:var(--text-h);font-size:1.5rem}.home-screen .subtitle{color:var(--muted);font-size:.9rem}.mode-list{flex-direction:column;gap:.75rem;display:flex}.mode-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);text-align:left;color:var(--text);flex-direction:column;gap:.25rem;padding:1rem 1.25rem;transition:border-color .15s;display:flex}.mode-card.selected{border-color:var(--udf)}.mode-label{color:var(--text-h);font-size:1rem;font-weight:600}.mode-desc{color:var(--muted);font-size:.8rem}.district-select{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);width:100%;padding:.75rem 1rem;font-size:1rem}.all-candidates-toggle{color:var(--muted);cursor:pointer;align-items:center;gap:.6rem;font-size:.85rem;display:flex}.all-candidates-toggle input{accent-color:var(--udf);cursor:pointer}.predict-screen{flex-direction:column;flex:1;gap:1rem;padding:1rem 1.25rem 1.5rem;display:flex}.progress-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:var(--udf);height:100%;transition:width .3s}.progress-label{color:var(--muted);text-align:right;font-size:.75rem}.seat-header{flex-direction:column;gap:.25rem;display:flex}.district-tag{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.75rem}.constituency-name{color:var(--text-h);font-size:1.75rem;font-weight:700}.reservation-badge{background:var(--border);color:var(--muted);border-radius:4px;align-self:flex-start;padding:.15rem .5rem;font-size:.7rem}.candidates-list{flex-direction:column;flex:1;gap:.75rem;display:flex}.candidate-row{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);text-align:left;box-sizing:border-box;width:100%;color:var(--text);align-items:center;gap:1rem;padding:.875rem 1rem;transition:border-color .15s,background-color .15s,box-shadow .15s;display:flex}.insignia-circle{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1.1rem;transition:background-color .15s,color .15s;display:flex}.candidate-info{flex-direction:column;flex:1;gap:.2rem;display:flex}.candidate-name{color:var(--text-h);font-size:.95rem;font-weight:600}.party-name{color:var(--muted);font-size:.75rem}.nav-buttons{gap:.75rem;display:flex}.nav-btn{border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);color:var(--text-h);flex:1;padding:.75rem;font-size:.95rem;font-weight:600}.nav-btn:disabled{opacity:.3;cursor:not-allowed;color:var(--muted)}.nav-btn.primary{background:var(--udf);border-color:var(--udf);color:#fff}.share-screen{flex-direction:column;flex:1;gap:1.5rem;padding:1.5rem 1.25rem;display:flex}.story-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.story-header{justify-content:space-between;align-items:center;display:flex}.story-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.75rem}.story-scope{color:var(--text);font-size:.85rem;font-weight:600}.story-title{color:var(--text-h);font-size:1.5rem;font-weight:700}.breakdown-bar{border-radius:6px;height:12px;display:flex;overflow:hidden}.bar-segment{height:100%;transition:width .4s}.seat-counts{justify-content:space-around;display:flex}.seat-count{flex-direction:column;align-items:center;gap:.2rem;display:flex}.count-num{color:var(--text-h);font-size:2rem;font-weight:700}.count-label{text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.picks-list{flex-direction:column;gap:.4rem;display:flex}.pick-row{justify-content:space-between;font-size:.85rem;display:flex}.pick-constituency{color:var(--muted)}.pick-alliance{font-weight:700}.pick-skipped{color:var(--border)}.story-footer{color:var(--muted);border-top:1px solid var(--border);justify-content:space-between;padding-top:.75rem;font-size:.75rem;display:flex}.story-url{color:var(--text);font-weight:600}.share-actions{flex-direction:column;gap:.75rem;display:flex}.share-hint{color:var(--muted);text-align:center;font-size:.8rem}.share-btn{background:var(--ldf);color:#fff;border-radius:var(--radius);border:none;width:100%;padding:.875rem;font-size:1rem;font-weight:600}.story-user{color:var(--text-h);font-weight:600}.prediction-id{color:var(--text);text-align:center;background:var(--border);border-radius:6px;align-self:center;padding:.25rem .5rem;font-size:.75rem}.prediction-id code{color:var(--text-h);background:0 0;padding:0;font-family:monospace;font-weight:600}.insta-btn{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)}.secondary-btn{color:var(--muted);border:2px solid var(--border);border-radius:var(--radius);background:0 0;width:100%;padding:.75rem;font-size:.9rem}
