/* PoliPrism bundled stylesheet — generated by scripts/build_poliprism_css.py; edit styles.css */

/* === styles.css === */
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;1,400&family=Space+Grotesk:wght@400;500;600;700&display=swap");

:root {
  --bg-deep: #0a1020;
  --bg-secondary: #0f172a;
  --surface: #10192b;
  --surface-elevated: #142033;
  --border: #22314a;
  --text: #e8eef9;
  --muted: #9fb0c9;
  --accent-blue: #4f8cff;
  --accent-cyan: #36d1dc;
  --accent-red: #e05263;
  --accent-gold: #d4a94d;
  --bg: var(--bg-deep);
  --federal: var(--accent-blue);
  --states: var(--accent-cyan);
  --territories: #7c9ce7;
  --party-democrat: #2563eb;
  --party-republican: #dc2626;
  --party-independent: #94a3b8;
  --party-other: #64748b;
}

* {
  box-sizing: border-box;
}

html {
  overflow-x: hidden;
  /* Keep layout width stable when vertical scrollbar appears on taller pages */
  scrollbar-gutter: stable;
}

body {
  margin: 0;
  width: 100%;
  font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background-color: var(--bg-deep);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(79, 140, 255, 0.18), transparent 32%),
    radial-gradient(circle at 82% 18%, rgba(224, 82, 99, 0.1), transparent 28%),
    linear-gradient(180deg, #0a1020 0%, #0b1220 45%, #0e1628 100%);
  background-size: auto;
  background-repeat: no-repeat;
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  position: relative;
  display: flex;
  flex-direction: column;
}

h1,
h2,
h3,
h4,
.page-title,
.home-hero__title {
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.38;
  background-image:
    linear-gradient(rgba(34, 49, 74, 0.45) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34, 49, 74, 0.45) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 78% 60% at 50% -8%, rgb(0 0 0) 18%, transparent 70%);
}

/* Header above main so masthead search dropdown stacks over page content (main follows header in DOM). */
body > .site-header {
  position: relative;
  z-index: 100;
}

body > main,
body > .site-footer {
  position: relative;
  z-index: 1;
}

.container {
  width: 100%;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  box-sizing: border-box;
}

.site-header {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 2rem 0;
}

.site-header h1 {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.tagline {
  margin: 0.25rem 0 0;
  color: var(--muted);
  font-size: 1rem;
}

main {
  padding: 2rem 0 3rem;
  flex: 1 1 auto;
}

.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 999;
  padding: 0.5rem 1rem;
  background: var(--surface-elevated);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.skip-link:focus {
  left: 1rem;
  top: 1rem;
}

.site-header__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem 2rem;
}

.site-header__brand-mark {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.85rem 1.1rem;
  min-width: 0;
}

.site-header__logo-link {
  flex-shrink: 0;
  line-height: 0;
  border-radius: 8px;
}
.site-header__logo-link:focus-visible {
  outline: 2px solid var(--federal);
  outline-offset: 3px;
}

.site-header__logo {
  display: block;
  height: 3.25rem;
  width: auto;
  max-width: min(200px, 38vw);
  object-fit: contain;
}

.site-header__titles {
  min-width: 0;
}

.site-header__brand h1 {
  margin: 0;
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
}
.site-nav a {
  color: var(--muted);
  text-decoration: none;
  font-weight: 500;
  font-size: 0.95rem;
}
.site-nav a:hover {
  color: var(--text);
  text-decoration: underline;
}

/* Masthead: logo mark + primary nav (all pages); glass bar — padding in homepage block below */

.site-header__row--masthead {
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  flex-wrap: nowrap;
}

@media (max-width: 540px) {
  .site-header__row--masthead {
    flex-wrap: wrap;
  }
}

.site-header__masthead-logo {
  display: block;
  line-height: 0;
  border-radius: 12px;
  flex-shrink: 0;
}

.site-header__masthead-logo:focus-visible {
  outline: 2px solid var(--accent-cyan);
  outline-offset: 4px;
  border-radius: 12px;
}

.site-header__logo--masthead {
  height: clamp(2.875rem, 5.5vw, 3.75rem);
  width: auto;
  max-width: min(240px, 55vw);
  object-fit: contain;
  display: block;
}

.site-nav--masthead {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.2rem 0.05rem;
}

.site-nav--masthead a {
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: 0.78125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition:
    color 0.18s ease,
    background 0.18s ease,
    box-shadow 0.18s ease;
}

.site-nav--masthead a:hover {
  color: var(--text);
  background: rgba(79, 140, 255, 0.1);
  text-decoration: none;
}

.site-nav--masthead a[aria-current="page"] {
  color: var(--accent-cyan);
  background: rgba(54, 209, 220, 0.12);
  box-shadow: inset 0 0 0 1px rgba(54, 209, 220, 0.32);
}

.site-nav--masthead a:focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
}

/* Icon bar: legislators + bills */
.site-nav--iconbar {
  flex-wrap: nowrap;
  gap: 0.35rem;
  align-items: center;
}

.site-nav-icon-svg {
  display: block;
  flex-shrink: 0;
}

.site-nav-icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 10px;
  color: var(--muted);
  text-decoration: none;
  transition:
    color 0.18s ease,
    background 0.18s ease,
    box-shadow 0.18s ease;
}

.site-nav-icon-link:hover {
  color: var(--text);
  background: rgba(79, 140, 255, 0.1);
}

.site-nav-icon-link[aria-current="page"] {
  color: var(--accent-cyan);
  background: rgba(54, 209, 220, 0.12);
  box-shadow: inset 0 0 0 1px rgba(54, 209, 220, 0.32);
}

.site-nav-icon-link:focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
}

.intro {
  margin-bottom: 2rem;
  padding: 0 0 1rem;
  border-bottom: 1px solid var(--border);
}

.intro p {
  margin: 0;
  color: var(--muted);
  max-width: 56ch;
}

.levels-heading {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 1.25rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.levels-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  align-items: stretch;
}

.level-card {
  display: flex;
  flex-direction: column;
  flex: 1 1 280px;
  max-width: 360px;
  min-width: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.5rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s ease;
}

.level-card:hover {
  border-color: currentColor;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  transform: translateY(-2px);
}

.level-card h3 {
  margin: 0 0 0.5rem;
  font-size: 1.35rem;
  font-weight: 600;
}

.level-card p {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: var(--muted);
  flex: 1;
}

.level-link {
  font-size: 0.9rem;
  font-weight: 500;
  opacity: 0.9;
}

/* Level card accent colors */
.level-federal { color: var(--federal); }
.level-federal .level-graphic { --graphic-color: var(--federal); }
.level-states { color: var(--states); }
.level-states .level-graphic { --graphic-color: var(--states); }
.level-territories { color: var(--territories); }
.level-territories .level-graphic { --graphic-color: var(--territories); }

/* Graphics: simple CSS shapes */
.level-graphic {
  --graphic-color: var(--muted);
  width: 100%;
  height: 120px;
  margin-bottom: 1rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.03) 0%, transparent 100%);
  border-radius: 8px;
}

/* Federal: capitol dome + pillars */
.graphic-dome {
  position: absolute;
  bottom: 28px;
  width: 56px;
  height: 36px;
  border: 3px solid var(--graphic-color);
  border-bottom: none;
  border-radius: 28px 28px 0 0;
  opacity: 0.85;
}

.graphic-pillars {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 32px;
  border: 2px solid var(--graphic-color);
  border-top: none;
  border-radius: 0 0 4px 4px;
  opacity: 0.7;
}

.graphic-pillars::before,
.graphic-pillars::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 2px;
  height: 32px;
  background: var(--graphic-color);
  opacity: 0.7;
}

.graphic-pillars::before { left: 12px; }
.graphic-pillars::after { right: 12px; left: auto; }

/* States: outline map + star */
.graphic-map {
  position: absolute;
  width: 70px;
  height: 44px;
  border: 2.5px solid var(--graphic-color);
  border-radius: 50% 50% 45% 48% / 48% 52% 45% 50%;
  opacity: 0.8;
  transform: rotate(-8deg);
}

.graphic-star {
  position: absolute;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 16px solid var(--graphic-color);
  opacity: 0.9;
  transform: translateY(-4px);
}

.graphic-star::before {
  content: "";
  position: absolute;
  top: 4px;
  left: -10px;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 16px solid var(--graphic-color);
}

/* Territories: islands + sun */
.graphic-islands {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: 72px;
  height: 20px;
}

.graphic-islands::before,
.graphic-islands::after {
  content: "";
  position: absolute;
  bottom: 0;
  border: 2px solid var(--graphic-color);
  border-radius: 50%;
  opacity: 0.8;
}

.graphic-islands::before {
  width: 24px;
  height: 20px;
  left: 0;
}

.graphic-islands::after {
  width: 18px;
  height: 16px;
  right: 8px;
  bottom: 2px;
}

.graphic-sun {
  position: absolute;
  top: 16px;
  right: 24px;
  width: 28px;
  height: 28px;
  border: 2.5px solid var(--graphic-color);
  border-radius: 50%;
  opacity: 0.85;
}

.site-footer {
  background: rgba(15, 23, 42, 0.92);
  border-top: 1px solid var(--border);
  padding: 1.5rem 0;
  margin-top: auto;
}

.site-footer p { margin: 0; }
.site-footer small {
  color: rgba(159, 176, 201, 1);
  font-size: 0.8125rem;
}

/* Sub-pages: breadcrumb + list layout */
.breadcrumb {
  margin-bottom: 1.5rem;
  font-size: 0.9rem;
}

.breadcrumb a {
  color: var(--muted);
  text-decoration: none;
}

.breadcrumb a:hover { color: var(--text); }
.breadcrumb span { color: var(--muted); }

.page-title {
  font-size: 1.5rem;
  margin: 0 0 0.5rem;
}

.page-subtitle {
  color: var(--muted);
  margin: 0 0 1.5rem;
}

.body-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
}

.body-list a {
  display: block;
  padding: 0.85rem 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: inherit;
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
}

.body-list a:hover {
  border-color: var(--federal);
  background: var(--surface-elevated);
}

.body-list .body-name { font-weight: 600; }
.body-list .body-desc { font-size: 0.875rem; color: var(--muted); margin-top: 0.2rem; }

.states-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0.5rem;
}

.states-grid a {
  display: block;
  padding: 0.6rem 0.75rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: inherit;
  text-decoration: none;
  text-align: center;
  font-size: 0.9rem;
  transition: border-color 0.2s, background 0.2s;
}

.states-grid a:hover {
  border-color: var(--states);
  background: var(--surface-elevated);
}

.states-grid .states-grid__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.45rem;
}

/* Fixed-height band so every card has the state name in the same vertical slot. */
.states-grid__thumb {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 3rem;
  box-sizing: border-box;
}

.states-grid__flag {
  display: block;
  max-width: 100%;
  max-height: 3rem;
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: center;
  border-radius: 3px;
}

.states-grid__label {
  display: block;
  width: 100%;
  line-height: 1.25;
  text-align: center;
}

.state-symbols-note {
  font-size: 0.8125rem;
  color: var(--muted);
  margin: -0.25rem 0 1.25rem;
  max-width: 48rem;
}

.state-symbols-note a {
  color: var(--states);
}

.state-hub-hero {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.5rem;
  margin: 0 0 1.25rem;
  padding: 0.75rem 0 1rem;
  border-bottom: 1px solid var(--border);
}

.state-hub-hero__flag {
  display: block;
  max-width: 180px;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
}

.state-hub-hero__seal {
  display: block;
  width: 100px;
  height: auto;
  max-height: 120px;
  object-fit: contain;
}

.territories-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
}

.territories-list a {
  display: block;
  padding: 1rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: inherit;
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
}

.territories-list a:hover {
  border-color: var(--territories);
  background: var(--surface-elevated);
}

.territories-list .body-name { font-weight: 600; }
.territories-list .body-desc { font-size: 0.875rem; color: var(--muted); margin-top: 0.25rem; }

/* Counties: dropdown on state page */
.counties-section {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}

/* State index: county dropdown at top of page */
.county-dropdown-top {
  margin-bottom: 1.5rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--border);
}
.county-dropdown-top .county-label { font-weight: 600; color: var(--text); }
.county-dropdown-desc {
  font-size: 0.875rem;
  color: var(--muted);
  margin-top: 0.5rem;
  margin-bottom: 0;
}

.county-dropdown-wrap {
  margin-top: 1rem;
}

.county-label {
  display: block;
  font-size: 0.9rem;
  color: var(--muted);
  margin-bottom: 0.5rem;
}

.county-select {
  width: 100%;
  max-width: 360px;
  padding: 0.6rem 2rem 0.6rem 0.75rem;
  font-size: 1rem;
  font-family: inherit;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b949e' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
}

.county-select:hover,
.county-select:focus {
  border-color: var(--states);
  outline: none;
}

/* County page: non-link list items */
.body-list-item.placeholder {
  display: block;
  padding: 0.85rem 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.body-list-item .body-name { font-weight: 600; }
.body-list-item .body-desc { font-size: 0.875rem; color: var(--muted); margin-top: 0.2rem; }

.county-officials .levels-heading { margin-top: 1.5rem; }
.county-officials .levels-heading:first-of-type { margin-top: 0; }

/* Federal/state member lists (DB-driven) */
.member-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}

.member-item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.65rem 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.member-item--empty {
  color: var(--muted);
  font-size: 0.9rem;
}

.member-name {
  font-weight: 600;
  color: inherit;
}

.member-item a.member-name:hover {
  color: var(--federal);
}

.member-meta {
  font-size: 0.875rem;
  color: var(--muted);
}

/* Federal member grid (photo cards linking to profile) */
.member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 1.25rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.member-grid .member-item--empty {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.9rem;
}

.member-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s ease;
}

