:root {
  --color-bg: #fafaf7;
  --color-surface: #ffffff;
  --color-text: #1a1a1a;
  --color-text-secondary: #5a5a5a;
  --color-border: #e5e5e0;
  --color-accent: #1b4d6e;
  --color-accent-hover: #153d58;
  --color-for: #2e7d32;
  --color-imod: #c62828;
  --color-fravaer: #9e9e9e;
  --font-heading: "Source Serif 4", "Georgia", serif;
  --font-body: "DM Sans", "Helvetica Neue", sans-serif;
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.5rem;
  --text-2xl: 2rem;
  --text-3xl: 2.75rem;
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --transition-fast: 150ms ease;
  --transition-default: 250ms ease;
}

* {
  box-sizing: border-box;
}

html {
  color-scheme: light;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --color-bg: #10161c;
  --color-surface: #171f27;
  --color-text: #f3efe6;
  --color-text-secondary: #b8c0ca;
  --color-border: #30404f;
  --color-accent: #8fb4d1;
  --color-accent-hover: #b0cbdf;
  --color-for: #78b882;
  --color-imod: #e07777;
  --color-fravaer: #98a0a8;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.5;
}

html[data-theme="dark"] body {
  background:
    linear-gradient(180deg, rgba(143, 180, 209, 0.08) 0%, rgba(143, 180, 209, 0) 220px),
    linear-gradient(180deg, #0e141a 0%, #10161c 100%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select {
  font: inherit;
  color: inherit;
}

button {
  background: none;
}

h1,
h2,
h3,
p,
dl,
dd,
dt,
ul,
ol {
  margin: 0;
}

img {
  display: block;
  max-width: 100%;
}

.hidden {
  display: none !important;
}

.site-shell {
  width: min(1480px, calc(100vw - 3rem));
  margin: 0 auto;
  padding: var(--space-md) 0 var(--space-xl);
}

.site-header,
.hero-panel,
.page-intro,
.toolbar-panel,
.content-section,
.panel,
.profile-hero,
.metric-strip,
.profile-empty,
.summary-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
}

.site-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-lg);
  align-items: center;
  padding: var(--space-md);
}

.site-brand-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.site-brand {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  color: var(--color-accent);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-header-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  min-width: 0;
}

.site-header-tools {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-md);
  margin-left: auto;
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-lg);
  min-width: 0;
}

.site-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  line-height: 1;
  color: var(--color-text-secondary);
  transition: color var(--transition-fast);
}

.site-nav a::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -0.2rem;
  left: 0;
  height: 2px;
  background: transparent;
  transition: background var(--transition-fast);
}

.site-nav a:hover,
.site-nav a:focus-visible {
  color: var(--color-text);
}

.site-nav a[aria-current="page"] {
  color: var(--color-accent);
}

.site-nav a[aria-current="page"]::after {
  background: var(--color-accent);
}

.site-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 20px;
  border: 2px solid var(--color-accent);
  color: var(--color-accent);
  border-radius: 2px;
  cursor: pointer;
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: auto;
  min-width: auto;
  padding: 0;
  border: none;
  border-radius: 0;
  color: var(--color-accent);
  background: transparent;
  cursor: pointer;
  transition: color var(--transition-fast), opacity var(--transition-fast);
}

.theme-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2rem;
  height: 1.2rem;
  font-size: 1.2rem;
  line-height: 1;
}

.theme-toggle[data-theme="light"] .theme-toggle-icon::before {
  content: "☾";
}

