*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #f0ebe0;--warm: #e6e0d4;--sand: #d4cdc1;--sage: #b8bfad;--forest: #2d5a3d;--forest-mid: #3d7a52;--forest-light: #5a9a72;--forest-pale: #eaf2ed;--white: #ffffff;--red: #c62828;--orange: #e65100;--border: var(--sand);--shadow-sm: 0 1px 3px rgba(45,90,61,.08);--shadow-md: 0 4px 12px rgba(45,90,61,.1);--radius: 12px;--radius-sm: 8px;--font-display: "Barlow Condensed", sans-serif;--font-body: "Inter Tight", sans-serif}body{font-family:var(--font-body);background:var(--cream);color:var(--forest);line-height:1.5}.site-header{background:var(--cream);color:var(--forest);padding:2.5rem 1.5rem 1.5rem;border-bottom:2px solid var(--sage)}.header-inner{max-width:1000px;margin:0 auto}.logo-text{font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--forest-mid)}.header-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.05;text-transform:uppercase;letter-spacing:.02em;margin-top:.4rem;color:var(--forest)}.header-subtitle{font-size:1rem;color:var(--forest-mid);margin-top:.5rem}.main-content{max-width:1000px;margin:0 auto;padding:2rem 1.5rem 3rem}.section{margin-bottom:3rem}.section-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--forest);border-bottom:2px solid var(--sage);padding-bottom:.4rem;margin-bottom:.75rem}.section-desc{color:var(--forest-mid);font-size:.92rem;margin-bottom:1.25rem}.filter-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--forest-pale);border:1px solid var(--sage);border-radius:var(--radius-sm);margin-bottom:1.75rem}.filter-label{font-size:.85rem;font-weight:600;color:var(--forest);white-space:nowrap}.filter-select{font-family:var(--font-body);font-size:.88rem;padding:.35rem .6rem;border:1px solid var(--sand);border-radius:6px;background:var(--cream);color:var(--forest);cursor:pointer;flex:1;min-width:220px;max-width:400px}.filter-select:focus{outline:2px solid var(--forest-mid)}.filter-clear{font-size:.8rem;padding:.3rem .7rem;border:1px solid var(--sand);border-radius:6px;background:var(--cream);color:var(--forest-mid);cursor:pointer;white-space:nowrap}.filter-clear:hover{background:var(--warm);color:var(--red);border-color:var(--red)}.district-context{font-size:.9rem;color:var(--forest-mid);margin-bottom:1.25rem}.hero-stats{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.hero-stat{flex:1;min-width:200px;padding:1.25rem 1.5rem;background:var(--white);border:1px solid var(--sand);border-radius:var(--radius-sm);border-left-width:4px;box-shadow:var(--shadow-sm)}.hero-stat--red{border-left-color:var(--red)}.hero-stat--orange{border-left-color:var(--orange)}.hero-stat-pct{font-family:var(--font-display);font-size:3.5rem;font-weight:800;line-height:1;margin-bottom:.35rem}.hero-stat--red .hero-stat-pct{color:var(--red)}.hero-stat--orange .hero-stat-pct{color:var(--orange)}.hero-stat-label{font-size:.92rem;color:var(--forest);line-height:1.4}.hero-top-concerns{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius-sm);padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.hero-concerns-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--forest-mid);margin-bottom:.75rem}.hero-concerns-list{list-style:none;counter-reset:concern-counter;display:flex;flex-direction:column;gap:.5rem}.hero-concerns-list li{counter-increment:concern-counter;display:flex;align-items:baseline;justify-content:space-between;gap:1rem;font-size:.88rem}.hero-concerns-list li:before{content:counter(concern-counter) ".";font-weight:700;color:var(--forest-mid);min-width:1.2rem;flex-shrink:0}.concern-name{color:var(--forest);flex:1}.concern-pct{color:var(--forest-mid);white-space:nowrap;font-size:.8rem}.hero-footnote{font-size:.78rem;color:var(--forest-light);font-style:italic}.county-map-wrap{position:relative;margin-bottom:1.5rem}.county-map-svg{width:100%;max-width:800px;height:auto;display:block;background:var(--forest-pale);border:1px solid var(--sand);border-radius:var(--radius-sm)}.map-tooltip{position:fixed;background:#2d5a3deb;color:#fff;font-size:.8rem;padding:.3rem .6rem;border-radius:4px;pointer-events:none;z-index:100;white-space:nowrap}.map-legend{display:flex;align-items:center;gap:1rem;margin-top:.5rem;font-size:.78rem;color:var(--forest-mid)}.legend-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;vertical-align:middle}.county-table-wrap{max-height:300px;overflow-y:auto;border:1px solid var(--sand);border-radius:var(--radius-sm)}.county-table{width:100%;border-collapse:collapse;font-size:.88rem}.county-table th{position:sticky;top:0;background:var(--forest-pale);padding:.6rem 1rem;text-align:left;font-weight:600;color:var(--forest);border-bottom:1px solid var(--sand)}.county-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.county-table th.sortable:hover{background:#d5e8db}.county-table td{padding:.5rem 1rem;border-bottom:1px solid var(--warm)}.county-table tr:last-child td{border-bottom:none}.county-table tr:hover td{background:var(--forest-pale)}.sentiment-bar{display:flex;height:40px;border-radius:6px;overflow:hidden;border:1px solid var(--sand);margin-bottom:1rem}.sentiment-segment{height:100%;transition:width .4s ease}.sentiment-legend{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;font-size:.85rem;margin-bottom:.75rem}.legend-item{display:flex;align-items:center;gap:.35rem}.legend-swatch{display:inline-block;width:14px;height:14px;border-radius:3px}.legend-label{color:var(--forest);font-weight:500}.legend-pct{color:var(--forest-mid)}.legend-count{color:var(--forest-light);font-size:.78rem}.sentiment-note{font-size:.78rem;color:var(--forest-light);font-style:italic}.topline-stat{display:flex;align-items:baseline;flex-wrap:wrap;gap:.4rem .6rem;margin-bottom:1.75rem;padding:1.25rem 1.5rem;background:var(--white);border:1px solid var(--sand);border-left:4px solid var(--red);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.topline-pct{font-family:var(--font-display);font-size:3rem;font-weight:800;color:var(--red);line-height:1}.topline-label{font-size:1rem;font-weight:500;color:var(--forest);max-width:340px}.topline-sub{width:100%;font-size:.78rem;color:var(--forest-light)}.hbar-list-title{font-size:1rem;font-weight:600;color:var(--forest);margin-bottom:1rem}.hbar-row{display:grid;grid-template-columns:1fr 200px 80px;align-items:center;gap:.75rem;margin-bottom:.6rem}@media(max-width:600px){.hbar-row{grid-template-columns:1fr;gap:.25rem}}.hbar-label{font-size:.84rem;color:var(--forest);line-height:1.35}.hbar-track{height:20px;background:var(--warm);border-radius:4px;overflow:hidden}.hbar-fill{height:100%;border-radius:4px;transition:width .4s ease}.hbar-fill--concern{background:var(--red)}.hbar-fill--policy{background:var(--forest-mid)}.hbar-stat{font-size:.82rem;color:var(--forest-mid);white-space:nowrap}.hbar-count{font-weight:600;margin-right:.25rem}.hbar-pct{color:var(--forest-light)}.hbar-note{font-size:.75rem;color:var(--forest-light);font-style:italic;margin-top:.75rem}.loading-state,.error-state,.empty-state{padding:2rem;text-align:center;color:var(--forest-light);font-size:.9rem}.error-state{color:var(--red)}.site-footer{background:var(--forest);color:#ffffffbf;padding:1.5rem;text-align:center;font-size:.82rem}.footer-inner{max-width:1000px;margin:0 auto}.footer-updated{margin-bottom:.5rem}.footer-links a{color:#ffffffd9;text-decoration:none}.footer-links a:hover{text-decoration:underline}