.member-card:hover {
  border-color: var(--federal);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  transform: translateY(-2px);
}

.member-card__photo {
  display: block;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  margin-bottom: 0.75rem;
  background: var(--surface-elevated);
  flex-shrink: 0;
}

.member-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.member-card__img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 0.75rem;
  color: var(--muted);
}

.member-card__name {
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.3;
}

.member-card__meta {
  font-size: 0.8rem;
  color: var(--muted);
  margin-top: 0.25rem;
}

/* Member profile page (individual) */
.member-profile {
  margin-top: 0.5rem;
}

.member-profile__head {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--border);
}

.member-profile__photo-wrap {
  flex-shrink: 0;
  width: 200px;
  height: 250px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--surface-elevated);
}

.member-profile__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.member-profile__photo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--muted);
  font-size: 1rem;
}

.member-profile__info {
  flex: 1;
  min-width: 200px;
}

.member-profile__role {
  color: var(--muted);
  margin: 0.25rem 0 0.5rem;
  font-size: 1.05rem;
}

.member-profile__bio {
  margin: 0.5rem 0 0;
  color: var(--text);
  max-width: 56ch;
}

.member-profile section {
  margin-top: 1.5rem;
}

.member-profile section h2 {
  font-size: 1.1rem;
  margin: 0 0 0.5rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.member-profile section p {
  margin: 0;
}

.term-history {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
}

.term-history li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
  color: var(--muted);
}

.term-history li:last-child {
  border-bottom: none;
}

/* --- Homepage: civic intelligence landing --- */
.main--home {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  flex: 1 1 auto;
}

.site-header--masthead {
  position: relative;
  background: rgba(15, 23, 42, 0.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(34, 49, 74, 0.95);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset;
  padding: 0.85rem 0 0.95rem;
}

.site-header--masthead + main {
  margin-top: 0;
}

/* Masthead: large white feature icons (map + capitol + bill document) */
.site-header--masthead .site-nav--iconbar {
  gap: 0.45rem;
}

.site-header--masthead .site-nav--iconbar a.site-nav-icon-link {
  padding: 0;
  width: 3.35rem;
  height: 3.35rem;
  border-radius: 14px;
  color: rgba(255, 255, 255, 0.94);
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.07) inset;
  text-transform: none;
  font-size: 0;
  letter-spacing: normal;
  transition:
    color 0.2s ease,
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.18s ease;
}

.site-header--masthead .site-nav--iconbar a.site-nav-icon-link:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 0 0 0 1px rgba(96, 165, 250, 0.45), 0 12px 32px rgba(0, 0, 0, 0.25);
  transform: translateY(-2px);
}

.site-header--masthead .site-nav--iconbar a.site-nav-icon-link[aria-current="page"] {
  color: #ffffff;
  background: rgba(45, 212, 191, 0.22);
  border-color: rgba(45, 212, 191, 0.55);
  box-shadow: inset 0 0 0 1px rgba(45, 212, 191, 0.4), 0 0 28px rgba(45, 212, 191, 0.2);
}

.site-header--masthead .site-nav-icon-svg--feature {
  display: block;
}

.home-hero {
  position: relative;
  display: flex;
  align-items: center;
  min-height: clamp(22rem, 42vh, 32rem);
  padding: clamp(5rem, 9vw, 7.5rem) 0;
  overflow: hidden;
}

.home-hero__glow {
  position: absolute;
  inset: -25% 0 auto 0;
  height: min(420px, 85vw);
  background: radial-gradient(ellipse 55% 70% at 28% 0%, rgba(79, 140, 255, 0.2), transparent 68%);
  pointer-events: none;
  z-index: 0;
}

.home-hero__texture {
  position: absolute;
  inset: 0;
  opacity: 0.12;
  background-image: linear-gradient(
    118deg,
    transparent 42%,
    rgba(54, 209, 220, 0.06) 50%,
    transparent 58%
  );
  pointer-events: none;
  z-index: 0;
}

.home-hero__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 52rem;
}

.home-brand-name {
  margin: 0 0 0.65rem;
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: clamp(1.25rem, 2.8vw, 1.55rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.2;
}

.home-brand-name::after {
  content: "";
  display: block;
  width: 3rem;
  height: 3px;
  margin-top: 0.85rem;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--accent-blue), var(--accent-cyan));
  opacity: 0.85;
}

.home-hero__title {
  margin: 0;
  font-size: clamp(2rem, 4.6vw, 3.25rem);
  font-weight: 700;
  line-height: 1.11;
  letter-spacing: -0.032em;
  color: var(--text);
  max-width: 22ch;
}

@media (min-width: 640px) {
  .home-hero__title {
    max-width: none;
  }
}

.home-hero__sub {
  margin: 1.35rem 0 0;
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--muted);
  max-width: 48ch;
}

.home-destinations {
  padding: clamp(2.25rem, 5vw, 3.5rem) 0 clamp(2.5rem, 5vw, 4rem);
  border-top: 1px solid rgba(34, 49, 74, 0.75);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.35) 0%, transparent 100%);
}

.home-section-head {
  margin-bottom: 1.75rem;
  max-width: 40rem;
}

.home-section-head__title {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.home-section-head__lead {
  margin: 0.65rem 0 0;
  font-size: 1.125rem;
  line-height: 1.5;
  color: var(--text);
  font-weight: 500;
}

.home-destination-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(17.5rem, 1fr));
  gap: 1.15rem;
}

/* Home: three large entry panels (States, Legislators, Bills) */
.home-destination-grid--home-main {
  grid-template-columns: 1fr;
  gap: 1.35rem;
}

@media (min-width: 640px) {
  .home-destination-grid--home-main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
  }
}

@media (min-width: 1100px) {
  .home-destination-grid--home-main {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
  }
}

.home-card--home-main {
  min-height: 15rem;
  padding: 2rem 1.75rem 1.65rem;
}

.home-card--home-main .home-card__title {
  font-size: 1.45rem;
}

.home-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 100%;
  padding: 1.5rem 1.45rem 1.35rem;
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset;
  transition:
    border-color 0.2s ease,
    box-shadow 0.22s ease,
    transform 0.18s ease,
    background 0.2s ease;
  overflow: hidden;
}

.home-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  background: var(--card-accent, var(--accent-blue));
  opacity: 0.85;
  transition: opacity 0.2s ease;
}

.home-card:hover {
  border-color: rgba(79, 140, 255, 0.35);
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(79, 140, 255, 0.12);
  transform: translateY(-3px);
}

.home-card:focus-visible {
  outline: 2px solid var(--accent-cyan);
  outline-offset: 3px;
}

.home-card--federal {
  --card-accent: var(--accent-blue);
}

.home-card--states {
  --card-accent: var(--accent-cyan);
}

.home-card--territories {
  --card-accent: var(--accent-gold);
}

.home-card--legislators {
  --card-accent: #2dd4bf;
}

.home-card--bills {
  --card-accent: #a78bfa;
}

.home-card__label {
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.home-card__meta {
  display: block;
  margin-top: 0.4rem;
  font-size: 0.8125rem;
  color: rgba(159, 176, 201, 1);
  line-height: 1.45;
}

.home-card__title {
  margin: 1rem 0 0;
  font-size: 1.28rem;
  font-weight: 600;
  line-height: 1.28;
  letter-spacing: -0.02em;
  color: var(--text);
}

.home-card__desc {
  margin: 0.65rem 0 0;
  flex: 1 1 auto;
  font-size: 0.9375rem;
  line-height: 1.58;
  color: var(--muted);
  max-width: 40ch;
}

.home-card__cta {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 1.25rem;
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--card-accent, var(--accent-blue));
}

.home-card__cta-arrow {
  transition: transform 0.18s ease;
}

.home-card:hover .home-card__cta-arrow {
  transform: translateX(4px);
}

.home-trust {
  padding: clamp(2rem, 4vw, 3rem) 0 clamp(2.75rem, 6vw, 4rem);
  border-top: 1px solid rgba(34, 49, 74, 0.65);
  background: rgba(10, 16, 32, 0.65);
}

.home-trust__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16.5rem, 1fr));
  gap: 1.5rem;
  align-items: start;
}

.home-trust__panel {
  padding: 1.35rem 1.4rem;
  border-radius: 12px;
  border: 1px solid rgba(34, 49, 74, 0.9);
  background: rgba(16, 25, 43, 0.55);
}

.home-trust__panel--accent {
  border-color: rgba(224, 82, 99, 0.25);
  background: linear-gradient(160deg, rgba(20, 32, 51, 0.9), rgba(16, 25, 43, 0.75));
}

.home-trust__title {
  margin: 0 0 0.65rem;
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.home-trust__subtitle {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--accent-cyan);
}

.home-trust__text {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.62;
  color: var(--muted);
}

.home-trust__text + .home-trust__text {
  margin-top: 0.85rem;
}

.home-trust__disclaimer {
  margin: 1.15rem 0 0;
  padding: 0.75rem 0.85rem;
  border-radius: 8px;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted);
  background: rgba(10, 16, 32, 0.55);
  border: 1px solid rgba(34, 49, 74, 0.85);
}

.home-trust__disclaimer-mark {
  display: block;
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-gold);
  margin-bottom: 0.35rem;
}

body.is-home main.main--home {
  padding-bottom: 0;
}

/* --- Header search --- */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-header__search {
  position: relative;
  z-index: 1;
  flex: 1 1 160px;
  min-width: 140px;
  max-width: min(320px, 42vw);
  margin: 0 0.75rem;
}

.site-header__search-input {
  width: 100%;
  box-sizing: border-box;
  padding: 0.45rem 0.65rem;
  font-size: 0.8125rem;
  border-radius: 8px;
  border: 1px solid rgba(34, 49, 74, 0.95);
  background: rgba(10, 16, 32, 0.65);
  color: var(--text);
}

.site-header__search-input::placeholder {
  color: rgba(159, 176, 201, 0.7);
}

.site-header__search-input:focus {
  outline: 2px solid var(--accent-cyan);
  outline-offset: 1px;
  border-color: rgba(54, 209, 220, 0.45);
}

.site-search-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  margin: 0;
  padding: 0.25rem 0;
  list-style: none;
  background: rgba(15, 23, 42, 0.98);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
  z-index: 200;
  max-height: 280px;
  overflow-y: auto;
}

.site-search-results li {
  margin: 0;
  border-bottom: 1px solid rgba(34, 49, 74, 0.6);
}

.site-search-results li:last-child {
  border-bottom: none;
}

.site-search-results a {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.5rem 0.65rem;
  color: var(--text);
  text-decoration: none;
  font-size: 0.8125rem;
}

.site-search-results a:hover {
  background: rgba(79, 140, 255, 0.12);
}

.site-search-results__name {
  font-weight: 600;
}

.site-search-results__meta {
  font-size: 0.72rem;
  color: var(--muted);
}

.site-search-results__group-label {
  display: block;
  padding: 0.35rem 0.65rem;
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 0.93);
  background: rgba(16, 25, 43, 0.95);
}

/* --- Party accents --- */
.member-card--party-democrat {
  border-left: 3px solid var(--party-democrat);
}

.member-card--party-republican {
  border-left: 3px solid var(--party-republican);
}

.member-card--party-independent {
  border-left: 3px solid var(--party-independent);
}

.member-card--party-other {
  border-left: 3px solid var(--party-other);
}

.member-profile--party-democrat .member-profile__head {
  border-left: 3px solid var(--party-democrat);
  padding-left: 1rem;
  margin-left: -1rem;
}

.member-profile--party-republican .member-profile__head {
  border-left: 3px solid var(--party-republican);
  padding-left: 1rem;
  margin-left: -1rem;
}

.member-profile--party-independent .member-profile__head {
  border-left: 3px solid var(--party-independent);
  padding-left: 1rem;
  margin-left: -1rem;
}

.member-profile--party-other .member-profile__head {
  border-left: 3px solid var(--party-other);
  padding-left: 1rem;
  margin-left: -1rem;
}

.party-badge {
  display: inline-block;
  margin: 0.35rem 0 0.25rem;
  padding: 0.2rem 0.55rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.party-badge--party-democrat {
  background: rgba(37, 99, 235, 0.18);
  color: #93c5fd;
  border: 1px solid rgba(37, 99, 235, 0.45);
}

.party-badge--party-republican {
  background: rgba(220, 38, 38, 0.18);
  color: #fca5a5;
  border: 1px solid rgba(220, 38, 38, 0.45);
}

.party-badge--party-independent {
  background: rgba(148, 163, 184, 0.15);
  color: #cbd5e1;
  border: 1px solid rgba(148, 163, 184, 0.4);
}

.party-badge--party-other {
  background: rgba(100, 116, 139, 0.18);
  color: var(--muted);
  border: 1px solid rgba(100, 116, 139, 0.4);
}

.member-photo-placeholder-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: linear-gradient(160deg, #1e293b 0%, #0f172a 55%, #0c1220 100%);
  color: #475569;
}

.member-photo-silhouette {
  width: 48%;
  height: auto;
  max-width: 72px;
  opacity: 0.75;
}

.member-card__img-placeholder .member-photo-placeholder-inner {
  border-radius: 50%;
}

.member-profile__photo-placeholder .member-photo-placeholder-inner {
  min-height: 100%;
}

/* --- Hub chamber cards (federal / state landings) --- */
.hub-section-title {
  font-size: 1.05rem;
  margin: 2rem 0 1rem;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.hub-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.25rem;
  margin-top: 0.5rem;
}

.hub-chamber-card {
  display: flex;
  flex-direction: column;
  padding: 1.35rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s ease;
}

.hub-chamber-card:hover {
  border-color: rgba(54, 209, 220, 0.45);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3);
  transform: translateY(-2px);
}

.hub-chamber-card--senate {
  border-left: 3px solid var(--federal);
}