.theme-toggle[data-theme="dark"] .theme-toggle-icon::before {
  content: "☀";
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
  color: var(--color-accent-hover);
  opacity: 1;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-stats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.site-stats strong {
  color: var(--color-text);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.site-stats-dot {
  width: 1px;
  height: 0.9rem;
  background: var(--color-border);
}

.eyebrow,
.field-label,
.toolbar-summary,
.signal-label,
.mini-metric-label,
.metric-card span:first-child,
.panel-heading .eyebrow,
.breadcrumb,
.vote-signal-card span,
.table-metric span {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.eyebrow,
.field-label,
.signal-label {
  color: var(--color-accent);
}

.button-link,
.table-link,
.member-card-link,
.vote-row-action,
.voter-row-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 20px;
  border-radius: 2px;
  border: 2px solid var(--color-accent);
  background: var(--color-accent);
  color: var(--color-bg);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.button-link:hover,
.button-link:focus-visible,
.table-link:hover,
.table-link:focus-visible,
.vote-row-action:hover,
.vote-row-action:focus-visible,
.voter-row-link:hover,
.voter-row-link:focus-visible {
  background: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
}

.button-link-secondary,
.table-link,
.vote-row-action,
.voter-row-link {
  background: transparent;
  color: var(--color-accent);
}

.button-link-secondary:hover,
.button-link-secondary:focus-visible,
.table-link:hover,
.table-link:focus-visible,
.vote-row-action:hover,
.vote-row-action:focus-visible,
.voter-row-link:hover,
.voter-row-link:focus-visible {
  background: var(--color-accent);
  color: var(--color-bg);
}

.home-layout,
.discover-layout,
.profile-layout,
.parties-layout,
.votes-layout {
  display: grid;
  gap: var(--space-lg);
  margin-top: var(--space-lg);
}

.hero-panel,
.page-intro,
.toolbar-panel,
.content-section,
.panel,
.profile-hero,
.metric-strip,
.profile-empty {
  padding: var(--space-lg);
}

.hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
  gap: var(--space-lg);
}

.hero-copy,
.page-intro,
.section-heading,
.toolbar-copy,
.profile-title-block,
.vote-detail-copy,
.profile-empty {
  display: grid;
  gap: var(--space-sm);
}

.hero-copy h1,
.page-intro h1,
.section-heading h2,
.profile-title-block h1,
.vote-detail-copy h2,
.profile-empty h1 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.05;
}

.hero-copy h1 {
  font-size: clamp(2.25rem, 5vw, var(--text-3xl));
  max-width: 13ch;
}

.page-intro h1,
.section-heading h2,
.profile-title-block h1 {
  font-size: clamp(1.8rem, 3vw, var(--text-2xl));
}

.hero-lead,
.page-intro p,
.signal-card p,
.info-card p,
.step-card p,
.definition-card p,
.summary-card p,
.toolbar-copy p,
.profile-summary,
.vote-row-body p,
.vote-detail-meta,
.vote-signal-card p,
.table-note,
.voter-row-party,
.member-meta-text,
.member-role,
.profile-role,
.photo-credit {
  color: var(--color-text-secondary);
}

.page-intro p,
.toolbar-copy p,
.table-note,
.footer-note,
.profile-summary,
.vote-detail-meta {
  max-width: 68ch;
}

.vote-resume {
  margin-top: var(--space-sm);
  max-width: 68ch;
}

.vote-resume summary {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  color: var(--color-accent);
  list-style: none;
  user-select: none;
}

.vote-resume summary::-webkit-details-marker {
  display: none;
}

.vote-resume summary::before {
  content: "▸";
  display: inline-block;
  transition: transform 0.15s ease;
}

.vote-resume[open] summary::before {
  transform: rotate(90deg);
}

.vote-resume p {
  margin-top: var(--space-sm);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.65;
}

.hero-actions,
.member-badges,
.context-tag-row,
.committee-tags,
.party-overview-meta,
.vote-list-counts,
.vote-list-signals,
.hero-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.hero-metrics {
  display: grid;
}

.page-home .hero-metrics {
  gap: 0;
}

.page-home .hero-metrics .signal-card {
  padding: var(--space-md) 0;
  border: none;
  border-top: 1px solid var(--color-border);
  background: transparent;
}

.page-home .hero-metrics .signal-card:first-child {
  padding-top: 0;
  border-top: none;
}

.page-home .hero-metrics .signal-card:last-child {
  padding-bottom: 0;
}

.signal-card,
.info-card,
.step-card,
.definition-card,
.summary-card,
.vote-signal-card,
.vote-list-panel {
  display: grid;
  gap: var(--space-sm);
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.signal-card strong,
.summary-card strong,
.vote-signal-card strong,
.metric-card strong,
.mini-metric strong {
  font-variant-numeric: tabular-nums;
}

.signal-card strong,
.summary-card strong,
.vote-signal-card strong {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
}

.content-section {
  display: grid;
  gap: var(--space-lg);
}

.content-section-cta {
  justify-items: start;
}

.info-grid,
.step-grid,
.definition-grid,
.party-summary-strip {
  display: grid;
  gap: var(--space-md);
}

.info-grid,
.party-summary-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.step-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.step-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--color-border);
  color: var(--color-accent);
  border-radius: 2px;
}

