:root { --bg:#f7f7f9; --card:#fff; --text:#042C53; --muted:#5F5E5A; --accent:#EF9F27; --border:#e8e8ee; --shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.03); --navy:#042C53; --gold:#EF9F27; }
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}
main{max-width:480px;margin:0 auto;padding:0;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
.muted{color:var(--muted)}.small{font-size:.85rem}.xsmall{font-size:.75rem}
.screen{display:none;flex:1;padding:1.25rem;animation:fi .25s ease}
.screen.active{display:flex;flex-direction:column}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.error{background:#fee2e2;color:#991b1b;border-radius:8px;padding:.65rem .85rem;margin-top:.75rem;font-size:.85rem}

/* ZIP entry */
.zip-card{background:var(--card);border-radius:16px;padding:2rem 1.5rem;box-shadow:var(--shadow);margin:auto;width:100%;text-align:center}
.zip-card h1{font-size:1.6rem;line-height:1.2;font-weight:700;margin-bottom:.4rem}
.zip-card .tagline{color:var(--muted);margin-bottom:1.5rem}
#zip-form{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.25rem}
#zip-input,#zip-form button{width:100%;padding:.85rem;border-radius:10px;border:1px solid var(--border);background:var(--card);font-size:1.05rem;font-family:inherit;text-align:center}
#zip-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.12)}
#zip-form button{cursor:pointer;font-weight:600;border-color:var(--text);transition:all .12s;color:var(--text)}
#zip-form button:hover{background:var(--text);color:#fff}
#zip-form button:active{background:var(--accent);color:#fff;border-color:var(--accent)}
#zip-multi{margin-top:1rem;padding:1rem;background:var(--bg);border-radius:10px}
#zip-multi .prompt{font-size:.9rem;margin-bottom:.75rem;color:var(--text);font-weight:600;text-align:left}
#zip-multi-buttons{display:flex;flex-direction:column;gap:.5rem}
#zip-multi-buttons button{background:var(--card);border:2px solid var(--border);border-radius:10px;padding:.75rem 1rem;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:600;text-align:left;transition:all .12s}
#zip-multi-buttons button:hover{border-color:var(--accent);background:#fff}
#zip-multi-buttons .district-type{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;margin-bottom:.15rem}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:.85rem;border-bottom:1px solid var(--border);margin-bottom:.85rem}
.back-btn{background:none;border:none;color:var(--muted);font-family:inherit;font-size:.85rem;cursor:pointer;padding:.4rem .5rem .4rem 0}
.district-label{font-weight:700;background:var(--text);color:#fff;padding:.25rem .65rem;border-radius:999px;font-size:.8rem}

/* Stats strip */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;margin-bottom:1rem}
.stat-chip.neutral{border-left:3px solid #6b6b80}
.stat-chip{background:var(--card);border-radius:8px;padding:.5rem .5rem .4rem;box-shadow:var(--shadow);overflow:hidden;min-width:0}
.stat-chip .sl{font-size:.55rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stat-chip .sv{font-size:.8rem;font-weight:800;color:var(--text);line-height:1.15;margin-top:.1rem;display:flex;align-items:baseline;flex-wrap:wrap;gap:.15rem}
.stat-chip .pct{font-size:.65rem;font-weight:800;padding:.1rem .3rem;border-radius:4px;margin-left:.25rem;vertical-align:middle}
.stat-chip .pct.up{background:#fee2e2;color:#dc2626}
.stat-chip .pct.dn{background:#d1fae5;color:#059669}
.stat-chip.is-up{border-left:3px solid #dc2626}
.stat-chip.is-dn{border-left:3px solid #059669}
.stat-chip .sp{display:block;margin-top:.2rem}

/* Story cards */
.stories{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1rem}
.story{background:var(--card);border-radius:12px;padding:1rem;box-shadow:var(--shadow);border-top:3px solid var(--accent)}
.story[data-topic="groceries"]{border-top-color:#e94560}
.story[data-topic="gas"]{border-top-color:#f59e0b}
.story[data-topic="healthcare"]{border-top-color:#06b6d4}
.story[data-topic="housing"]{border-top-color:#a78bfa}
.story[data-topic="jobs"]{border-top-color:#10b981}
.story .st{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--muted);margin-bottom:.25rem}
.story h3{font-size:1rem;line-height:1.25;font-weight:700;margin-bottom:.3rem}
.story .sn{font-size:1.8rem;font-weight:800;color:var(--accent);letter-spacing:-.02em;margin:.2rem 0 .1rem}
.story[data-topic="groceries"] .sn{color:#e94560}
.story[data-topic="gas"] .sn{color:#f59e0b}
.story[data-topic="healthcare"] .sn{color:#06b6d4}
.story[data-topic="jobs"] .sn{color:#10b981}
.story .sc{font-size:.78rem;color:var(--muted);margin-bottom:.4rem}
.story .ss{font-size:.82rem;color:var(--text);margin-bottom:.4rem;line-height:1.4}
.story .sr{font-size:.65rem;color:var(--muted);border-top:1px solid var(--border);padding-top:.4rem;margin-top:.4rem}
.story-vote{margin:.4rem 0;font-size:.8rem}

/* Chart inside story */
.story .ch{margin:.5rem 0;background:#fafafa;border-radius:8px;padding:.4rem;border:1px solid #f0f0f0}
.story .ch svg{display:block;width:100%;height:120px}

/* Share button */
.story .sb{display:block;width:100%;margin-top:.6rem;padding:.55rem;background:var(--text);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;text-align:center;transition:background .12s}
.story .sb:hover{background:var(--accent)}

/* Rep section */
.rep-sec{background:var(--card);border-radius:12px;padding:1rem;box-shadow:var(--shadow);margin-bottom:.85rem}
.rep-sec h2{font-size:1rem;margin-bottom:.6rem}
.contact-row{padding:.5rem 0;border-bottom:1px solid var(--border)}
.contact-row:last-child{border-bottom:none}
.contact-row strong{font-size:.9rem}
.contact-links{display:flex;gap:.4rem;margin-top:.35rem}
.contact-btn{display:inline-block;padding:.35rem .7rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-size:.78rem;font-weight:600;color:var(--text);text-decoration:none;transition:all .12s}
.contact-btn:hover{background:var(--text);color:#fff;border-color:var(--text)}

/* Actions */
.act-sec{background:var(--card);border-radius:12px;padding:1rem;box-shadow:var(--shadow)}
.act-sec h2{font-size:1rem;margin-bottom:.5rem}
.act-link{display:block;background:var(--text);color:#fff;padding:.75rem;border-radius:8px;text-decoration:none;font-weight:600;text-align:center;font-size:.9rem}
.act-link:hover{background:var(--accent)}

@media(max-width:500px){.stats-strip{grid-template-columns:repeat(2,1fr)}}
@media(min-width:501px) and (max-width:700px){.stats-strip{grid-template-columns:repeat(5,1fr)}}
@media(min-width:600px){main{max-width:540px;padding:1rem}}

/* Share modal */
#share-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center}
.share-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.4)}
.share-sheet{position:relative;background:#fff;border-radius:16px 16px 0 0;padding:1.25rem;width:100%;max-width:480px;animation:slideUp .2s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.share-sheet h3{font-size:1rem;margin-bottom:.75rem;text-align:center}
.share-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem .85rem;margin-bottom:.4rem;background:#f7f7f9;border:1px solid #e8e8ee;border-radius:10px;font-size:.95rem;font-family:inherit;color:#1a1a2e;text-decoration:none;cursor:pointer;font-weight:500}
.share-option:hover{background:#eee;border-color:#ccc}
.share-icon{font-size:1.2rem;width:28px;text-align:center}
.share-close{display:block;width:100%;padding:.7rem;margin-top:.5rem;background:none;border:1px solid #e8e8ee;border-radius:10px;font-family:inherit;font-size:.9rem;color:#6b6b80;cursor:pointer;text-align:center}
.share-close:hover{background:#f7f7f9}

.page-header{margin-bottom:.6rem}
.page-header h2{font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.3}

.pill{display:inline-block;padding:.1rem .35rem;border-radius:999px;font-size:.65rem;font-weight:700;background:#f3f4f6;color:#4b5563}
.pill.yes{background:#d1fae5;color:#065f46}
.pill.no{background:#fee2e2;color:#991b1b}
.accountability{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1rem}