.hub-chamber-card--house {
  border-left: 3px solid var(--accent-cyan);
}

.hub-chamber-card__label {
  font-family: "Space Grotesk", "IBM Plex Sans", sans-serif;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text);
}

.hub-chamber-card__desc {
  flex: 1;
  margin: 0.65rem 0 0.85rem;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--muted);
}

.hub-chamber-card__stats {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
}

.hub-chamber-card__cta {
  margin-top: 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--accent-cyan);
}

/* --- State landing quick facts --- */
.state-summary {
  margin: 1.5rem 0 2rem;
  padding: 1.25rem 1.35rem;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(34, 49, 74, 0.85);
  border-radius: 12px;
}

.state-summary__title {
  margin: 0 0 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.state-summary__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem 1.5rem;
  margin: 0;
}

.state-summary__item {
  margin: 0;
}

.state-summary__item dt {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 0.9);
  margin: 0 0 0.3rem;
}

.state-summary__item dd {
  margin: 0;
  font-size: 0.95rem;
  color: var(--text);
  line-height: 1.45;
}

@media (max-width: 720px) {
  .site-header__search {
    order: 3;
    flex: 1 1 100%;
    max-width: none;
    margin: 0.5rem 0 0;
  }

  .site-header__row--masthead {
    flex-wrap: wrap;
  }
}

/* Bills (Prism) */
.bills-congress-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 1.5rem;
}

.bills-congress-nav__item {
  font-size: 12px;
  padding: 4px 12px;
  border-radius: 20px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  color: rgba(159, 176, 201, 1);
  text-decoration: none;
}

.bills-congress-nav__item--active {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.4);
  color: rgba(133, 183, 235, 0.95);
}

.prism-bill-list {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin: 1.5rem 0 2rem;
}

/* Bill card (unified /bills/ detail layout) */
.prism-bill-detail {
  padding: 1.25rem 1.5rem;
  border-radius: 12px;
  border: 0.5px solid var(--border);
  background: var(--surface);
}

.prism-bill-detail__identity {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 12px;
  line-height: 1.35;
}

.prism-bill-detail__badge {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.04em;
  font-size: 12px;
  color: var(--accent-blue);
  background: rgba(79, 140, 255, 0.14);
  border: 0.5px solid rgba(79, 140, 255, 0.35);
}

.prism-bill-detail__badge--muted {
  background: rgba(159, 176, 201, 0.3);
  color: rgba(159, 176, 201, 1);
  border-color: rgba(159, 176, 201, 0.5);
}

.prism-bill-detail__badge--amber {
  background: rgba(186, 117, 23, 0.2);
  color: #ef9f27;
  border-color: rgba(186, 117, 23, 0.45);
}

.prism-bill-detail__badge--teal {
  background: rgba(29, 158, 117, 0.2);
  color: #1d9e75;
  border-color: rgba(29, 158, 117, 0.4);
}

/* List row: tight pill, slightly larger type than body chips */
.bills-card__row .prism-bill-detail__badge {
  padding: 0;
  font-size: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  max-width: 100%;
  background: transparent;
  border: none;
  border-radius: 0;
  color: inherit;
}

.prism-bill-detail__subjects {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 6px 0 10px;
}

.prism-bill-detail__subject-area {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(29, 158, 117, 0.15);
  color: rgba(93, 202, 165, 0.95);
  font-weight: 500;
}

.prism-bill-detail__subject-tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(159, 176, 201, 0.27);
  color: rgba(159, 176, 201, 1);
}

.prism-bill-detail__taxonomy {
  padding: 10px 0 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 0.5px solid rgba(159, 176, 201, 0.35);
  margin-top: 10px;
}

.prism-bill-detail__taxonomy-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(159, 176, 201, 0.8);
}

.prism-bill-detail__taxonomy-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}
.prism-bill-detail__taxonomy-col {
  flex: 1 1 0;
  min-width: 120px;
  padding-left: 16px;
  border-left: 0.5px solid rgba(159, 176, 201, 0.2);
}
.prism-bill-detail__taxonomy-col:first-child {
  padding-left: 0;
  border-left: none;
}
.prism-bill-detail__taxonomy-col-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 0.6);
  margin: 0 0 4px;
}
.prism-bill-detail__taxonomy-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.prism-bill-detail__tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(55, 138, 221, 0.15);
  color: rgba(133, 183, 235, 0.95);
}

.prism-bill-detail__tag--action {
  background: rgba(127, 119, 221, 0.15);
  color: rgba(175, 169, 236, 0.95);
}

.prism-bill-detail__tag--flag {
  background: rgba(216, 90, 48, 0.15);
  color: rgba(240, 153, 123, 0.95);
}

/* Federal bill detail: CRS + Prism pills as links to /bills/ (see buildBillsFilterHref) */
a.prism-bill-detail__pill-link {
  cursor: pointer;
  text-decoration: none;
  border: none;
  display: inline-block;
  box-sizing: border-box;
}

a.prism-bill-detail__pill-link:hover {
  filter: brightness(1.15);
  text-decoration: underline;
  text-underline-offset: 2px;
}

a.prism-bill-detail__pill-link:focus-visible {
  outline: 2px solid rgba(55, 138, 221, 0.55);
  outline-offset: 2px;
}

/* CRS chip colors must not be overridden by .prism-bill-detail__tag (links omit that class) */
a.prism-bill-detail__subject-area.prism-bill-detail__pill-link,
a.prism-bill-detail__subject-tag.prism-bill-detail__pill-link {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 500;
}

a.prism-bill-detail__subject-area.prism-bill-detail__pill-link {
  background: rgba(29, 158, 117, 0.15);
  color: rgba(93, 202, 165, 0.95);
}

a.prism-bill-detail__subject-tag.prism-bill-detail__pill-link {
  background: rgba(159, 176, 201, 0.27);
  color: rgba(159, 176, 201, 1);
  font-weight: 500;
}

.prism-bill-detail__identity-meta,
.prism-bill-detail__identity-type {
  color: var(--muted);
}

.prism-bill-detail__identity-dot {
  color: var(--muted);
  opacity: 0.65;
  user-select: none;
}

.prism-bill-detail__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.prism-bill-detail__title {
  flex: 1;
  min-width: 0;
  margin: 10px 0 12px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--text);
}

.prism-bill-detail__expand-label {
  flex-shrink: 0;
  margin: 10px 0 0;
  padding: 0.2rem 0.35rem;
  cursor: pointer;
  user-select: none;
  background: none;
  border: none;
  color: var(--muted);
  font-size: 0.8125rem;
  line-height: 1.2;
}

.prism-bill-detail__expand-label:hover {
  color: var(--text);
}

.prism-bill-detail__expand-label:focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
  border-radius: 4px;
}

.prism-bill-detail__state:checked ~ .prism-bill-detail__title-row .prism-bill-detail__chev--more {
  display: none;
}

.prism-bill-detail__state:not(:checked) ~ .prism-bill-detail__title-row .prism-bill-detail__chev--less {
  display: none;
}

.prism-bill-detail--bills-index .prism-bill-detail__slide {
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.prism-bill-detail--bills-index .prism-bill-detail__state:not(:checked) ~ .prism-bill-detail__slide {
  max-height: 0;
  margin: 0;
  padding: 0;
  border: 0;
  pointer-events: none;
}

.prism-bill-detail--bills-index .prism-bill-detail__state:checked ~ .prism-bill-detail__slide {
  max-height: 800px;
}

.prism-bill-detail:not(.prism-bill-detail--bills-index) .prism-bill-detail__state {
  display: none;
}

.prism-bill-detail:not(.prism-bill-detail--bills-index) .prism-bill-detail__expand-label {
  display: none;
}

.prism-bill-detail:not(.prism-bill-detail--bills-index) .prism-bill-detail__slide {
  max-height: none;
  overflow: visible;
}

.prism-bill-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.prism-bill-detail__tile {
  min-height: 72px;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--bg-secondary);
  border: 0.5px solid rgba(34, 49, 74, 0.65);
}

.prism-bill-detail__tile-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.25;
  margin-bottom: 0.35rem;
}

.prism-bill-detail__tile-value {
  font-size: 13px;
  line-height: 1.45;
  color: rgba(230, 237, 248, 0.92);
  word-break: break-word;
}

.prism-bill-detail__tile-value--stack {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.prism-bill-detail__tile-value--cosponsors {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.prism-bill-detail__cosponsor-line {
  line-height: 1.45;
}

.prism-bill-detail__action-text {
  color: rgba(159, 176, 201, 1);
  font-size: 13px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.prism-bill-detail__action-date {
  font-size: 11px;
  line-height: 1.3;
  color: rgba(159, 176, 201, 0.8);
}

.prism-bill-detail__tertiary {
  color: rgba(159, 176, 201, 0.8);
}

.prism-bill-detail__info-link {
  color: var(--accent-blue);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(79, 140, 255, 0.4);
}

.prism-bill-detail__info-link:hover {
  color: var(--text);
  border-bottom-color: rgba(232, 238, 249, 0.45);
}

.prism-bill-detail__info-link:focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
  border-bottom-color: transparent;
}

.prism-bill-detail__prism {
  margin-top: 0;
  padding-top: 14px;
  border-top: 0.5px solid var(--border);
}

.prism-bill-detail__prism-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.prism-bill-detail__prism-mark {
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  flex-shrink: 0;
  line-height: 0;
}

.prism-bill-detail__prism-mark img {
  display: block;
  width: 52px;
  height: 52px;
  object-fit: contain;
}

.prism-bill-detail__prism-body {
  flex: 1;
  min-width: 0;
}

.prism-bill-detail__prism-kicker {
  margin: 0 0 0.35rem;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.2;
}

.prism-bill-detail__prism-track {
  position: relative;
  padding-top: 10px;
}

.prism-bill-detail__prism-bar {
  position: relative;
  z-index: 0;
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(90deg, #4f8cff 0%, #7c3aed 50%, #e05263 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.prism-bill-detail__prism-needle {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: none;
}

.prism-bill-detail__prism-needle-cap {
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid var(--text);
}

.prism-bill-detail__prism-needle-stem {
  width: 2px;
  height: 14px;
  margin-top: -1px;
  background: var(--text);
  border-radius: 1px;
}

.prism-bill-detail__prism-scale {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: baseline;
  gap: 0.35rem;
  margin-top: 0.4rem;
  font-variant-numeric: tabular-nums;
}

.prism-bill-detail__prism-scale-end {
  font-size: 10px;
  line-height: 1.3;
  color: rgba(159, 176, 201, 0.8);
}

.prism-bill-detail__prism-scale > :nth-child(1) {
  justify-self: start;
  text-align: left;
}

.prism-bill-detail__prism-scale > :nth-child(3) {
  justify-self: end;
  text-align: right;
}

.prism-bill-detail__prism-scale-center {
  justify-self: center;
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--text);
  max-width: 100%;
}

.prism-bill-detail__slide--summary .prism-bill-detail__summary-block {
  margin-top: 0;
  padding-top: 12px;
  border-top: 0.5px solid var(--border);
}

.prism-bill-detail__summary-label {
  margin: 0 0 0.4rem;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
  line-height: 1.2;
}

.prism-bill-detail__summary-text {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: rgba(220, 228, 240, 1);
}

.prism-bills-empty {
  color: var(--muted);
  font-size: 1rem;
}

/* Dynamic federal shells (API-driven member / chamber pages) */
.skeleton {
  background: rgba(159, 176, 201, 0.23);
  border-radius: 4px;
  animation: skeleton-pulse 1.5s ease-in-out infinite;
  display: block;
}

@keyframes skeleton-pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.chamber-stats {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
  font-size: 13px;
  color: rgba(159, 176, 201, 1);
}

.chamber-stats__item--dem { color: #378add; }
.chamber-stats__item--rep { color: #d85a30; }
.chamber-stats__item--ind { color: rgba(159, 176, 201, 1); }

.chamber-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 1.25rem;
}

.chamber-filter__state,
.chamber-filter__search {
  font-size: 13px;
  padding: 5px 10px;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: transparent;
  color: rgba(159, 176, 201, 1);
}

.chamber-filter__search {
  min-width: 180px;
}

.chamber-filter__party {
  display: flex;
  gap: 6px;
}

.chamber-filter__pill {
  font-size: 12px;
  padding: 4px 12px;
  border-radius: 20px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: transparent;
  color: rgba(159, 176, 201, 1);
  cursor: pointer;
}

.chamber-filter__pill--active {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.4);
  color: rgba(133, 183, 235, 0.95);
}

/* Bills landing (/bills/) — toolbar + API-driven list */
.bills-app__intro {
  max-width: 52rem;
}

.bills-app__archive-links {
  display: inline;
}

.bills-app__archive-links a {
  white-space: nowrap;
}

.bills-app-congress-fallback {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin: 0 0 0.65rem;
}

.bills-app-congress-fallback__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
}

.bills-app-congress-fallback__select {
  font: inherit;
  font-size: 14px;
  padding: 0.45rem 0.55rem;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.5);
  background: rgba(8, 12, 18, 0.65);
  color: rgba(220, 228, 240, 1);
  min-width: 10rem;
}

.bills-app-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 8.5rem;
}

.bills-app-field--grow {
  flex: 1 1 12rem;
  min-width: 12rem;
}

.bills-app-field label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
}

.bills-app-field select,
.bills-app-field input[type="search"] {
  font: inherit;
  font-size: 14px;
  padding: 0.45rem 0.55rem;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.5);
  background: rgba(8, 12, 18, 0.65);
  color: rgba(220, 228, 240, 1);
}

.bills-app-actions {
  min-width: unset;
  align-self: flex-end;
}

.bills-app-btn {
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  border: 0.5px solid rgba(55, 138, 221, 0.45);
  background: rgba(55, 138, 221, 0.2);
  color: rgba(133, 183, 235, 0.98);
  cursor: pointer;
}