.definition-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.civics-process-list,
.civics-definition-list,
.civics-source-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.page-civics .content-section {
  gap: var(--space-md);
}

.page-civics .civics-process-list {
  display: grid;
  gap: 0;
}

.page-civics .civics-process-item {
  display: grid;
  grid-template-columns: 2rem minmax(0, 1fr);
  gap: var(--space-lg);
  align-items: start;
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-border);
}

.page-civics .civics-process-item:first-child {
  padding-top: 0;
  border-top: none;
}

.page-civics .civics-process-step {
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 700;
  line-height: 1;
}

.page-civics .civics-process-copy,
.page-civics .civics-definition-item,
.page-civics .civics-context-item,
.page-civics .civics-source-group {
  display: grid;
  gap: var(--space-sm);
}

.page-civics .civics-process-copy h3,
.page-civics .civics-definition-item dt,
.page-civics .civics-context-item h3,
.page-civics .civics-source-group h3 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 700;
}

.page-civics .civics-definition-item dd {
  margin: 0;
}

.page-civics .civics-definition-list,
.page-civics .civics-context-list,
.page-civics .civics-source-columns {
  display: grid;
  gap: 0 var(--space-xl);
}

.page-civics .civics-definition-list,
.page-civics .civics-source-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.page-civics .civics-context-list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.page-civics .civics-definition-item,
.page-civics .civics-context-item,
.page-civics .civics-source-group {
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-border);
}

.page-civics .civics-definition-item:nth-child(-n + 2),
.page-civics .civics-source-group:nth-child(-n + 2) {
  padding-top: 0;
  border-top: none;
}

.page-civics .civics-context-item:nth-child(-n + 3) {
  padding-top: 0;
  border-top: none;
}

.page-civics .civics-source-list {
  display: grid;
  gap: 0;
}

.page-civics .civics-source-list li {
  padding: var(--space-sm) 0;
  border-top: 1px solid var(--color-border);
}

.page-civics .civics-source-list li:first-child {
  padding-top: 0;
  border-top: none;
}

.page-civics .civics-source-link {
  color: var(--color-accent);
  font-weight: 600;
}

.page-civics .civics-source-link:hover,
.page-civics .civics-source-link:focus-visible {
  color: var(--color-accent-hover);
}

.discover-toolbar-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-md);
  align-items: start;
}

.filters-toggle {
  display: none;
}

.filters-panel-head {
  display: none;
}

.toolbar-panel {
  display: grid;
  gap: var(--space-md);
}

.toolbar-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) repeat(4, minmax(0, 1fr));
  gap: var(--space-md);
  align-items: end;
}

.field {
  display: grid;
  gap: var(--space-xs);
}

.field input,
.field select {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  background: var(--color-surface);
  color: var(--color-text);
}

.field input:focus,
.field select:focus {
  outline: 2px solid rgba(27, 77, 110, 0.16);
  outline-offset: 1px;
}

.toolbar-summary {
  color: var(--color-text-secondary);
}

.active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.active-filter {
  padding: 2px 8px;
  border: 1px solid var(--color-border);
  border-radius: 2px;
  background: transparent;
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
}

.discover-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-md);
}

.member-card {
  position: relative;
  display: grid;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
}

.member-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--color-border);
}

.member-card-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-md);
  align-items: start;
}

.member-avatar-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
}

.profile-avatar-wrap {
  display: grid;
  gap: var(--space-sm);
  align-content: start;
  justify-items: center;
}

.profile-avatar-frame {
  display: flex;
  align-items: center;
  justify-content: center;
}

.member-photo,
.member-initials {
  width: 72px;
  height: 72px;
}

.profile-photo,
.profile-initials {
  width: 128px;
  height: 128px;
}

.member-photo,
.profile-photo,
.member-initials,
.profile-initials {
  border-radius: 50%;
  border: 1px solid var(--color-border);
}

.member-initials,
.profile-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface);
  color: var(--color-accent);
  text-align: center;
  font-weight: 700;
  line-height: 1;
}