.bills-app-btn:hover {
  background: rgba(55, 138, 221, 0.28);
}

.bills-app-btn--ghost {
  background: transparent;
  border-color: rgba(159, 176, 201, 0.5);
  color: rgba(159, 176, 201, 1);
}

.bills-app-btn--ghost:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.bills-app-status {
  min-height: 1.15rem;
  font-size: 13px;
  color: var(--muted);
  margin: 0 0 0.35rem;
  text-align: left;
}

.bills-app-error {
  color: rgba(235, 120, 120, 0.9);
}

.bills-app-jurisdiction {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.65rem;
}

.bills-app-jurisdiction__label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pp-muted, #6b7a8f);
}

.bills-app-jurisdiction__select {
  min-width: 12rem;
  max-width: 100%;
  padding: 0.35rem 0.5rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
}

.bills-app-filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(100, 120, 150, 0.2);
}

.bills-app-filter-row__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: min(100%, 10.5rem);
  flex: 1 1 auto;
}

.bills-app-filter-row__field--sponsor {
  flex: 2 1 16rem;
  min-width: min(100%, 18rem);
  position: relative;
}

.bills-app-filter-row__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--pp-muted, #6b7a8f);
}

.bills-app-filter-row__select,
.bills-app-filter-row__input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 0.45rem 0.55rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
  font-size: 0.875rem;
}

.bills-app-filter-row__field--sponsor .bills-sponsor-search {
  margin-bottom: 0;
  max-width: none;
}

.bills-research-panel {
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(100, 120, 150, 0.2);
}

.bills-research-panel__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem 1rem;
}

.bills-research-panel__row--2 {
  margin-top: 0.75rem;
  align-items: flex-end;
}

.bills-research-panel__search-wrap {
  flex: 1 1 100%;
  min-width: min(100%, 12rem);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

@media (min-width: 720px) {
  .bills-research-panel__search-wrap {
    flex: 3 1 18rem;
  }
}

.bills-research-panel__search-input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 0.5rem 0.65rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
  font-size: 0.9rem;
}

.bills-research-panel__jurisdiction,
.bills-research-panel__congress-wrap,
.bills-research-panel__session-wrap {
  flex: 1 1 10rem;
  min-width: min(100%, 10.5rem);
}

.bills-research-panel__seg-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  flex: 1 1 auto;
  min-width: min(100%, 9rem);
}

.bills-research-panel__seg {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}

.bills-research-panel__seg-btn {
  padding: 0.3rem 0.55rem;
  font-size: 0.8rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.45);
  color: inherit;
  cursor: pointer;
}

.bills-research-panel__seg-btn:hover:not(:disabled) {
  border-color: rgba(55, 138, 221, 0.45);
}

.bills-research-panel__seg-btn--active {
  border-color: rgba(55, 138, 221, 0.75);
  background: rgba(55, 138, 221, 0.15);
}

.bills-research-panel__seg-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.bills-research-panel__federal-only--muted {
  opacity: 0.55;
}

/* ── Advanced search toggle + collapsible panel ── */
.bills-research-panel__advanced-toggle {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  width: 100%;
  margin-top: 0.5rem;
  padding: 0.45rem 0.65rem;
  border: 1px solid rgba(100, 120, 150, 0.2);
  border-radius: 6px;
  background: rgba(12, 16, 24, 0.35);
  color: rgba(159, 176, 201, 1);
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.bills-research-panel__advanced-toggle:hover {
  border-color: rgba(55, 138, 221, 0.4);
  background: rgba(55, 138, 221, 0.06);
}
.bills-research-panel__advanced-toggle--open {
  border-color: rgba(55, 138, 221, 0.35);
  background: rgba(55, 138, 221, 0.06);
}
.bills-research-panel__advanced-chev {
  font-size: 0.7rem;
  line-height: 1;
}
.bills-research-panel__advanced {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  border-left: 3px solid rgba(55, 138, 221, 0.4);
  background: rgba(55, 138, 221, 0.04);
  border-radius: 0 8px 8px 0;
  margin-top: 0.5rem;
}
.bills-research-panel__advanced--open {
  max-height: 2000px;
  overflow: visible;
  padding: 0.5rem 1rem 0.75rem;
}
.bills-research-panel__advanced-header {
  display: flex;
  justify-content: flex-end;
  padding: 0 0 0.25rem;
}

/* ── Reset buttons ── */
.bills-research-panel__reset {
  padding: 0.3rem 0.7rem;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: 5px;
  border: 1px solid rgba(100, 120, 150, 0.3);
  background: transparent;
  color: rgba(159, 176, 201, 0.95);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
  flex-shrink: 0;
  align-self: flex-end;
}
.bills-research-panel__reset:hover {
  border-color: rgba(55, 138, 221, 0.5);
  color: rgba(200, 210, 225, 1);
}
.bills-research-panel__row-reset {
  padding: 0.2rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 500;
  border-radius: 4px;
  border: 1px solid rgba(100, 120, 150, 0.25);
  background: transparent;
  color: rgba(159, 176, 201, 0.8);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
  margin-top: 0.15rem;
  align-self: flex-start;
}
.bills-research-panel__row-reset:hover {
  border-color: rgba(55, 138, 221, 0.45);
  color: rgba(200, 210, 225, 1);
}

/* ── Topic browse host inside advanced panel ── */
.bills-research-panel__topic-host {
  margin-top: 0.75rem;
}
.bills-topic-browse-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.bills-research-panel__sponsor {
  flex: 2 1 14rem;
  min-width: min(100%, 14rem);
}

.bills-active-topics-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.5rem;
  min-height: 0.25rem;
}

.bills-active-topic-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.35rem 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.8rem;
  background: rgba(55, 138, 221, 0.18);
  border: 1px solid rgba(55, 138, 221, 0.4);
}

.bills-active-topic-pill__x {
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0 0.15rem;
  border-radius: 4px;
}

/* ── Universal Filter Bucket ── */
.filter-bucket {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 0.6rem 0.75rem;
  margin-bottom: 0.75rem;
  background: rgba(159, 176, 201, 0.06);
  border: 0.5px solid rgba(159, 176, 201, 0.2);
  border-radius: 8px;
}
.filter-bucket[hidden] { display: none; }
.filter-bucket__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.filter-bucket__pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 6px 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 500;
  border: 1px solid rgba(159, 176, 201, 0.35);
  background: rgba(159, 176, 201, 0.1);
  color: rgba(200, 210, 225, 0.95);
}
.filter-bucket__pill-label {
  white-space: nowrap;
}
.filter-bucket__pill-x {
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0 2px;
  border-radius: 3px;
  opacity: 0.7;
  transition: opacity 0.15s;
}
.filter-bucket__pill-x:hover {
  opacity: 1;
  background: rgba(255, 255, 255, 0.08);
}
/* Color variants */
.filter-bucket__pill--dem {
  background: rgba(37, 99, 235, 0.15);
  border-color: rgba(37, 99, 235, 0.4);
  color: rgba(130, 175, 255, 0.95);
}
.filter-bucket__pill--rep {
  background: rgba(220, 38, 38, 0.15);
  border-color: rgba(220, 38, 38, 0.4);
  color: rgba(250, 140, 140, 0.95);
}
.filter-bucket__pill--ind {
  background: rgba(148, 163, 184, 0.15);
  border-color: rgba(148, 163, 184, 0.4);
  color: rgba(180, 195, 210, 0.95);
}
.filter-bucket__pill--score {
  background: rgba(127, 119, 221, 0.15);
  border-color: rgba(127, 119, 221, 0.4);
  color: rgba(175, 169, 236, 0.95);
}
.filter-bucket__pill--cat {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.4);
  color: rgba(133, 183, 235, 0.95);
}
.filter-bucket__pill--action {
  background: rgba(127, 119, 221, 0.15);
  border-color: rgba(127, 119, 221, 0.4);
  color: rgba(175, 169, 236, 0.95);
}
.filter-bucket__pill--flag {
  background: rgba(216, 90, 48, 0.15);
  border-color: rgba(216, 90, 48, 0.4);
  color: rgba(240, 153, 123, 0.95);
}
.filter-bucket__pill--crs {
  background: rgba(54, 209, 220, 0.1);
  border-color: rgba(54, 209, 220, 0.35);
  color: rgba(120, 220, 225, 0.95);
}
.filter-bucket__pill--neutral {
  background: rgba(159, 176, 201, 0.1);
  border-color: rgba(159, 176, 201, 0.35);
}
.filter-bucket__clear-all {
  flex-shrink: 0;
  padding: 4px 12px;
  border-radius: 5px;
  border: 1px solid rgba(159, 176, 201, 0.3);
  background: transparent;
  color: rgba(159, 176, 201, 0.8);
  font: inherit;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.filter-bucket__clear-all:hover {
  border-color: rgba(55, 138, 221, 0.5);
  color: rgba(200, 210, 225, 0.95);
}

/* Result count badge */
.filter-bucket__count {
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(220, 230, 245, 0.95);
  margin-right: 4px;
  white-space: nowrap;
}

/* AND/OR mode toggle */
.filter-bucket__mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-right: 6px;
}
.filter-bucket__mode-label {
  font-size: 0.72rem;
  color: rgba(159, 176, 201, 0.75);
  font-weight: 500;
}
.filter-bucket__mode-btn {
  padding: 2px 8px;
  font-size: 0.72rem;
  font-weight: 500;
  border-radius: 4px;
  border: 1px solid rgba(100, 120, 150, 0.3);
  background: transparent;
  color: rgba(159, 176, 201, 0.8);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.filter-bucket__mode-btn--active {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.5);
  color: rgba(200, 215, 235, 0.95);
}

/* Actions row (Clear all + Share + Export) */
.filter-bucket__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.filter-bucket__share,
.filter-bucket__export {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 5px;
  border: 1px solid rgba(100, 120, 150, 0.3);
  background: transparent;
  color: rgba(159, 176, 201, 0.8);
  font: inherit;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.filter-bucket__share:hover,
.filter-bucket__export:hover {
  border-color: rgba(55, 138, 221, 0.5);
  color: rgba(200, 210, 225, 0.95);
}
.filter-bucket__share svg,
.filter-bucket__export svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

/* Date range inputs in advanced panel */
.bills-research-panel__date-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  flex: 1 1 auto;
  min-width: min(100%, 14rem);
}
.bills-research-panel__date-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.bills-research-panel__date-input {
  flex: 1;
  min-width: 0;
  padding: 0.35rem 0.5rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
  font-size: 0.82rem;
}
.bills-research-panel__date-input:focus {
  border-color: rgba(55, 138, 221, 0.55);
  outline: none;
}
.bills-research-panel__date-sep {
  font-size: 0.78rem;
  color: rgba(159, 176, 201, 0.65);
  flex-shrink: 0;
}

/* Empty state */
.bills-empty-state {
  text-align: center;
  padding: 1.5rem 1rem;
}
.bills-empty-state__text {
  font-size: 0.95rem;
  color: rgba(200, 210, 225, 0.85);
  margin: 0 0 0.5rem;
}
.bills-empty-state__hint {
  font-size: 0.82rem;
  color: rgba(159, 176, 201, 0.7);
  margin: 0;
}

.bills-active-topic-pill__x:hover {
  background: rgba(255, 255, 255, 0.08);
}

.bills-score-dist__limited {
  margin: 0.35rem 0 0;
  font-size: 0.78rem;
  color: var(--pp-muted, #8a96a8);
}

.bills-topic-browse-panel--static {
  margin-bottom: 1.25rem;
}

.bills-topic-browse-static-title {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 0.5rem;
  letter-spacing: 0.02em;
}

/* Sponsor search autocomplete */
.bills-sponsor-search {
  position: relative;
  margin-bottom: 0.5rem;
  max-width: 340px;
}
.bills-sponsor-search__input {
  width: 100%;
  box-sizing: border-box;
  padding: 0.4rem 0.6rem;
  border: 0.5px solid rgba(159, 176, 201, 0.43);
  border-radius: 4px;
  background: rgba(8, 12, 20, 0.55);
  color: rgba(210, 218, 232, 1);
  font-size: 0.85rem;
}
.bills-sponsor-search__input:focus {
  border-color: rgba(55, 138, 221, 0.55);
  outline: none;
}
.bills-sponsor-search__input::placeholder {
  color: rgba(159, 176, 201, 0.6);
}
.bills-sponsor-search__results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 80;
  margin-top: 2px;
  border-radius: 6px;
  background: rgba(16, 20, 30, 0.97);
  border: 1px solid rgba(100, 120, 150, 0.35);
  max-height: 320px;
  overflow-y: auto;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.45);
}
.bills-sponsor-search__item {
  display: flex;
  flex-direction: column;
  gap: 1px;
  width: 100%;
  padding: 0.5rem 0.7rem;
  border: none;
  background: none;
  color: inherit;
  text-align: left;
  cursor: pointer;
  font-size: 0.85rem;
}
.bills-sponsor-search__item:hover,
.bills-sponsor-search__item--active {
  background: rgba(79, 140, 255, 0.14);
}
.bills-sponsor-search__item + .bills-sponsor-search__item {
  border-top: 1px solid rgba(100, 120, 150, 0.15);
}
.bills-sponsor-search__item-name {
  font-weight: 600;
  color: #c8d6e5;
}
.bills-sponsor-search__item-meta {
  font-size: 0.78rem;
  color: rgba(159, 176, 201, 0.8);
}
.bills-sponsor-search__empty {
  padding: 0.6rem 0.7rem;
  font-size: 0.82rem;
  color: rgba(159, 176, 201, 0.65);
}