.profile-avatar-wrap .photo-credit {
  max-width: 16ch;
  font-size: var(--text-xs);
  line-height: 1.45;
  text-align: center;
}

.member-headline,
.voter-row-copy,
.vote-row-body,
.vote-row-meta {
  display: grid;
  gap: var(--space-xs);
  min-width: 0;
}

.member-card h2,
.party-name-text,
.timeline-body strong,
.voter-row-copy strong,
.vote-row-body h3 {
  font-family: var(--font-heading);
  font-weight: 700;
}

.member-card h2,
.vote-row-body h3,
.voter-row-copy strong {
  font-size: var(--text-lg);
  line-height: 1.3;
}

.member-card-title-link {
  position: static;
  color: inherit;
}

.member-card-title-link::after {
  content: "";
  position: absolute;
  inset: 0;
}

.member-card-title-link:focus-visible {
  outline: none;
}

.member-card-link {
  position: relative;
  z-index: 0;
  margin-left: auto;
  min-height: auto;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--color-accent);
}

.party-pill,
.context-tag,
.vote-chip,
.vote-flag,
.party-code-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border: 1px solid currentColor;
  border-radius: 2px;
  background: transparent;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.context-tag-minister {
  color: var(--color-accent);
}

.context-tag-newcomer,
.context-tag-north-atlantic {
  color: var(--color-text-secondary);
}

.member-metrics,
.metric-strip,
.vote-signal-strip,
.vote-lists-grid {
  display: grid;
  gap: var(--space-md);
}

.member-metrics {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.metric-strip {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.mini-metric,
.metric-card,
.vote-distribution,
.vote-list-item,
.voter-row,
.vote-row,
.committee-tag,
.toggle-check,
.table-metric {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.mini-metric,
.metric-card,
.vote-signal-card,
.distribution-stat,
.voter-row,
.vote-list-item,
.vote-row,
.vote-list-panel {
  padding: var(--space-md);
}

.mini-metric,
.metric-card,
.table-metric {
  display: grid;
  gap: var(--space-xs);
}

.mini-metric strong,
.metric-card strong {
  font-size: var(--text-xl);
}

.page-discover .member-metrics {
  gap: 0;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.page-discover .mini-metric {
  padding: 0 var(--space-md);
  border: none;
  border-left: 1px solid var(--color-border);
  background: transparent;
}

.page-discover .mini-metric:first-child {
  padding-left: 0;
  border-left: none;
}

.page-discover .member-card-footer {
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}

.member-card-footer,
.vote-list-item-top,
.vote-list-item-footer,
.vote-detail-head,
.votes-toolbar,
.voter-row,
.voter-row-main,
.party-overview {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.member-card-footer,
.vote-list-item-top,
.vote-list-item-footer,
.vote-detail-head,
.votes-toolbar,
.voter-row {
  align-items: center;
  justify-content: space-between;
}

.profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-lg);
}

.profile-hero-main,
.profile-title-block,
.profile-hero-actions,
.vote-detail-content,
.votes-browser-controls,
.votes-filter-toggles,
.panel,
.profile-section-grid,
.detail-columns,
.timeline-list,
.vote-feed,
.vote-browser-list,
.voter-list {
  display: grid;
  gap: var(--space-md);
}

.profile-identity {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-lg);
  align-items: start;
}

.profile-hero-actions {
  justify-items: start;
  align-content: start;
}

.profile-stat-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.key-stat {
  display: grid;
  gap: var(--space-xs);
  padding: 0 var(--space-md);
  border-left: 1px solid var(--color-border);
}

.key-stat:first-child {
  padding-left: 0;
  border-left: none;
}

.key-stat__label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
}

.key-stat__value {
  margin: 0;
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-text);
}

.context-note {
  display: grid;
  gap: var(--space-sm);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.context-note-emphasis {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

.profile-section-grid,
.detail-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.panel-heading,
.panel-heading-inline > div {
  display: grid;
  gap: var(--space-xs);
}

.panel-heading-inline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-md);
  align-items: end;
}

.fact-list {
  display: grid;
  gap: var(--space-sm);
}

.fact-row {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: var(--space-md);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}

.fact-row dt {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.fact-row dd a {
  color: var(--color-accent);
}

.detail-list,
.timeline-list,
.committee-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.page-profile .detail-list,
.page-profile .timeline-list,
.committee-list {
  display: grid;
  gap: 0;
}

.page-profile .detail-list li,
.page-profile .timeline-item,
.committee-list-item {
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-border);
  background: transparent;
}