/* Sponsor filter banner */
.bills-sponsor-banner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0.85rem;
  margin-bottom: 0.5rem;
  border-radius: 6px;
  background: rgba(79, 140, 255, 0.12);
  border: 1px solid rgba(79, 140, 255, 0.3);
  font-size: 0.92rem;
  color: #c8d6e5;
}
.bills-sponsor-banner__text {
  flex: 1 1 auto;
}
.bills-sponsor-banner__clear {
  flex: 0 0 auto;
  background: none;
  border: none;
  color: #8fa4b8;
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0 0.3rem;
  line-height: 1;
}
.bills-sponsor-banner__clear:hover {
  color: #fff;
}

.bills-app-sort-bar {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  padding: 0.15rem 0 0;
  margin-bottom: 0;
  border-bottom: none;
}

.bills-app-sort-bar__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  padding: 0;
  box-sizing: border-box;
}

/* Same 5-column grid as .bills-card__row; bordered cells; flush with first bill row. */
.bills-app-sort-bar__grid {
  display: grid;
  grid-template-columns:
    var(--bills-list-col-badge) minmax(0, 1fr) var(--bills-list-col-action) var(--bills-list-col-score)
    var(--bills-list-col-chev);
  column-gap: 0;
  align-items: stretch;
  padding: 0 12px 0 0;
  box-sizing: border-box;
  border: 0.5px solid rgba(159, 176, 201, 0.37);
  border-radius: 8px 8px 0 0;
  background: rgba(16, 22, 32, 0.35);
}

.bills-app-sort-bar__cell {
  min-width: 0;
  display: flex;
  align-items: center;
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  box-sizing: border-box;
}

.bills-app-sort-bar__cell:last-child {
  border-right: none;
}

.bills-app-sort-bar__cell--stacked {
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 6px;
}

.bills-app-sort-bar__stack {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  min-width: 0;
  width: 100%;
}

.bills-app-sort-header-search {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  font: inherit;
  font-size: 11px;
  padding: 4px 6px;
  border-radius: 4px;
  border: 0.5px solid rgba(159, 176, 201, 0.43);
  background: rgba(8, 12, 20, 0.55);
  color: rgba(210, 218, 232, 1);
}

.bills-app-sort-header-search::placeholder {
  color: rgba(159, 176, 201, 0.6);
}

.bills-app-sort-header-search:focus {
  outline: none;
  border-color: rgba(55, 138, 221, 0.55);
}

/* Match .bills-card__row cell padding (no grid gap — borders align). */
.bills-app-sort-bar__cell--bill {
  padding: 10px 12px 10px 8px;
}

.bills-app-sort-bar__cell--name {
  padding: 10px 12px 10px 12px;
}

.bills-app-sort-bar__cell--action {
  padding: 10px 12px 10px 12px;
}

.bills-app-sort-bar__cell--score {
  padding: 10px 12px 10px 12px;
}

.bills-app-sort-bar__cell--chev {
  padding: 10px 14px 10px 12px;
}

.bills-app-sort-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0.2rem 0;
  border: none;
  background: transparent;
  font: inherit;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 0.7);
  cursor: pointer;
  text-align: inherit;
  transition: color 0.15s;
}

.bills-app-sort-bar__cell--bill .bills-app-sort-btn {
  justify-content: flex-start;
  width: 100%;
  text-align: left;
}

.bills-app-sort-bar__cell--name .bills-app-sort-btn {
  justify-content: flex-start;
  width: 100%;
  text-align: left;
}

.bills-app-sort-bar__cell--action .bills-app-sort-btn {
  justify-content: flex-end;
  width: 100%;
  text-align: right;
}

.bills-app-sort-bar__cell--score .bills-app-sort-btn {
  justify-content: flex-end;
  width: 100%;
  text-align: right;
}

.bills-app-sort-btn:hover,
.bills-app-sort-btn:focus-visible {
  color: rgba(200, 210, 225, 1);
  outline: none;
}

.bills-app-sort-btn--active {
  color: rgba(133, 183, 235, 0.95);
}

.bills-app-sort-dir {
  font-size: 10px;
  opacity: 0.9;
  min-width: 1em;
}

.bills-app-sort-bar__clear {
  font-size: 12px;
  padding: 0.25rem 0.5rem;
}

.bills-app-sort-bar__clear:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.bills-app-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.bills-app-sort-bar + .bills-app-list > .bills-card:first-child {
  border-top: none;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  margin-top: 0;
}

.bills-app-card {
  padding: 1rem 1.1rem;
  border-radius: 8px;
  border: 0.5px solid rgba(159, 176, 201, 0.37);
  background: rgba(16, 22, 32, 0.45);
}

.bills-app-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.5rem;
}

.bills-app-card__meta {
  font-size: 12px;
  color: rgba(159, 176, 201, 1);
}

.bills-app-card__dot {
  color: rgba(159, 176, 201, 0.6);
}

.bills-app-card__badge {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(55, 138, 221, 0.15);
  color: rgba(133, 183, 235, 0.95);
}

.bills-app-card__title {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 0.6rem;
  line-height: 1.35;
  color: rgba(235, 238, 245, 0.98);
}

.bills-app-card__action {
  margin: 0 0 0.35rem;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(200, 210, 225, 1);
}

.bills-app-card__date {
  margin: 0 0 0.6rem;
  font-size: 12px;
  color: rgba(159, 176, 201, 0.9);
}

.bills-app-card__links {
  margin: 0;
  font-size: 13px;
}

.bills-app-card__links a {
  color: rgba(133, 183, 235, 0.95);
}

.bills-app-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.75rem 1rem;
  margin: 1.5rem 0 2rem;
}

.bills-app-pagination__status {
  font-size: 13px;
  color: var(--muted);
}

#bills-landing {
  margin-bottom: 2rem;
}

#bills-app-root.bills-app-root--below-landing {
  border-top: 0.5px solid rgba(159, 176, 201, 0.35);
  padding-top: 0.65rem;
}

/* Bill list row + sort header: shared column widths (badge pill + type/number). */
#bills-app-root {
  --bills-list-col-badge: 6.5rem;
  --bills-list-col-action: 6.75rem;
  --bills-list-col-score: 200px;
  --bills-list-col-chev: 2.5rem;
}

.bills-stat-tiles {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 1.5rem;
}

.bills-stat-tiles--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bills-stat-tile {
  background: rgba(159, 176, 201, 0.21);
  border: 0.5px solid rgba(159, 176, 201, 0.3);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.bills-stat-tile__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgba(159, 176, 201, 0.75);
}

.bills-stat-tile__value {
  font-size: 22px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
}

.bills-stat-tile--congress .bills-stat-tile__label {
  margin-bottom: 2px;
}

.bills-stat-tile__congress-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 0;
}

.bills-stat-tile__value--congress-count {
  flex: 0 0 auto;
  line-height: 1;
}

.bills-stat-tile__congress-select {
  flex: 1 1 9rem;
  min-width: 0;
  max-width: 100%;
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  padding: 0.35rem 0.5rem;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: rgba(8, 12, 18, 0.55);
  color: rgba(220, 228, 240, 1);
}

.bills-category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 1.5rem;
}

.bills-category-cell {
  background: rgba(159, 176, 201, 0.2);
  border: 0.5px solid rgba(159, 176, 201, 0.3);
  border-radius: 8px;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font: inherit;
  color: inherit;
}

.bills-category-cell:hover {
  border-color: rgba(55, 138, 221, 0.4);
  background: rgba(55, 138, 221, 0.08);
}

.bills-category-cell__name {
  font-size: 13px;
  color: rgba(220, 228, 240, 1);
  font-weight: 500;
}

.bills-category-cell__count {
  font-size: 11px;
  color: rgba(159, 176, 201, 0.75);
}

.bills-score-dist {
  margin-bottom: 1rem;
}

.bills-score-dist__bar-row {
  display: flex;
  align-items: flex-start;
  gap: 0;
  margin-bottom: 6px;
}
.bills-score-dist__token {
  width: 28px;
  height: 40px;
  flex-shrink: 0;
  margin-right: 8px;
  object-fit: contain;
  object-position: center;
}

.bills-score-dist__bar-col {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.bills-score-dist__all {
  flex: 0 0 auto;
  min-width: 3rem;
  height: 40px;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 6px 0 0 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.5);
  border-right: none;
  background: rgba(159, 176, 201, 0.23);
  color: rgba(200, 210, 225, 1);
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: filter 0.15s, box-shadow 0.15s, border-color 0.15s;
  outline: none;
  box-sizing: border-box;
}

.bills-score-dist__all:hover,
.bills-score-dist__all:focus-visible {
  filter: brightness(1.12);
  border-color: rgba(200, 210, 225, 0.6);
  outline: 2px solid rgba(255, 255, 255, 0.25);
  outline-offset: 2px;
}

.bills-score-dist__all.bills-score-dist__segment--selected {
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.75);
  border-color: rgba(200, 210, 225, 0.7);
  background: rgba(55, 138, 221, 0.12);
}

.bills-score-dist__bar {
  display: flex;
  flex: 1;
  min-width: 0;
  height: 40px;
  min-height: 40px;
  border-radius: 0 6px 6px 0;
  overflow: hidden;
  box-sizing: border-box;
}

.bills-score-dist__half,
.bills-score-dist__center {
  display: flex;
  min-width: 0;
  height: 40px;
}
.bills-score-dist__segment {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
}

.bills-score-dist__labels {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: rgba(159, 176, 201, 0.65);
  margin: 0;
  padding: 0 1px;
  width: 100%;
  box-sizing: border-box;
}

.bills-score-dist__count {
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  color: rgba(255, 255, 255, 0.95);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
  pointer-events: none;
}

.bills-score-dist__filter-msg {
  font-size: 0.8125rem;
  line-height: 1.45;
  color: rgba(159, 176, 201, 0.87);
  margin: 0.5rem 0 0;
}

.bills-archive-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 1.25rem;
  padding: 12px 16px;
  background: rgba(159, 176, 201, 0.2);
  border-radius: 8px;
  border: 0.5px solid rgba(159, 176, 201, 0.3);
}

.bills-archive-filter__search {
  flex: 1;
  min-width: 200px;
  font-size: 13px;
  padding: 5px 10px;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: transparent;
  color: rgba(159, 176, 201, 1);
}

.bills-archive-filter__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.bills-archive-pill {
  font-size: 11px;
  padding: 3px 10px;
  border-radius: 20px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: transparent;
  color: rgba(159, 176, 201, 0.9);
  cursor: pointer;
  font: inherit;
}

.bills-archive-pill--active {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.4);
  color: rgba(133, 183, 235, 0.95);
}

.bills-archive-filter__count {
  font-size: 12px;
  color: rgba(159, 176, 201, 0.7);
  margin: 0;
  white-space: nowrap;
}

/* Merged bill card — collapsed row + expandable detail (bills-app.js) */
.bills-app-toolbar__pills-row {
  flex: 1 1 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.5rem 1rem;
  margin-top: 0.25rem;
}

.bills-app-field--pills-label {
  min-width: 10rem;
  padding-top: 0.25rem;
}

.bills-app-pills-heading {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
}

.bills-app-category-pills-mount {
  margin: 0 0 0.5rem;
}

.bills-card {
  background: rgba(255, 255, 255, 0.03);
  border: 0.5px solid rgba(159, 176, 201, 0.33);
  border-radius: 8px;
  margin-bottom: 6px;
  transition: border-color 0.15s;
}

.bills-card:hover {
  border-color: rgba(159, 176, 201, 0.5);
}

.bills-card__row {
  display: grid;
  grid-template-columns:
    var(--bills-list-col-badge) minmax(0, 1fr) var(--bills-list-col-action) var(--bills-list-col-score)
    var(--bills-list-col-chev);
  column-gap: 0;
  align-items: stretch;
  padding: 0 12px 0 0;
  min-height: 50px;
  cursor: pointer;
  user-select: none;
}

.bills-card__row > .bills-card__badge {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 6px 10px;
  box-sizing: border-box;
  justify-self: stretch;
  align-self: stretch;
  display: flex;
  align-items: center;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  background: rgba(79, 140, 255, 0.12);
  color: rgba(130, 175, 255, 0.95);
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: 0.03em;
  border-radius: 0;
  border: none;
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
}