.page-profile .detail-list li:first-child,
.page-profile .timeline-item:first-child {
  padding-top: 0;
  border-top: none;
}

.timeline-item {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: var(--space-md);
}

.timeline-meta {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.committee-tags {
  gap: var(--space-sm);
}

.committee-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 var(--space-lg);
}

.committee-list-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-sm);
  align-items: start;
}

.committee-list-link {
  color: var(--color-text);
  font-weight: 600;
}

.committee-list-link:hover,
.committee-list-link:focus-visible {
  color: var(--color-accent);
}

.committee-list-meta {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.committee-tag {
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 2px;
  color: var(--color-text-secondary);
}

.committee-tag:hover,
.committee-tag:focus-visible {
  color: var(--color-accent);
  border-color: var(--color-accent);
}

.vote-feed,
.vote-browser-list,
.voter-list {
  max-height: 34rem;
  overflow-y: auto;
}

.vote-row {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) auto auto;
  gap: var(--space-md);
  align-items: start;
}

.vote-link {
  color: var(--color-accent);
  font-weight: 600;
}

.vote-row-action {
  min-height: auto;
  padding: 6px 12px;
}

.page-profile .vote-feed {
  max-height: none;
}

.page-profile .vote-row {
  padding: var(--space-md) 0;
  border: none;
  border-top: 1px solid var(--color-border);
  background: transparent;
}

.page-profile .vote-row:first-child {
  padding-top: 0;
  border-top: none;
}

.page-profile .vote-row-action {
  padding: 0;
  border: none;
  background: transparent;
  color: var(--color-accent);
}

.page-profile .vote-row-action:hover,
.page-profile .vote-row-action:focus-visible {
  border: none;
  background: transparent;
  color: var(--color-accent-hover);
}

.page-profile .vote-chip {
  padding: 0;
  border: none;
  background: transparent;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  color: var(--color-text-secondary);
}

.votes-shell {
  display: grid;
  grid-template-columns: minmax(340px, 0.85fr) minmax(0, 1.35fr);
  gap: var(--space-lg);
  align-items: start;
}

.profile-section-grid[data-single="true"] {
  grid-template-columns: 1fr;
}

.votes-browser {
  position: sticky;
  top: var(--space-md);
}

.toggle-check {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-height: 44px;
  padding: 10px 12px;
}

.toggle-check input {
  margin: 0;
}

.vote-list-item {
  width: 100%;
  text-align: left;
  cursor: pointer;
}

.vote-list-item.active {
  border-left: 3px solid var(--color-accent);
  padding-left: calc(var(--space-md) - 2px);
}

.vote-distribution,
.vote-list-panel {
  display: grid;
  gap: var(--space-md);
}

.page-votes .vote-browser-list,
.page-votes .voter-list {
  gap: 0;
}

.page-votes .vote-list-item {
  padding: var(--space-md) 0;
  border: none;
  border-top: 1px solid var(--color-border);
  background: transparent;
}

.page-votes .vote-list-item:first-child {
  padding-top: 0;
  border-top: none;
}

.page-votes .vote-list-item.active {
  padding-left: var(--space-sm);
  border-left: 3px solid var(--color-accent);
  border-top-color: var(--color-border);
  background: transparent;
}

.page-votes .vote-list-item-top,
.page-votes .vote-list-item-footer {
  justify-content: flex-start;
}

.page-votes .vote-list-item-footer {
  gap: var(--space-md);
}