.bills-card__row > .bills-card__title {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 10px 12px 10px 12px;
  box-sizing: border-box;
  justify-self: stretch;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  text-align: left;
  font-size: 14px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bills-card__row > .bills-card__action-date {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 10px 12px 10px 12px;
  box-sizing: border-box;
  justify-self: stretch;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-size: 12px;
  font-weight: 500;
  color: rgba(159, 176, 201, 0.93);
  white-space: nowrap;
  min-width: 0;
  text-align: right;
}

.bills-card__row > .bills-card__score-mini {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 10px 12px 10px 12px;
  box-sizing: border-box;
  justify-self: stretch;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
}

.bills-card__row > .bills-card__chev {
  padding: 0;
  box-sizing: border-box;
  justify-self: stretch;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(200, 215, 235, 0.85);
  user-select: none;
}

/* Legacy single-class rules — row children use scoped rules above. */
.bills-card__badge {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-sizing: border-box;
}

.bills-card__title {
  min-width: 0;
  text-align: left;
  font-size: 14px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bills-card__action-date {
  font-size: 12px;
  font-weight: 500;
  color: rgba(159, 176, 201, 0.93);
  white-space: nowrap;
  min-width: 0;
  text-align: right;
}

.bills-card__score-mini {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  box-sizing: border-box;
}

.bills-card__score-track {
  flex: 1;
  height: 8px;
  min-height: 8px;
  border-radius: 4px;
  background: linear-gradient(to right, #378add, #7f77dd, #d85a30);
  position: relative;
  max-width: 120px;
}

.bills-card__score-needle {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 3px;
  height: 14px;
  background: rgba(220, 228, 240, 1);
  border-radius: 1px;
}

.bills-card__score-label {
  font-size: 10px;
  color: rgba(159, 176, 201, 0.85);
  white-space: nowrap;
  min-width: 90px;
  text-align: right;
}

.bills-card__chev {
  justify-self: end;
  align-self: center;
  font-size: 11px;
  color: rgba(159, 176, 201, 0.6);
  width: var(--bills-list-col-chev);
  text-align: center;
  user-select: none;
}

/* ── Bills card mobile responsive ── */
@media (max-width: 640px) {
  /* 3-column grid: Bill | Title | Score — kill Last Action + Chevron */
  .bills-card__row,
  .bills-app-sort-bar__grid {
    grid-template-columns: 4.5rem minmax(0, 1fr) 50px;
  }
  /* Hide action date + chevron columns entirely */
  .bills-card__row > .bills-card__action-date,
  .bills-card__row > .bills-card__chev,
  .bills-app-sort-bar__cell--action,
  .bills-app-sort-bar__cell--chev {
    display: none;
  }
  /* Hide score label text — just the track */
  .bills-card__score-label {
    display: none;
  }
  /* Score: fill the cell, no right border (it's the last visible column) */
  .bills-card__score-track {
    max-width: none;
    flex: 1;
  }
  .bills-card__row > .bills-card__score-mini {
    padding: 6px 6px;
    border-right: none;
  }
  /* Sort bar score cell: hide label on mobile, just an empty header */
  .bills-app-sort-bar__cell--score {
    padding: 8px 6px;
    border-right: none;
  }
  .bills-app-sort-bar__cell--score .bills-app-sort-btn__label {
    display: none;
  }
  /* Title wraps to 2-3 lines */
  .bills-card__row > .bills-card__title {
    white-space: normal;
    overflow: hidden;
  }
  .bills-card__title-text {
    white-space: normal;
    text-overflow: clip;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 13px;
  }
  /* Tighter row padding */
  .bills-card__row {
    padding: 0 4px 0 0;
    min-height: 42px;
  }
  .bills-card__row > .bills-card__badge {
    padding: 4px 6px;
    font-size: 11px;
  }
  .bills-card__row > .bills-card__title {
    padding: 6px 8px;
    font-size: 13px;
  }
  /* Sort bar matches */
  .bills-app-sort-bar__grid {
    padding: 0 4px 0 0;
  }
  .bills-app-sort-bar__cell--bill {
    padding: 8px 6px;
  }
  .bills-app-sort-bar__cell--name {
    padding: 8px 8px;
  }
  .bills-app-sort-bar__cell--score {
    padding: 8px 6px;
  }
}

.bills-card__detail {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  border-top: 0 solid rgba(159, 176, 201, 0.3);
}

.bills-card--expanded .bills-card__detail {
  max-height: 2000px;
  border-top-width: 0.5px;
}

.bills-card__detail-inner {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.bills-card__section {
  border-top: 0.5px solid rgba(159, 176, 201, 0.27);
  padding-top: 12px;
}

.bills-card__section--head {
  border-top: none;
  padding-top: 0;
}

.bills-card__section-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(159, 176, 201, 0.65);
  margin: 0 0 6px;
}

.bills-card__full-title {
  font-size: 15px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
  line-height: 1.45;
  margin: 0;
}

.bills-card__summary {
  font-size: 14px;
  color: rgba(220, 228, 240, 0.97);
  line-height: 1.65;
  margin: 0;
}

.bills-card__meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.bills-card__meta-value {
  font-size: 13px;
  color: rgba(220, 228, 240, 0.9);
  margin: 0;
  line-height: 1.5;
}

.bills-card__meta-date {
  font-size: 11px;
  color: rgba(159, 176, 201, 0.6);
  margin: 4px 0 0;
}

/* ── Prism Factor branded panel ── */
.bills-card__prism-factor {
  border-left: 3px solid #7f77dd;
  background: rgba(127, 119, 221, 0.06);
  border-radius: 0 8px 8px 0;
  padding: 0.75rem 1rem;
  margin: 0.5rem 0;
}
.bills-card__prism-factor .bills-card__section {
  border-bottom: none;
  padding-bottom: 0.35rem;
  width: 100%;
  min-width: 0;
}
.bills-card__prism-factor .bills-card__section:last-child {
  padding-bottom: 0;
}
.bills-card__prism-factor-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0.65rem;
}
.bills-card__prism-factor-icon {
  flex-shrink: 0;
  opacity: 0.9;
}
.bills-card__prism-factor-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(180, 175, 230, 0.95);
  letter-spacing: 0.03em;
}

/* ── Page-level Prism Factor panel (bills landing) ── */
.bills-page-prism-factor {
  border-left: 3px solid #7f77dd;
  background: rgba(127, 119, 221, 0.06);
  border-radius: 0 8px 8px 0;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
}
.bills-page-prism-factor__header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0.65rem;
}
.bills-page-prism-factor__icon {
  flex-shrink: 0;
  opacity: 0.9;
}
.bills-page-prism-factor__title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: rgba(180, 175, 230, 0.95);
  letter-spacing: 0.03em;
}
/* Collapsible Prism Categories inside Prism Factor */
.bills-page-prism-cats__toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  margin-top: 0.5rem;
  padding: 0.4rem 0;
  border: none;
  border-top: 0.5px solid rgba(159, 176, 201, 0.2);
  background: transparent;
  color: rgba(180, 175, 230, 0.85);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: color 0.15s;
}
.bills-page-prism-cats__toggle:hover {
  color: rgba(200, 195, 240, 1);
}
.bills-page-prism-cats__toggle--open {
  color: rgba(200, 195, 240, 1);
}
.bills-page-prism-cats__chev {
  flex-shrink: 0;
  transition: transform 0.2s;
}
.bills-page-prism-cats__toggle--open .bills-page-prism-cats__chev {
  transform: rotate(180deg);
}
.bills-page-prism-cats {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding-top: 0;
}
.bills-page-prism-cats--open {
  max-height: 2000px;
  overflow: visible;
  padding-top: 0.5rem;
}
.bills-page-prism-cats__group {
  width: 100%;
  margin-bottom: 0.5rem;
}
.bills-page-prism-cats__group:last-of-type {
  margin-bottom: 0;
}
.bills-page-prism-cats__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.bills-page-prism-cats__collapse {
  width: 100%;
  margin-top: 0.5rem;
}
/* Prism category chips match bill detail tag colors */
.bills-page-prism-cats .bills-filter-chip {
  background: rgba(55, 138, 221, 0.12);
  border-color: rgba(55, 138, 221, 0.3);
  color: rgba(133, 183, 235, 0.95);
}
.bills-page-prism-cats .bills-filter-chip:hover {
  border-color: rgba(55, 138, 221, 0.5);
}
.bills-page-prism-cats .bills-filter-chip--selected {
  background: rgba(55, 138, 221, 0.25);
  border-color: rgba(55, 138, 221, 0.6);
  color: rgba(180, 210, 245, 1);
}
/* Action chips — purple (matches bill detail) */
.bills-page-prism-cats .bills-filter-chip--action {
  background: rgba(127, 119, 221, 0.12);
  border-color: rgba(127, 119, 221, 0.3);
  color: rgba(175, 169, 236, 0.95);
}
.bills-page-prism-cats .bills-filter-chip--action:hover {
  border-color: rgba(127, 119, 221, 0.5);
}
.bills-page-prism-cats .bills-filter-chip--action.bills-filter-chip--selected {
  background: rgba(127, 119, 221, 0.25);
  border-color: rgba(127, 119, 221, 0.6);
  color: rgba(195, 190, 245, 1);
}
/* Flag chips — orange (matches bill detail) */
.bills-page-prism-cats .bills-filter-chip--flag {
  background: rgba(216, 90, 48, 0.12);
  border-color: rgba(216, 90, 48, 0.3);
  color: rgba(240, 153, 123, 0.95);
}
.bills-page-prism-cats .bills-filter-chip--flag:hover {
  border-color: rgba(216, 90, 48, 0.5);
}
.bills-page-prism-cats .bills-filter-chip--flag.bills-filter-chip--selected {
  background: rgba(216, 90, 48, 0.25);
  border-color: rgba(216, 90, 48, 0.6);
  color: rgba(250, 175, 150, 1);
}

.bills-card__prism-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.bills-card__prism-body {
  flex: 1;
  min-width: 0;
}

.bills-card__prism-track {
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(to right, #378add, #7f77dd, #d85a30);
  position: relative;
  margin-bottom: 6px;
}

.bills-card__prism-needle {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(-50%, -50%);
  width: 2px;
  height: 14px;
  background: rgba(220, 228, 240, 1);
  border-radius: 1px;
}

.bills-card__prism-scale {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}

.bills-card__prism-scale-end {
  font-size: 10px;
  color: rgba(159, 176, 201, 0.6);
}

.bills-card__prism-scale-center {
  font-size: 12px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
}

.bills-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  align-items: center;
}

.bills-card__footer-sep {
  color: rgba(159, 176, 201, 0.4);
  font-size: 13px;
}

.bills-card__footer-action {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0.3rem 0.6rem;
  border-radius: 5px;
  border: 1px solid rgba(100, 120, 150, 0.3);
  background: transparent;
  color: rgba(159, 176, 201, 1);
  font: inherit;
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.bills-card__footer-action:hover {
  border-color: rgba(55, 138, 221, 0.5);
  color: rgba(200, 210, 225, 1);
  background: rgba(55, 138, 221, 0.06);
}
.bills-card__footer-action svg {
  flex-shrink: 0;
}
.bills-card__footer-action--copied {
  border-color: rgba(29, 158, 117, 0.6);
  color: rgba(29, 158, 117, 0.95);
}

/* Collapse button at bottom of expanded detail */
.bills-card__collapse-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 10px 0;
  margin-top: 0.5rem;
  border: 1px solid rgba(159, 176, 201, 0.25);
  border-radius: 6px;
  background: rgba(159, 176, 201, 0.05);
  color: rgba(159, 176, 201, 0.8);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.bills-card__collapse-btn:hover {
  border-color: rgba(55, 138, 221, 0.45);
  color: rgba(200, 210, 225, 0.95);
  background: rgba(55, 138, 221, 0.06);
}
.bills-card__collapse-icon {
  flex-shrink: 0;
  color: rgba(220, 230, 245, 0.95);
}

/* Bill detail: designation line above title */
.bills-card__detail-designation {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(159, 176, 201, 0.75);
  margin: 0 0 4px;
}

/* Bill detail: introduced + synced dates column */
.bills-card__meta-dates-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bills-card__meta-dates-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 24px;
}

/* Legislative progress timeline */
/* ── Legislative progress: Congress.gov-inspired arrow tracker ── */
.bills-card__progress-track {
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
  padding: 0;
}

.progress-arrow {
  flex: 1;
  min-width: 0;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  background: rgba(159, 176, 201, 0.23);
  border-top: 1px solid rgba(159, 176, 201, 0.35);
  border-bottom: 1px solid rgba(159, 176, 201, 0.35);
  cursor: default;
}

/* Arrow pointing right between steps */
.progress-arrow::after {
  content: "";
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 17px solid transparent;
  border-bottom: 17px solid transparent;
  border-left: 10px solid rgba(159, 176, 201, 0.23);
  z-index: 2;
}
/* Outline arrow behind the fill arrow */
.progress-arrow::before {
  content: "";
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 18px solid transparent;
  border-bottom: 18px solid transparent;
  border-left: 11px solid rgba(159, 176, 201, 0.35);
  z-index: 1;
}

/* First step: rounded left edge */
.progress-arrow--first {
  border-left: 1px solid rgba(159, 176, 201, 0.35);
  border-radius: 5px 0 0 5px;
}

/* Last step: rounded right edge, no arrow */
.progress-arrow--last {
  border-right: 1px solid rgba(159, 176, 201, 0.35);
  border-radius: 0 5px 5px 0;
}
.progress-arrow--last::after,
.progress-arrow--last::before {
  display: none;
}

/* Done steps */
.progress-arrow--done {
  background: rgba(55, 138, 221, 0.18);
  border-color: rgba(55, 138, 221, 0.35);
}
.progress-arrow--done::after {
  border-left-color: rgba(55, 138, 221, 0.18);
}
.progress-arrow--done::before {
  border-left-color: rgba(55, 138, 221, 0.35);
}

/* Current step (last completed): brighter highlight */
.progress-arrow--current {
  background: rgba(55, 138, 221, 0.3);
  border-color: rgba(55, 138, 221, 0.5);
}
.progress-arrow--current::after {
  border-left-color: rgba(55, 138, 221, 0.3);
}
.progress-arrow--current::before {
  border-left-color: rgba(55, 138, 221, 0.5);
}

.progress-arrow__label {
  font-size: 11px;
  font-weight: 500;
  color: rgba(159, 176, 201, 0.65);
  text-align: center;
  line-height: 1.2;
  padding: 0 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  z-index: 3;
  position: relative;
}

.progress-arrow--done .progress-arrow__label {
  color: rgba(200, 215, 235, 0.9);
}

.progress-arrow--current .progress-arrow__label {
  color: rgba(220, 230, 245, 0.98);
  font-weight: 600;
}

/* Responsive: smaller text on narrow screens */
@media (max-width: 540px) {
  .progress-arrow {
    height: 30px;
  }
  .progress-arrow__label {
    font-size: 9px;
    padding: 0 3px;
  }
  .progress-arrow::after {
    right: -7px;
    border-top-width: 15px;
    border-bottom-width: 15px;
    border-left-width: 7px;
  }
  .progress-arrow::before {
    right: -9px;
    border-top-width: 16px;
    border-bottom-width: 16px;
    border-left-width: 8px;
  }
}