.vote-count-item {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.page-votes .vote-signal-strip {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.page-votes .vote-signal-card {
  padding: 0 var(--space-md);
  border: none;
  border-left: 1px solid var(--color-border);
  background: transparent;
}

.page-votes .vote-signal-card:first-child {
  padding-left: 0;
  border-left: none;
}

.page-votes .vote-distribution {
  padding: 0;
  border: none;
  background: transparent;
}

.page-votes .vote-distribution-legend {
  gap: 0 var(--space-lg);
}

.page-votes .distribution-stat {
  padding: var(--space-sm) 0;
  border-top: 1px solid var(--color-border);
}

.page-votes .distribution-stat:nth-child(-n + 2) {
  padding-top: 0;
  border-top: none;
}

.page-votes .vote-list-panel {
  padding: 0;
  border: none;
  background: transparent;
}

.page-votes .voter-row {
  padding: var(--space-md) 0;
  border: none;
  border-top: 1px solid var(--color-border);
  background: transparent;
}

.page-votes .voter-row:first-child {
  padding-top: 0;
  border-top: none;
}

.vote-distribution-bar {
  display: flex;
  height: 16px;
  overflow: hidden;
  background: var(--color-border);
}

.vote-distribution-segment {
  min-width: 0;
  transition: width var(--transition-default);
}

.vote-distribution-for {
  background: var(--color-for);
}

.vote-distribution-against {
  background: var(--color-imod);
}

.vote-distribution-absent {
  background: var(--color-fravaer);
}

.vote-distribution-neither {
  background: var(--color-accent);
}

.vote-distribution-legend {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-md) var(--space-lg);
}

.distribution-stat {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: var(--space-sm);
  padding: 0;
  border: none;
  background: transparent;
}

.distribution-stat [data-share] {
  color: var(--color-text-secondary);
}

.distribution-swatch {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  background: var(--color-border);
}

.distribution-stat[data-distribution="for"] .distribution-swatch {
  background: var(--color-for);
}

.distribution-stat[data-distribution="imod"] .distribution-swatch {
  background: var(--color-imod);
}

.distribution-stat[data-distribution="fravaer"] .distribution-swatch {
  background: var(--color-fravaer);
}

.distribution-stat[data-distribution="hverken"] .distribution-swatch {
  background: var(--color-accent);
}

.field-inline {
  min-width: 240px;
}

.voter-row {
  justify-content: space-between;
}

.voter-row-main {
  align-items: center;
}

.party-overview {
  flex-direction: column;
  align-items: flex-start;
}

.party-name-text {
  font-size: var(--text-base);
}

.party-table-wrap {
  overflow-x: auto;
}

.party-table {
  width: 100%;
  border-collapse: collapse;
}

.party-table th,
.party-table td {
  padding: var(--space-md) var(--space-sm);
  border-bottom: 1px solid var(--color-border);
  text-align: left;
  vertical-align: top;
}

.party-table th {
  color: var(--color-text-secondary);
  border-bottom: 2px solid var(--color-text);
}

.party-table-number {
  font-variant-numeric: tabular-nums;
}

.table-metric strong {
  font-size: var(--text-base);
}

.table-metric span {
  color: var(--color-text-secondary);
}

.panel-empty,
.empty-state {
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  background: var(--color-surface);
}

.interest-block {
  display: grid;
  gap: var(--space-sm);
}

.interest-block + .interest-block {
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.cvr-relation-item {
  display: grid;
  gap: var(--space-xs);
}

.cvr-relation-link {
  color: var(--color-text);
  font-weight: 600;
}

.cvr-relation-link:hover,
.cvr-relation-link:focus-visible {
  color: var(--color-accent);
}

.cvr-relation-meta {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.panel-source-note {
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.panel-source-note a {
  color: var(--color-accent);
}

.site-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  margin-top: var(--space-2xl);
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-border);
}

.footer-note {
  color: var(--color-text-secondary);
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.footer-links a {
  color: var(--color-accent);
  font-size: var(--text-sm);
}

.footer-links a:hover,
.footer-links a:focus-visible {
  color: var(--color-accent-hover);
}

.tooltip-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.tooltip-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.3rem;
  min-width: 1rem;
  min-height: 1rem;
  color: var(--color-text-secondary);
  font-size: 1rem;
  line-height: 1;
  cursor: help;
}

.tooltip-body {
  display: none;
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  z-index: 20;
  width: 280px;
  font-size: var(--text-xs);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  padding: var(--space-sm);
  transform: translateX(-50%);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  line-height: 1.5;
  white-space: normal;
}

.tooltip-wrap:hover .tooltip-body,
.tooltip-trigger:focus-visible + .tooltip-body {
  display: block;
}

.vote-chip.for,
.distribution-stat[data-distribution="for"] strong {
  color: var(--color-for);
}

.vote-chip.imod,
.distribution-stat[data-distribution="imod"] strong {
  color: var(--color-imod);
}

.vote-chip.fravaer,
.distribution-stat[data-distribution="fravaer"] strong {
  color: var(--color-fravaer);
}

.vote-chip.hverken,
.distribution-stat[data-distribution="hverken"] strong,
.vote-flag-close,
.vote-flag-split,
.party-code-badge,
.party-pill,
.table-link {
  color: var(--color-accent);
}

.member-card[data-party="S"]::before {
  background: #b51428;
}

.party-pill[data-party="S"],
.party-code-badge[data-party="S"] {
  color: #b51428;
}

.member-card[data-party="V"]::before {
  background: #005da6;
}

.party-pill[data-party="V"],
.party-code-badge[data-party="V"] {
  color: #005da6;
}

.member-card[data-party="M"]::before {
  background: #6f5493;
}

.party-pill[data-party="M"],
.party-code-badge[data-party="M"] {
  color: #6f5493;
}

.member-card[data-party="SF"]::before {
  background: #b60063;
}

.party-pill[data-party="SF"],
.party-code-badge[data-party="SF"] {
  color: #b60063;
}

.member-card[data-party="EL"]::before {
  background: #ae5f0d;
}

.party-pill[data-party="EL"],
.party-code-badge[data-party="EL"] {
  color: #ae5f0d;
}

.member-card[data-party="KF"]::before {
  background: #00583c;
}

.party-pill[data-party="KF"],
.party-code-badge[data-party="KF"] {
  color: #00583c;
}

.member-card[data-party="LA"]::before {
  background: #0086ab;
}

.party-pill[data-party="LA"],
.party-code-badge[data-party="LA"] {
  color: #0086ab;
}

.member-card[data-party="RV"]::before {
  background: #733280;
}

.party-pill[data-party="RV"],
.party-code-badge[data-party="RV"] {
  color: #733280;
}

.member-card[data-party="ALT"]::before {
  background: #218a4d;
}

.party-pill[data-party="ALT"],
.party-code-badge[data-party="ALT"] {
  color: #218a4d;
}

.member-card[data-party="DD"]::before {
  background: #004450;
}

.party-pill[data-party="DD"],
.party-code-badge[data-party="DD"] {
  color: #004450;
}

.member-card[data-party="DF"]::before {
  background: #003b6f;
}

.party-pill[data-party="DF"],
.party-code-badge[data-party="DF"] {
  color: #003b6f;
}

html[data-theme="dark"] .member-card[data-party="DF"]::before {
  background: #4f8fc2;
}

html[data-theme="dark"] .party-pill[data-party="DF"],
html[data-theme="dark"] .party-code-badge[data-party="DF"] {
  color: #4f8fc2;
}

.member-card[data-party="IA"]::before {
  background: #266a91;
}

.party-pill[data-party="IA"],
.party-code-badge[data-party="IA"] {
  color: #266a91;
}

.member-card[data-party="JF"]::before {
  background: #6d3149;
}

.party-pill[data-party="JF"],
.party-code-badge[data-party="JF"] {
  color: #6d3149;
}

.member-card[data-party="N"]::before {
  background: #915a0f;
}

.party-pill[data-party="N"],
.party-code-badge[data-party="N"] {
  color: #915a0f;
}

.party-pill[data-party="SP"],
.party-code-badge[data-party="SP"] {
  color: #6f5a16;
}

.party-pill[data-party="SIU"],
.party-code-badge[data-party="SIU"] {
  color: #7c3b3b;
}

.party-pill[data-party="BP"],
.party-code-badge[data-party="BP"] {
  color: #4f5f75;
}

.party-pill[data-party="UFG"],
.party-code-badge[data-party="UFG"] {
  color: #707b75;
}

@media (max-width: 1000px) {
  .hero-panel,
  .profile-hero,
  .profile-section-grid,
  .detail-columns,
  .votes-shell,
  .vote-lists-grid,
  .info-grid,
  .party-summary-strip {
    grid-template-columns: 1fr;
  }

  .page-civics .civics-definition-list,
  .page-civics .civics-context-list,
  .page-civics .civics-source-columns {
    grid-template-columns: 1fr;
  }

  .page-civics .civics-definition-item,
  .page-civics .civics-context-item,
  .page-civics .civics-source-group {
    padding: var(--space-md) 0 0;
    border-top: 1px solid var(--color-border);
  }

  .page-civics .civics-definition-item:first-child,
  .page-civics .civics-context-item:first-child,
  .page-civics .civics-source-group:first-child {
    padding-top: 0;
    border-top: none;
  }

  .votes-browser {
    position: static;
  }
}

@media (max-width: 820px) {
  .site-header {
    grid-template-columns: 1fr;
  }

  .site-header-meta {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-header-tools {
    width: 100%;
    justify-content: space-between;
    margin-left: 0;
  }

  .toolbar-grid,
  .step-grid,
  .definition-grid,
  .metric-strip,
  .profile-stat-rail,
  .member-metrics,
  .vote-signal-strip,
  .vote-distribution-legend {
    grid-template-columns: 1fr;
  }

  .discover-grid {
    grid-template-columns: 1fr;
  }

  .member-card-head,
  .profile-identity,
  .vote-row,
  .page-civics .civics-process-item,
  .timeline-item,
  .fact-row {
    grid-template-columns: 1fr;
  }

  .member-avatar-wrap,
  .profile-avatar-wrap {
    justify-content: flex-start;
  }

  .key-stat {
    padding: var(--space-sm) 0 0;
    border-top: 1px solid var(--color-border);
    border-left: none;
  }

  .key-stat:first-child {
    padding-top: 0;
    border-top: none;
  }

  .committee-list {
    grid-template-columns: 1fr;
  }

  .page-discover .mini-metric,
  .page-votes .vote-signal-card {
    padding: var(--space-sm) 0 0;
    border-top: 1px solid var(--color-border);
    border-left: none;
  }

  .page-discover .mini-metric:first-child,
  .page-votes .vote-signal-card:first-child {
    padding-top: 0;
    border-top: none;
  }

  .page-votes .distribution-stat {
    padding: var(--space-sm) 0 0;
    border-top: 1px solid var(--color-border);
  }

  .page-votes .distribution-stat:first-child {
    padding-top: 0;
    border-top: none;
  }

  .vote-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.filters-open {
    overflow: hidden;
  }

  .site-shell {
    width: min(100vw - 1rem, 100%);
  }

  .site-brand-row {
    justify-content: space-between;
  }

  .site-nav-toggle {
    display: inline-flex;
  }

  .site-nav {
    display: none;
    width: 100%;
    flex-direction: column;
    gap: var(--space-sm);
  }

  .site-header-tools {
    flex-direction: column;
    align-items: stretch;
  }

  .theme-toggle {
    width: 100%;
  }

  .site-nav[data-open="true"] {
    display: flex;
  }

  .hero-panel,
  .page-intro,
  .toolbar-panel,
  .content-section,
  .panel,
  .profile-hero,
  .metric-strip,
  .profile-empty,
  .summary-card {
    padding: var(--space-md);
  }

  .discover-toolbar-head {
    grid-template-columns: 1fr;
  }

  .page-discover .toolbar-panel {
    order: -1;
  }

  .page-votes .votes-shell {
    order: -1;
  }

  .filters-toggle {
    display: inline-flex;
    justify-self: start;
  }

  .toolbar-grid {
    display: none;
    grid-template-columns: 1fr;
  }

  .toolbar-grid[data-open="true"] {
    display: grid;
    position: fixed;
    inset: 0.75rem;
    z-index: 40;
    padding: var(--space-md);
    border: 1px solid var(--color-border);
    background: var(--color-bg);
    align-content: start;
    overflow-y: auto;
  }

  .filters-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
  }

  .votes-toolbar,
  .vote-detail-head,
  .member-card-footer,
  .voter-row {
    align-items: stretch;
  }

  .party-table thead {
    display: none;
  }

  .party-table,
  .party-table tbody,
  .party-table tr,
  .party-table td {
    display: block;
    width: 100%;
  }

  .party-table tr {
    margin-bottom: var(--space-md);
    padding: var(--space-md);
    border: 1px solid var(--color-border);
  }

  .party-table td {
    display: grid;
    grid-template-columns: 9rem minmax(0, 1fr);
    gap: var(--space-sm);
    padding: var(--space-sm) 0;
    border: none;
  }

  .party-table td::before {
    content: attr(data-label);
    color: var(--color-text-secondary);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
  }

  .site-footer {
    align-items: flex-start;
    flex-direction: column;
  }
}