/* Committees list */
.bills-card__committee-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.bills-card__committee-item {
  font-size: 13px;
  color: rgba(220, 228, 240, 0.9);
  padding: 3px 0;
  line-height: 1.45;
}

.bills-card__committee-meta {
  font-size: 11px;
  color: rgba(159, 176, 201, 0.6);
}

/* Cosponsors toggle */
.bills-card__cosponsors-toggle {
  background: none;
  border: none;
  color: rgba(135, 180, 240, 0.8);
  font-size: 12px;
  cursor: pointer;
  padding: 4px 0 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.bills-card__cosponsors-toggle:hover {
  color: rgba(135, 180, 240, 1);
}

/* Standalone detail page: card always open, no collapsed row */
.bills-card--detail-page {
  border: none;
  background: transparent;
}

.bills-card--detail-page .bills-card__detail {
  max-height: none;
}

/* Title link in collapsed bill row */
.bills-card__title-link {
  color: inherit;
  text-decoration: none;
}

.bills-card__title-link:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Collapsed row: only the title characters are the detail link; rest of cell expands/collapses */
.bills-card__row .bills-card__title-link {
  align-self: flex-start;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
}

.bills-subject-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 0 4px;
  flex: 1;
  min-width: 0;
}

.bills-subject-pill {
  font-size: 11px;
  padding: 3px 10px;
  border-radius: 20px;
  border: 0.5px solid rgba(159, 176, 201, 0.4);
  background: transparent;
  color: rgba(159, 176, 201, 0.9);
  cursor: pointer;
  font: inherit;
}

.bills-subject-pill--active {
  background: rgba(55, 138, 221, 0.15);
  border-color: rgba(55, 138, 221, 0.4);
  color: rgba(133, 183, 235, 0.95);
}

.bills-subject-pill:hover {
  border-color: rgba(159, 176, 201, 0.6);
}

.prism-bill-detail__metadata-strip {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 13px;
  line-height: 1.45;
  color: rgba(200, 210, 225, 1);
}

.prism-bill-detail__metadata-strip-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 4px 8px;
}

.prism-bill-detail__metadata-item {
  display: inline;
}

.prism-bill-detail__metadata-item strong {
  font-weight: 600;
  color: rgba(159, 176, 201, 1);
}

.prism-bill-detail__metadata-sep {
  color: rgba(159, 176, 201, 0.5);
  user-select: none;
}

/* ── bills-app collapsible panels + score bar links ────────────────────── */

.bills-landing-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

@media (max-width: 640px) {
  .bills-landing-two-col {
    grid-template-columns: 1fr;
  }
}

.bills-collapsible-panel {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.03);
}

.bills-collapsible-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.6rem 0.875rem;
  background: rgba(255, 255, 255, 0.05);
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  cursor: pointer;
  color: inherit;
  font: inherit;
  text-align: left;
  transition: background 0.15s;
}

.bills-collapsible-header:hover {
  background: rgba(255, 255, 255, 0.09);
}

.bills-collapsible-title {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.75;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.bills-collapsible-badge {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 1px 6px;
  border-radius: 20px;
  background: rgba(55, 138, 221, 0.25);
  color: #7ec4f8;
  border: 1px solid rgba(55, 138, 221, 0.35);
}

.bills-collapsible-caret {
  font-size: 0.75rem;
  opacity: 0.5;
  transition: transform 0.15s;
}

.bills-collapsible-body {
  padding: 0.75rem;
}

.bills-collapsible-empty {
  font-size: 0.8rem;
  opacity: 0.5;
  margin: 0;
}

.bills-subject-pills--inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  padding: 0;
}

.bills-score-dist__segment--link {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  transition: filter 0.15s, outline 0.1s, box-shadow 0.15s;
  outline: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  box-sizing: border-box;
  min-width: 0;
}

.bills-score-dist__segment--link:hover,
.bills-score-dist__segment--link:focus-visible {
  filter: brightness(1.25);
  outline: 2px solid rgba(255, 255, 255, 0.4);
  outline-offset: -2px;
  z-index: 1;
  position: relative;
}

.bills-score-dist__segment--link.bills-score-dist__segment--selected {
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.85);
  filter: brightness(1.08);
  z-index: 2;
  position: relative;
}

/* Bills topic browse: stacked rows, full-width chips, no inner scroll */
.bills-topic-browse-panel {
  margin-bottom: 1.25rem;
}

.bills-topic-browse-body {
  padding-top: 0.5rem;
}

.bills-topic-browse-hint {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(159, 176, 201, 0.73);
  margin: 0 0 0.75rem;
  max-width: 56rem;
}

.bills-topic-browse-actions {
  margin-bottom: 0.75rem;
}

.bills-topic-clear {
  font-size: 0.875rem;
  padding: 0.4rem 0.85rem;
}

.bills-topic-browse-rows {
  display: flex;
  flex-direction: column;
  gap: 1.35rem;
}

.bills-topic-row {
  padding-bottom: 1.25rem;
  border-bottom: 0.5px solid rgba(159, 176, 201, 0.27);
}

.bills-topic-row:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.bills-topic-col {
  min-width: 0;
  width: 100%;
}

.bills-topic-col__head {
  margin-bottom: 0.65rem;
}

.bills-topic-col__title {
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(200, 210, 225, 1);
}

.bills-topic-col__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.45rem;
  padding: 0;
}

.bills-filter-chip {
  font: inherit;
  font-size: 12px;
  padding: 6px 12px;
  border-radius: 18px;
  border: 0.5px solid rgba(159, 176, 201, 0.43);
  background: transparent;
  color: rgba(210, 218, 232, 1);
  cursor: pointer;
  text-align: left;
  line-height: 1.4;
  transition: border-color 0.15s, background 0.15s;
}

.bills-filter-chip:hover {
  border-color: rgba(159, 176, 201, 0.6);
}

.bills-filter-chip--selected {
  background: rgba(55, 138, 221, 0.18);
  border-color: rgba(55, 138, 221, 0.45);
  color: rgba(180, 210, 245, 0.98);
}

/* ── Bill card collapsed subtitle chips ────────────────────────────── */

/* Override single-line constraint so the title column can hold two lines. */
.bills-card__row > .bills-card__title {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  white-space: normal;
  overflow: hidden;
  text-overflow: clip;
}

/* Main title line — retains ellipsis truncation. */
.bills-card__title-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 14px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
  min-width: 0;
  line-height: 1.3;
}

/* Chip row below the title. */
.bills-card__subtitle {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 5px;
  min-width: 0;
  overflow: hidden;
  padding-bottom: 1px;
}

/* Base chip — small rounded pill. */
.bills-card__chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 500;
  line-height: 1.5;
  padding: 1px 7px;
  border-radius: 999px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 220px;
  flex-shrink: 0;
}

/* Category chip — teal, matches subject-area style. */
.bills-card__chip--cat {
  background: rgba(29, 158, 117, 0.13);
  color: rgba(93, 202, 165, 0.9);
  border: 0.5px solid rgba(29, 158, 117, 0.28);
  max-width: 180px;
}

/* Sponsor chip — muted, with inline party badge. */
.bills-card__chip--sponsor {
  background: transparent;
  color: rgba(159, 176, 201, 0.75);
  max-width: 200px;
}

/* Party badge inside the sponsor chip. */
.bills-card__chip__party {
  font-size: 9px;
  font-weight: 700;
  padding: 0 4px;
  border-radius: 3px;
  line-height: 1.6;
  letter-spacing: 0.03em;
  flex-shrink: 0;
}

.bills-card__chip__party--dem {
  background: rgba(55, 138, 221, 0.22);
  color: rgba(133, 183, 245, 0.95);
}

.bills-card__chip__party--rep {
  background: rgba(216, 90, 48, 0.22);
  color: rgba(240, 145, 115, 0.95);
}

.bills-card__chip__party--ind {
  background: rgba(127, 119, 221, 0.22);
  color: rgba(185, 180, 240, 0.95);
}

/* Text-available indicator chip. */
.bills-card__chip--text {
  background: rgba(79, 140, 255, 0.09);
  color: rgba(120, 170, 240, 0.65);
  border: 0.5px solid rgba(79, 140, 255, 0.22);
}
/* Summary-available indicator chip (amber). */
.bills-card__chip--summary {
  background: rgba(180, 140, 60, 0.09);
  color: rgba(210, 180, 100, 0.7);
  border: 0.5px solid rgba(180, 140, 60, 0.22);
}

/* Prism Analysis paragraph inside Prism Factor panel. */
.bills-card__prism-factor-summary {
  margin: 0.5rem 0;
}
.bills-card__prism-summary-text {
  font-size: 0.88rem;
  line-height: 1.55;
  color: rgba(210, 210, 230, 0.75);
  margin: 0.25rem 0 0;
}

/* ── Member Prism Scores section ────────────────────────────────── */

.member-prism-scores {
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1.25rem 1.25rem 1rem;
}

.member-prism-scores h2 {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.member-prism-scores__icon {
  height: 1.2em;
  width: auto;
  vertical-align: middle;
  opacity: 0.85;
}

.member-scores-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 0.5rem;
}

@media (max-width: 640px) {
  .member-scores-grid {
    grid-template-columns: 1fr;
  }
}

.member-score-item {
  padding: 0.75rem;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border);
}

.member-score-item--pending {
  opacity: 0.5;
}

.member-score-item__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.4rem;
}

.member-score-item__label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text);
}

.member-score-item__value {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
}

.member-score-item__value--na {
  color: var(--muted);
  font-weight: 400;
}

.member-score-item__track {
  height: 8px;
  border-radius: 4px;
  overflow: visible;
  position: relative;
  margin-bottom: 0.35rem;
}

.member-score-item__fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.4s ease;
}

/* Default needle */
.member-score-item__needle {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 3px;
  height: 14px;
  background: rgba(220, 228, 240, 1);
  border-radius: 1px;
}

/* Enhanced Prism needle: white tick with triangle pointer */
.member-score-item__needle--prism {
  top: 0;
  transform: translateX(-50%);
  width: 3px;
  height: 100%;
  background: #fff;
  border-radius: 0;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.5);
}

.member-score-item__needle--prism::before {
  content: "";
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid #fff;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.4));
}

/* Axis labels below Prism bar */
.member-score-item__axis-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.65rem;
  color: var(--muted);
  opacity: 0.55;
  margin-bottom: 0.3rem;
  padding-top: 2px;
}

.member-score-item__caveat {
  display: block;
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.7;
}

.member-score-item__caveat--subtle {
  opacity: 0.55;
  font-style: italic;
  margin-bottom: 0.25rem;
}

/* ── Committee detail page ─────────────────────────────────────────────── */

.committee-detail {
  margin-top: 0.5rem;
}

.committee-detail__meta {
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 2rem;
}

.committee-members-section,
.committee-bills-section,
.committee-subcommittees {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}

.committee-members-table-wrap,
.committee-bills-table-wrap {
  overflow-x: auto;
}

.committee-members-table,
.committee-bills-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.92rem;
}

.committee-members-table th,
.committee-members-table td,
.committee-bills-table th,
.committee-bills-table td {
  padding: 0.5rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.committee-members-table th,
.committee-bills-table th {
  font-weight: 600;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
}

.committee-member-photo-cell {
  width: 36px;
  padding-right: 0;
}

.committee-member-thumb {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  vertical-align: middle;
}

.committee-member-thumb--placeholder {
  display: inline-block;
  background: var(--border);
}

.committee-bill-label {
  white-space: nowrap;
}

.committee-bill-score {
  text-align: center;
}

.committee-bill-action {
  font-size: 0.85rem;
  color: var(--muted);
}

.committee-sub-count {
  color: var(--muted);
  font-size: 0.85rem;
}

.member-committee-role {
  color: var(--muted);
  font-size: 0.9em;
}

/* ── Federal bill text panel (detail + expanded list cards) ─────────────── */
.bills-card__section--bill-text-trigger {
  padding-top: 0.25rem;
}

.bill-text-panel {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 0.5px solid rgba(159, 176, 201, 0.37);
  border-radius: 0 0 8px 8px;
  background: rgba(0, 0, 0, 0.12);
}

.bill-text-panel--open {
  padding-bottom: 0.5rem;
}

.bill-text-panel__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0 0.25rem 0.65rem;
}

.bill-text-panel__heading {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(159, 176, 201, 1);
}

.bill-text-panel__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.bill-text-panel__tool-btn {
  font-size: 0.8rem !important;
  padding: 0.35rem 0.65rem !important;
}

.bill-text-panel__body {
  max-height: min(55vh, 520px);
  overflow: auto;
  margin: 0 0.25rem;
  padding: 0.75rem 0.85rem;
  border-radius: 6px;
  border: 0.5px solid rgba(159, 176, 201, 0.3);
  background: rgba(255, 255, 255, 0.03);
}

.bill-text-panel__text {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: "IBM Plex Sans", "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  font-size: 0.92rem;
  line-height: 1.55;
  color: rgba(220, 228, 240, 1);
}

.bill-text-panel__footer {
  padding: 0.65rem 0.35rem 0.15rem;
  margin: 0 0.25rem;
  border-top: 0.5px solid rgba(159, 176, 201, 0.27);
}

.bill-text-panel__source-link {
  font-size: 0.9rem;
}

.bill-text-panel__loading,
.bill-text-panel__empty,
.bill-text-panel__error {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(159, 176, 201, 1);
}

.bill-text-panel__error {
  color: rgba(248, 113, 113, 0.9);
}

.bill-text-toast {
  position: fixed;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  z-index: 9999;
  padding: 0.55rem 1.1rem;
  border-radius: 8px;
  background: rgba(30, 41, 59, 0.96);
  border: 0.5px solid rgba(55, 138, 221, 0.35);
  color: rgba(220, 228, 240, 1);
  font-size: 0.88rem;
  font-weight: 500;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.25s ease;
}

.bill-text-toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@media print {
  .site-header,
  .site-footer,
  .breadcrumb,
  .skip-link,
  .bill-text-toast {
    display: none !important;
  }

  body {
    background: #fff !important;
    color: #111 !important;
  }

  main.container {
    max-width: none !important;
    padding: 0.5rem 1rem !important;
  }

  .bills-card--detail-page .bills-card__section--bill-text-trigger,
  .bills-card--detail-page .bills-card__prism-row,
  .bills-card--detail-page .bill-text-panel__toolbar,
  .bills-card--detail-page .bill-text-panel__footer {
    display: none !important;
  }

  .bills-card--detail-page .bill-text-panel {
    border: none !important;
    background: transparent !important;
    margin-top: 0.75rem !important;
    padding: 0 !important;
  }

  .bills-card--detail-page .bill-text-panel[hidden] {
    display: none !important;
  }

  .bills-card--detail-page .bill-text-panel__body {
    max-height: none !important;
    overflow: visible !important;
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .bills-card--detail-page .bill-text-panel__text {
    color: #111 !important;
    font-size: 0.82rem !important;
    line-height: 1.45 !important;
  }

  .bills-card--detail-page .bills-card__detail-inner {
    padding: 0 !important;
  }

  .bills-card--detail-page {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  .bills-card--detail-page .bills-card__full-title,
  .bills-card--detail-page .bills-card__detail-designation,
  .bills-card--detail-page .bills-card__section-label,
  .bills-card--detail-page .bills-card__meta-value,
  .bills-card--detail-page .bills-card__meta-date,
  .bills-card--detail-page .bills-card__summary {
    color: #111 !important;
  }
}

/* =====================================================================
   Legislators App
   ===================================================================== */

.legislators-app__intro {
  max-width: 52rem;
}

/* Level toggle (Federal / State / Territory) */
.legislators-app-level {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.65rem;
}

.legislators-app-level__label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pp-muted, #6b7a8f);
}

.legislators-app-level__pills {
  display: flex;
  gap: 0;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(100, 120, 150, 0.35);
}

.legislators-app-level__pill {
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  padding: 0.35rem 0.75rem;
  border: none;
  background: rgba(12, 16, 24, 0.55);
  color: var(--pp-muted, #6b7a8f);
  cursor: pointer;
  border-right: 1px solid rgba(100, 120, 150, 0.35);
}

.legislators-app-level__pill:last-child {
  border-right: none;
}

.legislators-app-level__pill--active {
  background: rgba(55, 138, 221, 0.2);
  color: rgba(133, 183, 235, 0.98);
}

/* Filter row — reuses bills-app patterns */
.legislators-app-filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(100, 120, 150, 0.2);
}

.legislators-app-filter-row__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: min(100%, 10.5rem);
  flex: 1 1 auto;
}

.legislators-app-filter-row__field--search {
  flex: 2 1 16rem;
  min-width: min(100%, 16rem);
}

.legislators-app-filter-row__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--pp-muted, #6b7a8f);
}

.legislators-app-filter-row__select,
.legislators-app-filter-row__input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 0.45rem 0.55rem;
  border-radius: 6px;
  border: 1px solid rgba(100, 120, 150, 0.35);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
  font-size: 0.875rem;
}

/* Party pills inline (All / D / R / I) */
.legislators-party-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.legislators-party-pill {
  font: inherit;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3rem 0.65rem;
  border-radius: 20px;
  border: 0.5px solid rgba(159, 176, 201, 0.45);
  background: transparent;
  color: rgba(159, 176, 201, 0.85);
  cursor: pointer;
}

.legislators-party-pill--active {
  border-color: rgba(133, 183, 235, 0.6);
  background: rgba(55, 138, 221, 0.15);
  color: rgba(133, 183, 235, 0.98);
}

.legislators-party-pill--dem.legislators-party-pill--active {
  border-color: rgba(50, 120, 220, 0.5);
  background: rgba(50, 120, 220, 0.15);
  color: #5ba0e8;
}

.legislators-party-pill--rep.legislators-party-pill--active {
  border-color: rgba(220, 60, 60, 0.5);
  background: rgba(220, 60, 60, 0.12);
  color: #e06060;
}

.legislators-party-pill--ind.legislators-party-pill--active {
  border-color: rgba(140, 100, 220, 0.5);
  background: rgba(140, 100, 220, 0.12);
  color: #b090e0;
}

/* Status line */
.legislators-app-status {
  min-height: 1.15rem;
  font-size: 13px;
  color: var(--muted);
  margin: 0 0 0.35rem;
  text-align: left;
}

.legislators-app-error {
  color: rgba(235, 120, 120, 0.9);
}

/* Results list */
.legislators-app-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Legislator card */
.legislator-card {
  background: rgba(255, 255, 255, 0.03);
  border: 0.5px solid rgba(159, 176, 201, 0.33);
  border-radius: 8px;
  margin-bottom: 6px;
  transition: border-color 0.15s;
}

.legislator-card:hover {
  border-color: rgba(159, 176, 201, 0.5);
}

/* Collapsed row: photo | name+party | state | scores | chevron */
.legislator-card__row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 110px minmax(180px, auto) 36px;
  column-gap: 0;
  align-items: stretch;
  padding: 0 12px 0 0;
  min-height: 54px;
  cursor: pointer;
  user-select: none;
}

.legislator-card__row > .legislator-card__photo {
  padding: 6px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.legislator-card__photo-img {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  object-fit: cover;
  background: rgba(159, 176, 201, 0.15);
}

.legislator-card__photo-placeholder {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(159, 176, 201, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(159, 176, 201, 0.5);
}

.legislator-card__photo-placeholder svg {
  width: 22px;
  height: 22px;
}

.legislator-card__row > .legislator-card__identity {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 8px 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.legislator-card__name {
  font-size: 14px;
  font-weight: 500;
  color: rgba(220, 228, 240, 1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.legislator-card__party-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 0.05rem 0.4rem;
  border-radius: 4px;
  margin-left: 0.35rem;
  vertical-align: middle;
}

.legislator-card__party-badge--dem {
  background: rgba(50, 120, 220, 0.18);
  color: #5ba0e8;
}

.legislator-card__party-badge--rep {
  background: rgba(220, 60, 60, 0.15);
  color: #e06060;
}

.legislator-card__party-badge--ind {
  background: rgba(140, 100, 220, 0.15);
  color: #b090e0;
}

.legislator-card__subtitle {
  font-size: 11.5px;
  color: rgba(159, 176, 201, 0.85);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}

.legislator-card__row > .legislator-card__state {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 8px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 500;
  color: rgba(159, 176, 201, 0.93);
  text-align: center;
}

/* Prism Factors mini scores in collapsed row */
.legislator-card__row > .legislator-card__scores {
  border-right: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 6px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.legislator-card__score-dot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  min-width: 32px;
}

.legislator-card__score-dot-label {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(159, 176, 201, 0.65);
}

.legislator-card__score-dot-value {
  font-size: 13px;
  font-weight: 600;
  color: rgba(220, 228, 240, 0.95);
}

.legislator-card__score-dot-value--na {
  font-size: 11px;
  color: rgba(159, 176, 201, 0.4);
}

/* Chevron */
.legislator-card__row > .legislator-card__chev {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(200, 215, 235, 0.85);
  user-select: none;
}

/* Expanded detail */
.legislator-card__detail {
  display: none;
  border-top: 0.5px solid rgba(159, 176, 201, 0.33);
  padding: 1rem 1.25rem 1.25rem;
}

.legislator-card--expanded .legislator-card__detail {
  display: block;
}

.legislator-card__detail-header {
  display: flex;
  gap: 1.25rem;
  margin-bottom: 1rem;
}

.legislator-card__detail-photo {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: rgba(159, 176, 201, 0.12);
}

.legislator-card__detail-info {
  flex: 1;
  min-width: 0;
}

.legislator-card__detail-name {
  font-size: 1.15rem;
  font-weight: 600;
  color: rgba(220, 228, 240, 1);
  margin: 0 0 0.25rem;
}

.legislator-card__detail-title {
  font-size: 0.875rem;
  color: rgba(159, 176, 201, 0.9);
  margin: 0 0 0.5rem;
}

.legislator-card__detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  font-size: 0.8125rem;
  color: rgba(159, 176, 201, 0.8);
}

/* Prism Factors section */
.prism-factors {
  margin-bottom: 1rem;
}

.prism-factors__title {
  font-size: 0.8125rem;
  font-weight: 600;
  color: rgba(159, 176, 201, 0.75);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 0.65rem;
}

.prism-factors__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.75rem;
}

.prism-factor-card {
  padding: 0.75rem;
  border-radius: 8px;
  border: 0.5px solid rgba(159, 176, 201, 0.25);
  background: rgba(255, 255, 255, 0.02);
}

.prism-factor-card__label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(159, 176, 201, 0.7);
  margin-bottom: 0.35rem;
}

.prism-factor-card__value {
  font-size: 1.25rem;
  font-weight: 700;
  color: rgba(220, 228, 240, 0.95);
  margin-bottom: 0.3rem;
}

.prism-factor-card__bar {
  height: 5px;
  border-radius: 3px;
  background: rgba(159, 176, 201, 0.15);
  overflow: hidden;
}

.prism-factor-card__bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s ease;
}

.prism-factor-card__bar-fill--prism { background: rgba(55, 138, 221, 0.7); }
.prism-factor-card__bar-fill--effectiveness { background: rgba(29, 158, 117, 0.7); }
.prism-factor-card__bar-fill--bipartisan { background: rgba(186, 117, 23, 0.7); }
.prism-factor-card__bar-fill--donor { background: rgba(140, 100, 220, 0.7); }

.prism-factor-card__sub {
  font-size: 0.6875rem;
  color: rgba(159, 176, 201, 0.6);
  margin-top: 0.25rem;
}

.prism-factor-card--na .prism-factor-card__value {
  font-size: 0.875rem;
  color: rgba(159, 176, 201, 0.4);
}

/* Detail sections (committees, bills, contact) */
.legislator-card__section {
  margin-bottom: 0.85rem;
}

.legislator-card__section-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgba(159, 176, 201, 0.7);
  margin-bottom: 0.4rem;
}

.legislator-card__committees {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.legislator-card__committee-chip {
  font-size: 11.5px;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(55, 138, 221, 0.12);
  color: rgba(133, 183, 235, 0.9);
}

.legislator-card__bills-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.legislator-card__bills-list li {
  font-size: 0.8125rem;
  padding: 0.25rem 0;
  border-bottom: 0.5px solid rgba(159, 176, 201, 0.12);
  color: rgba(220, 228, 240, 0.9);
}

.legislator-card__bills-list li a {
  color: rgba(133, 183, 235, 0.9);
  text-decoration: none;
}

.legislator-card__bills-list li a:hover {
  text-decoration: underline;
}

/* Profile link */
.legislator-card__profile-link {
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(133, 183, 235, 0.9);
  text-decoration: none;
  margin-top: 0.5rem;
}

.legislator-card__profile-link:hover {
  text-decoration: underline;
}

/* Pagination — same as bills */
.legislators-app-pagination {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.25rem 0 2rem;
  justify-content: center;
}

.legislators-app-pagination button {
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  border: 0.5px solid rgba(55, 138, 221, 0.45);
  background: rgba(55, 138, 221, 0.2);
  color: rgba(133, 183, 235, 0.98);
  cursor: pointer;
}

.legislators-app-pagination button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.legislators-app-pagination__status {
  font-size: 13px;
  color: var(--muted);
}

/* Landing stats */
.legislators-landing-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.legislators-landing-stat {
  padding: 0.85rem;
  border-radius: 8px;
  border: 0.5px solid rgba(159, 176, 201, 0.2);
  background: rgba(255, 255, 255, 0.02);
  text-align: center;
}

.legislators-landing-stat__value {
  font-size: 1.5rem;
  font-weight: 700;
  color: rgba(220, 228, 240, 0.95);
}

.legislators-landing-stat__label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(159, 176, 201, 0.7);
  margin-top: 0.2rem;
}

/* Score distribution histogram */
.legislators-score-histogram {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 60px;
  margin-bottom: 0.5rem;
}

.legislators-score-histogram__bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  min-height: 2px;
  cursor: pointer;
  transition: opacity 0.15s;
}

.legislators-score-histogram__bar:hover {
  opacity: 0.8;
}

.legislators-score-histogram__bar--vc { background: rgba(30, 80, 180, 0.7); }
.legislators-score-histogram__bar--c { background: rgba(60, 120, 200, 0.6); }
.legislators-score-histogram__bar--m { background: rgba(140, 140, 160, 0.5); }
.legislators-score-histogram__bar--l { background: rgba(200, 80, 80, 0.5); }
.legislators-score-histogram__bar--vl { background: rgba(180, 40, 40, 0.6); }

.legislators-score-histogram__labels {
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: rgba(159, 176, 201, 0.5);
}

/* Sort bar */
.legislators-app-sort-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 0.8125rem;
  color: var(--pp-muted, #6b7a8f);
}

.legislators-app-sort-bar select {
  font: inherit;
  font-size: 0.8125rem;
  padding: 0.25rem 0.4rem;
  border-radius: 4px;
  border: 1px solid rgba(100, 120, 150, 0.3);
  background: rgba(12, 16, 24, 0.55);
  color: inherit;
}

/* Responsive */
@media (max-width: 720px) {
  .legislator-card__row {
    grid-template-columns: 48px minmax(0, 1fr) 36px;
  }

  .legislator-card__row > .legislator-card__state,
  .legislator-card__row > .legislator-card__scores {
    display: none;
  }

  .legislator-card__detail-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .prism-factors__grid {
    grid-template-columns: 1fr 1fr;
  }

  .legislators-landing-stats {
    grid-template-columns: 1fr 1fr;
  }
}
