/* ============================================================
   Your Ballot — Clean, minimal, serious
   ============================================================ */

html {
  color-scheme: light only;
  background: #ffffff;
}

:root {
  --ink:        #000000;  /* pure black for main body text */
  --ink-soft:   #111418;  /* near-black for secondary text */
  --ink-mute:   #3a4049;  /* darker grey for labels/meta (was #6b7280) */
  --line:       #c9cdd3;  /* stronger so structure reads clearly */
  --line-soft:  #e7e7ea;
  --paper:      #ffffff;
  --paper-alt:  #f7f7f8;
  --accent:     #1f3a93;  /* deep civic blue, used sparingly */
  --accent-ink: #ffffff;
  --danger:     #a01810;

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --max:   1040px;
  --pad:   clamp(1.25rem, 3vw, 2.25rem);
}

/* ---------- Reset-ish ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
  font-size: 18px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; display: block; }
a { color: var(--accent); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { text-decoration-thickness: 2px; }

/* Accessibility helpers */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--ink); color: var(--paper);
  padding: .75rem 1rem; z-index: 999;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* ---------- Layout ---------- */
.container {
  max-width: var(--max);
  margin: 0 auto;
  padding-left:  var(--pad);
  padding-right: var(--pad);
}

/* ---------- Header ---------- */
.site-header {
  padding-top:    clamp(3rem, 8vh, 6rem);
  padding-bottom: clamp(2rem, 5vh, 3.5rem);
  border-bottom: 1px solid var(--line);
}
.eyebrow {
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 1rem;
  font-weight: 500;
}
.site-title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.75rem, 7vw, 4.75rem);
  letter-spacing: -0.02em;
  line-height: 1.02;
  margin: 0 0 1.25rem;
  font-variation-settings: "opsz" 144;
}
.site-tagline {
  font-size: 1.15rem;
  max-width: 36em;
  color: var(--ink);
  margin: 0;
}

/* ---------- Search ---------- */
.search-section {
  padding-top:    clamp(2.5rem, 6vh, 4rem);
  padding-bottom: clamp(2rem, 5vh, 3rem);
}
.postcode-form { max-width: 560px; }
.postcode-label {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink-soft);
  margin-bottom: .6rem;
}
.postcode-row {
  display: flex;
  gap: .5rem;
  align-items: stretch;
}
#postcode-input,
#council-search {
  flex: 1 1 auto;
  min-width: 0;
  font: inherit;
  font-size: 1.15rem;
  padding: .9rem 1rem;
  border: 1.5px solid var(--ink);
  border-radius: 0;
  background: var(--paper);
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: border-color .15s ease;
}
#postcode-input::placeholder,
#council-search::placeholder { color: var(--ink-mute); text-transform: none; letter-spacing: 0; }
#postcode-input:focus,
#council-search:focus {
  outline: 3px solid var(--accent);
  outline-offset: 2px;
}
#postcode-submit {
  font: inherit;
  font-weight: 600;
  font-size: 1rem;
  padding: .9rem 1.5rem;
  background: var(--ink);
  color: var(--paper);
  border: 1.5px solid var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  transition: background .15s ease, color .15s ease;
  white-space: nowrap;
}
#postcode-submit:hover:not([disabled]) { background: var(--accent); border-color: var(--accent); }
#postcode-submit:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;
}
#postcode-submit[disabled] { opacity: .6; cursor: progress; }
#postcode-submit .btn-spinner {
  display: none;
  width: 14px; height: 14px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
#postcode-submit.is-loading .btn-spinner { display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

.postcode-help {
  margin: .75rem 0 0;
  font-size: .9rem;
  color: var(--ink-mute);
}
.postcode-error {
  margin: .9rem 0 0;
  font-size: .95rem;
  color: var(--danger);
  font-weight: 500;
}

/* ---------- Status ---------- */
.status-region { min-height: 1px; }
.status-msg {
  padding: 1rem 0;
  color: var(--ink-mute);
  font-size: .95rem;
}

/* ---------- Results ---------- */
.results { padding-bottom: 5rem; }
.results-header {
  padding: 2rem 0 2.5rem;
  border-top: 1px solid var(--line);
}
.results-kicker {
  margin: 0 0 .5rem;
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.results-heading {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  letter-spacing: -0.015em;
  line-height: 1.1;
  margin: 0 0 .5rem;
}
.results-sub {
  margin: 0;
  color: var(--ink);
  font-size: 1.05rem;
}

.results-grid {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--line);
}

/* Candidate row - editorial list style */
.candidate {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  padding: 1.75rem 0;
  border-bottom: 1px solid var(--line);
  align-items: start;
}

/* Compare card layout — shown on postcode results with photo + consistent facts */
.candidate-compare {
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 1.25rem;
}
.candidate-photo {
  width: 88px;
  height: 88px;
  overflow: hidden;
  background: var(--paper-alt);
  border: 1px solid var(--line);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.candidate-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.candidate-photo.is-placeholder {
  background:
    repeating-linear-gradient(
      135deg,
      var(--paper-alt) 0px,
      var(--paper-alt) 6px,
      var(--line-soft) 6px,
      var(--line-soft) 7px
    );
}
.candidate-photo .photo-placeholder-mark::before {
  content: "No photo";
  font-size: .7rem;
  color: var(--ink-mute);
  letter-spacing: .04em;
  text-transform: uppercase;
  background: var(--paper);
  padding: .15rem .35rem;
  border-radius: 2px;
}

/* Consistent fact grid so every candidate shows the same slots */
.candidate-facts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: .75rem 1.25rem;
  margin: .85rem 0 0;
  padding: .6rem 0 0;
  border-top: 1px solid var(--line-soft);
}
.candidate-facts .fact {
  display: flex;
  flex-direction: column;
  gap: .1rem;
  margin: 0;
}
.candidate-facts dt {
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.candidate-facts dd {
  margin: 0;
  font-size: .95rem;
  color: var(--ink);
  font-weight: 500;
}
.candidate-facts .fact-empty {
  color: var(--ink-mute);
  font-weight: 400;
  font-style: italic;
}

/* Statement preview snippet */
.candidate-statement-snippet {
  margin: .85rem 0 0;
  padding: .15rem 0 .15rem .85rem;
  border-left: 2px solid var(--line);
  color: var(--ink-soft);
  font-size: .92rem;
  line-height: 1.55;
  font-style: italic;
}

/* Full profile CTA */
.candidate-profile-link {
  margin: .75rem 0 0;
  font-size: .9rem;
}
.candidate-profile-link a {
  color: var(--ink);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1.5px solid var(--ink);
  padding-bottom: 1px;
  transition: color .15s, border-color .15s;
}
.candidate-profile-link a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

@media (max-width: 560px) {
  .candidate-compare {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: .9rem;
  }
  .candidate-photo { width: 64px; height: 64px; }
  .candidate-facts {
    grid-template-columns: 1fr 1fr;
    gap: .6rem 1rem;
  }
}

.candidate-main { min-width: 0; }
.candidate-name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin: 0 0 .25rem;
}
.candidate-party {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: 1rem;
  color: var(--ink);
  font-weight: 500;
}
.party-swatch {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--ink-mute);
  flex-shrink: 0;
}
.candidate-links {
  margin-top: .75rem;
  display: flex;
  flex-wrap: wrap;
  gap: .4rem .75rem;
  font-size: .9rem;
}
.candidate-links a {
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 1px;
  transition: color .15s, border-color .15s;
}
.candidate-links a:hover { color: var(--accent); border-bottom-color: var(--accent); }

.candidate-aside {
  text-align: right;
  font-size: .85rem;
  color: var(--ink-mute);
  white-space: nowrap;
}

/* ---------- Full candidate statement (Democracy Club's own words) ---------- */
.candidate-statement-full {
  margin: 1rem 0 0;
  padding: 1rem 1.1rem;
  background: var(--paper-alt);
  border-left: 3px solid var(--accent);
  color: var(--ink);
  font-size: .98rem;
  line-height: 1.6;
}
.candidate-statement-full p {
  margin: 0 0 .75rem;
}
.candidate-statement-full p:last-of-type { margin-bottom: 0; }
.candidate-statement-full cite {
  display: block;
  margin-top: .75rem;
  font-size: .82rem;
  color: var(--ink-mute);
  font-style: italic;
}

/* ---------- Priority-matcher tool ---------- */
.priority-tool {
  margin: 2.5rem 0 0;
  padding: 1.75rem 1.5rem;
  background: var(--paper-alt);
  border: 1.5px solid var(--ink);
}
.priority-heading {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.35rem;
  letter-spacing: -0.01em;
  margin: 0 0 .5rem;
}
.priority-intro {
  margin: 0 0 1rem;
  color: var(--ink);
  font-size: .98rem;
  line-height: 1.55;
}
.priority-fieldset {
  border: 0;
  padding: 0;
  margin: 0;
}
.priority-issues {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.priority-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .45rem .85rem;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 2px;
  font-size: .92rem;
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
  user-select: none;
}
.priority-chip:hover { border-color: var(--ink); }
.priority-chip input[type="checkbox"] {
  margin: 0;
  accent-color: var(--ink);
  cursor: pointer;
}
.priority-chip:has(input:checked) {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.priority-note {
  margin: 1rem 0 0;
  font-size: .88rem;
  color: var(--ink-mute);
}

/* Candidate-position inline block (shows when priority issues selected) */
.candidate-positions {
  margin: .95rem 0 0;
  padding: .85rem 1rem;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 2px;
}
.candidate-positions-intro {
  margin: 0 0 .6rem;
  font-size: .88rem;
  color: var(--ink-soft);
}
.candidate-positions-disclaimer {
  display: block;
  font-size: .78rem;
  color: var(--ink-mute);
  font-style: italic;
  margin-top: .15rem;
}
.candidate-positions-list {
  margin: 0;
  display: grid;
  gap: .55rem;
}
.candidate-position-item {
  display: grid;
  grid-template-columns: 9rem minmax(0, 1fr);
  gap: .75rem;
  align-items: baseline;
}
.candidate-position-item dt {
  font-size: .75rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
.candidate-position-item dd {
  margin: 0;
  font-size: .92rem;
  color: var(--ink);
  line-height: 1.5;
}
.candidate-position-item.is-empty dd { color: var(--ink-mute); font-style: italic; }
@media (max-width: 560px) {
  .candidate-position-item {
    grid-template-columns: 1fr;
    gap: .15rem;
  }
}

/* ---------- Council powers details ---------- */
.council-powers {
  margin: 2rem 0 0;
  border: 1px solid var(--line);
  background: var(--paper);
}
.council-powers > summary {
  padding: .95rem 1.1rem;
  font-weight: 500;
  font-size: 1rem;
  color: var(--ink-soft);
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-right: 2.2rem;
  transition: background .15s ease;
}
.council-powers > summary::-webkit-details-marker { display: none; }
.council-powers > summary::after {
  content: "+";
  position: absolute;
  right: 1.1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.3rem;
  color: var(--ink-mute);
  line-height: 1;
  font-weight: 400;
}
.council-powers[open] > summary::after { content: "−"; }
.council-powers > summary:hover { background: var(--paper-alt); }
.council-powers > summary:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: -3px;
}
.council-powers-body {
  padding: .25rem 1.1rem 1.25rem;
  border-top: 1px solid var(--line-soft);
}
.council-powers-body p { margin: .85rem 0; font-size: .95rem; line-height: 1.55; }
.council-powers-body dl { margin: 0; }
.council-powers-body dt {
  font-weight: 600;
  font-size: .95rem;
  color: var(--ink);
  margin-top: 1rem;
}
.council-powers-body dd {
  margin: .3rem 0 0;
  color: var(--ink-soft);
  font-size: .92rem;
  line-height: 1.6;
}
.council-powers-note {
  margin-top: 1rem;
  padding: .7rem .85rem;
  background: var(--paper-alt);
  border-left: 3px solid var(--line);
  font-size: .88rem !important;
  color: var(--ink-mute);
  font-style: italic;
}

/* Drop the old snippet style (superseded by .candidate-statement-full) */
.candidate-statement-snippet { display: none; }

/* ---------- Next steps (polling station + share) ---------- */
.next-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0;
  margin-top: 2.5rem;
  border-top: 1px solid var(--line);
}
.next-step-link {
  display: grid;
  grid-template-rows: auto auto;
  gap: .15rem;
  padding: 1.3rem 1.25rem 1.3rem 0;
  font: inherit;
  background: none;
  border: 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  text-decoration: none;
  text-align: left;
  cursor: pointer;
  transition: background .15s ease;
}
.next-step-link + .next-step-link {
  padding-left: 1.25rem;
  padding-right: 0;
  border-left: 1px solid var(--line);
}
@media (max-width: 640px) {
  .next-step-link + .next-step-link {
    padding-left: 0;
    border-left: none;
  }
}
.next-step-link:hover {
  background: var(--paper-alt);
}
.next-step-link:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: -2px;
}
.next-step-label {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.15rem;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.next-step-host {
  font-size: .85rem;
  color: var(--ink-mute);
}

/* ---------- Parties ---------- */
.parties-section {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid var(--line);
}
.parties-heading {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -0.015em;
  margin: 0 0 .5rem;
}
.parties-note {
  color: var(--ink-mute);
  font-size: .95rem;
  margin: 0 0 2rem;
  max-width: 38em;
}
.parties-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  border-top: 1px solid var(--line);
}
.party-card {
  padding: 1.75rem 1.5rem 1.75rem 0;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
}
.party-card:nth-child(even)  { padding-left: 1.5rem; padding-right: 0; border-right: none; }
@media (max-width: 640px) {
  .party-card, .party-card:nth-child(even) {
    padding: 1.5rem 0;
    border-right: none;
  }
}
.party-card-head {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: .85rem;
}
.party-card-name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
  margin: 0;
}
.party-card-swatch {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--ink-mute);
}
.party-card-summary {
  margin: 0 0 1rem;
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.6;
}
.party-card-themes {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}
.party-card-themes li {
  font-size: .8rem;
  color: var(--ink-soft);
  padding: .2rem .55rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper-alt);
}
.party-card-link {
  font-size: .85rem;
  font-weight: 500;
}

/* ---------- No election ---------- */
.no-election {
  padding: 3rem 0 5rem;
  border-top: 1px solid var(--line);
  max-width: 42em;
}
.no-election h2 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -0.015em;
  margin: 0 0 1rem;
}
.no-election p { color: var(--ink); }

/* ---------- Footer ---------- */
.site-footer {
  border-top: 1px solid var(--line);
  padding: 2.5rem 0 3.5rem;
  font-size: .88rem;
  color: var(--ink-mute);
  background: var(--paper-alt);
}
.site-footer p { margin: 0 0 .75rem; max-width: 48em; }
.site-footer .disclaimer { font-style: italic; }

/* ---------- Small screens ---------- */
@media (max-width: 560px) {
  .postcode-row { flex-direction: column; }
  #postcode-submit { width: 100%; justify-content: center; }
  .candidate {
    grid-template-columns: 1fr;
    gap: .5rem;
  }
  .candidate-aside { text-align: left; }
}

/* ---------- Voter ID reminder banner ---------- */
.voter-id-banner {
  margin-top: clamp(1.5rem, 4vh, 2.25rem);
  padding: 1.1rem 1.25rem;
  border: 1.5px solid var(--ink);
  background: #fff7d9;
  color: var(--ink);
  font-size: .98rem;
  line-height: 1.55;
}
.voter-id-banner p {
  margin: 0;
}
.voter-id-banner p + p {
  margin-top: .55rem;
  padding-top: .55rem;
  border-top: 1px dashed var(--line);
}
.voter-id-banner .voter-id-fallback {
  font-size: .92rem;
  color: var(--ink-soft);
}
.voter-id-banner strong {
  font-weight: 600;
}
.voter-id-banner a {
  color: var(--ink);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1.5px solid var(--ink);
  padding-bottom: 1px;
  white-space: nowrap;
  transition: color .15s, border-color .15s;
}
.voter-id-banner a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* ---------- Election day details (collapsible) ---------- */
.election-day {
  margin-top: 1rem;
  border: 1px solid var(--line);
  background: var(--paper);
}
.election-day > summary {
  padding: .95rem 1.1rem;
  font-weight: 500;
  font-size: 1rem;
  color: var(--ink-soft);
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-right: 2.2rem;
  transition: background .15s ease;
}
.election-day > summary::-webkit-details-marker { display: none; }
.election-day > summary::after {
  content: "+";
  position: absolute;
  right: 1.1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.3rem;
  color: var(--ink-mute);
  line-height: 1;
  font-weight: 400;
}
.election-day[open] > summary::after { content: "−"; }
.election-day > summary:hover { background: var(--paper-alt); }
.election-day > summary:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: -3px;
}
.election-day-body {
  padding: .25rem 1.1rem 1.25rem;
  border-top: 1px solid var(--line-soft);
}
.election-day-body dl {
  margin: 0;
  display: grid;
  gap: 1.1rem;
}
.election-day-body dt {
  font-weight: 600;
  font-size: .95rem;
  color: var(--ink);
  margin-top: .5rem;
}
.election-day-body dd {
  margin: .25rem 0 0;
  color: var(--ink-soft);
  font-size: .95rem;
  line-height: 1.55;
}
.election-day-body a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1.5px solid var(--line);
  padding-bottom: 1px;
  transition: color .15s, border-color .15s;
}
.election-day-body a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* ---------- Browse link on home page ---------- */
.browse-link {
  margin: 1.75rem 0 0;
  font-size: 1rem;
  color: var(--ink-mute);
}
.browse-link a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1.5px solid var(--ink);
  padding-bottom: 2px;
  transition: color .15s, border-color .15s;
}
.browse-link a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.browse-link a + a {
  margin-left: 1.25rem;
}
.browse-link a:focus-visible,
.back-link:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;
}

/* ---------- Candidate page (candidate.html) ---------- */
.candidate-page {
  padding: 2rem 0 5rem;
}
.candidate-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--line);
}
.candidate-top-meta p {
  margin: 0 0 .35rem;
  font-size: 1.05rem;
}
.candidate-top-meta .candidate-party {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-weight: 500;
}
.candidate-top-meta .candidate-ward {
  color: var(--ink-soft);
}
.candidate-top-meta .candidate-seat {
  color: var(--ink-mute);
  font-size: .95rem;
  margin-top: .25rem;
}
.candidate-top-photo img {
  width: 140px;
  height: 140px;
  object-fit: cover;
  border: 1px solid var(--line);
  border-radius: 2px;
}
@media (max-width: 560px) {
  .candidate-top { grid-template-columns: 1fr; }
  .candidate-top-photo img { width: 100%; height: auto; max-height: 280px; }
}

.candidate-section {
  padding: 2.25rem 0 0;
}
.candidate-section h2 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  margin: 0 0 1rem;
}

/* Links list */
.candidate-links-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: .4rem 1rem;
}
.candidate-links-list a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 1px;
  transition: color .15s, border-color .15s;
}
.candidate-links-list a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.candidate-links-empty {
  margin: 0;
  color: var(--ink-mute);
  font-size: .95rem;
}

/* Personal statement */
.candidate-statement {
  font-size: 1.05rem;
  line-height: 1.7;
  border-left: 3px solid var(--accent);
  padding: .2rem 0 .2rem 1.1rem;
  color: var(--ink);
  white-space: pre-wrap;
}
.candidate-statement-source {
  margin: .65rem 0 0;
  font-size: .85rem;
  color: var(--ink-mute);
  font-style: italic;
}

/* History list */
.candidate-history {
  list-style: none;
  padding: 0;
  margin: 0;
}
.candidate-history li {
  display: grid;
  grid-template-columns: 4rem minmax(0, 2fr) minmax(0, 1.5fr) auto;
  gap: 1rem;
  align-items: baseline;
  padding: .65rem 0;
  border-bottom: 1px dotted var(--line);
  font-size: .95rem;
}
.candidate-history li:last-child { border-bottom: 0; }
.history-year { font-weight: 600; color: var(--ink); }
.history-post { color: var(--ink); }
.history-party { color: var(--ink-soft); }
.history-result {
  justify-self: end;
  font-size: .85rem;
  padding: .15rem .55rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper-alt);
  color: var(--ink-soft);
  white-space: nowrap;
}
.history-result--won {
  background: #e8f5e8;
  border-color: #1d7f1d;
  color: #1d7f1d;
}
.history-result--lost {
  background: var(--paper-alt);
  border-color: var(--line);
  color: var(--ink-mute);
}
.candidate-history-empty {
  margin: 0;
  color: var(--ink-mute);
  font-size: .95rem;
}

@media (max-width: 560px) {
  .candidate-history li {
    grid-template-columns: 3rem minmax(0, 1fr);
    gap: .25rem 1rem;
  }
  .history-party { grid-column: 2; color: var(--ink-mute); font-size: .88rem; }
  .history-result { grid-column: 2; justify-self: start; margin-top: .2rem; }
}

/* Other candidates in same ward */
.ward-others {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--line);
}
.ward-other-link {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 1rem;
  align-items: baseline;
  padding: .85rem 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  text-decoration: none;
  transition: background .1s;
}
.ward-other-link:hover { background: var(--paper-alt); }
.ward-other-name { font-family: var(--serif); font-size: 1.1rem; font-weight: 500; }
.ward-other-party {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: var(--ink-soft);
  font-size: .95rem;
}

/* Make candidate names visibly clickable — a subtle but visible
   underline so users know the name links to the candidate's profile */
.candidate-name a,
.candidate-item-name a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  transition: border-color .15s, color .15s;
}
.candidate-name a:hover,
.candidate-item-name a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* ---------- Party positions block ---------- */
.party-positions {
  margin: 1.25rem 0 0;
  padding: 1.1rem 0 0;
  border-top: 1px solid var(--line);
}
.party-positions-heading {
  font-family: var(--sans);
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 .85rem;
}
.party-positions-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
}
.party-position {
  display: grid;
  grid-template-columns: 11rem minmax(0, 1fr);
  gap: 1.25rem;
  align-items: baseline;
  padding: .7rem 0;
  border-bottom: 1px dotted var(--line);
}
.party-position:last-child { border-bottom: 0; }
.party-position dt {
  font-weight: 600;
  font-size: .92rem;
  color: var(--ink);
  margin: 0;
}
.party-position dd {
  margin: 0;
  color: var(--ink-soft);
  font-size: .95rem;
  line-height: 1.55;
}
.party-positions-disclaimer {
  margin: 1rem 0 0;
  font-size: .82rem;
  color: var(--ink-mute);
  line-height: 1.5;
  font-style: italic;
  padding: .65rem .85rem;
  background: var(--paper-alt);
  border-left: 3px solid var(--line);
}
@media (max-width: 560px) {
  .party-position {
    grid-template-columns: 1fr;
    gap: .2rem;
    padding: .75rem 0;
  }
  .party-position dt {
    font-size: .75rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--ink-mute);
  }
}

/* ---------- Party row tweaks on parties.html ---------- */
.party-row .council-name {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
}
.party-detail .ward .ward-name {
  font-size: 1rem;
  color: var(--ink-soft);
  font-family: var(--sans);
  font-weight: 600;
  letter-spacing: 0;
}

/* ---------- Back link in eyebrow on all.html ---------- */
.back-link {
  color: var(--ink-mute);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .15s, border-color .15s;
}
.back-link:hover {
  color: var(--ink);
  border-bottom-color: var(--ink);
}

/* ---------- Council list (all.html) ---------- */
.council-list {
  padding-bottom: 5rem;
  border-top: 1px solid var(--line);
}
.council-row {
  border-bottom: 1px solid var(--line);
}
.council-toggle {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 1rem;
  align-items: baseline;
  padding: 1.4rem 0;
  background: none;
  border: 0;
  font: inherit;
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: background .1s ease;
}
.council-toggle:hover {
  background: var(--paper-alt);
}
.council-toggle:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 2px;
}
.council-name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: var(--ink);
}
.council-meta {
  font-size: .88rem;
  color: var(--ink-mute);
  justify-self: end;
  white-space: nowrap;
}
.council-chevron {
  font-size: 1rem;
  color: var(--ink-mute);
  transition: transform .18s ease;
  display: inline-block;
  width: 1rem;
  text-align: center;
}
.council-row.is-open .council-chevron {
  transform: rotate(90deg);
  color: var(--ink);
}

.council-wards {
  padding: 0 0 2rem 0;
  border-top: 1px solid var(--line-soft);
  background: var(--paper-alt);
}
.ward {
  padding: 1.2rem clamp(.5rem, 2vw, 1.25rem);
  border-bottom: 1px solid var(--line-soft);
}
.ward:last-child { border-bottom: 0; }
.ward.is-match {
  background: #fff7d9;
  border-left: 3px solid var(--ink);
  padding-left: calc(clamp(.5rem, 2vw, 1.25rem) - 3px);
}
.ward-head {
  margin-bottom: .75rem;
}
.ward-name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: -0.005em;
  margin: 0 0 .15rem;
  color: var(--ink);
}
.ward-meta {
  margin: 0;
  font-size: .82rem;
  color: var(--ink-mute);
  letter-spacing: .02em;
}
.candidate-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .2rem;
}
.candidate-item {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: baseline;
  padding: .55rem 0;
  border-bottom: 1px dotted var(--line);
  font-size: .95rem;
}
.candidate-item:last-child { border-bottom: 0; }
.candidate-item-name {
  color: var(--ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
}
.candidate-item-party {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: var(--ink-soft);
  overflow: hidden;
  text-overflow: ellipsis;
}
.candidate-item-link {
  font-size: .85rem;
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 1px;
  white-space: nowrap;
  transition: color .15s, border-color .15s;
}
.candidate-item-link:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

@media (max-width: 640px) {
  .council-toggle {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .5rem;
    align-items: start;
  }
  .council-meta {
    grid-column: 1 / -1;
    justify-self: start;
    white-space: normal;
    font-size: .82rem;
  }
  .council-chevron {
    grid-row: 1;
    grid-column: 2;
    align-self: center;
  }
  .candidate-item {
    grid-template-columns: 1fr;
    gap: .15rem;
    padding: .7rem 0;
  }
  .candidate-item-link { justify-self: start; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

/* ---------- Print stylesheet ----------
   Voters may print their postcode result to take to the polling station.
   Strip everything interactive; keep the ballot info and polling station link.
*/
@media print {
  :root { color-scheme: light; }
  body {
    background: #fff;
    color: #000;
    font-size: 11pt;
    line-height: 1.4;
  }
  /* Hide scaffolding that's useless on paper */
  .skip-link,
  .site-header,
  .browse-link,
  .search-section,
  #status-region,
  #no-election,
  #share-btn,
  .election-day,
  .parties-note,
  .site-footer {
    display: none !important;
  }
  /* Fuller-bleed and let it flow naturally */
  .container { max-width: none; padding: 0; }
  main#main { padding: 0 1cm; }

  /* Voter ID banner — keep, simplify */
  .voter-id-banner {
    margin: 0 0 1rem;
    padding: .5rem .75rem;
    border: 1pt solid #000;
    background: #fff;
    color: #000;
    font-size: 10pt;
    page-break-inside: avoid;
  }

  /* Results — the main point */
  .results { padding: 0; }
  .results-header {
    padding: 0 0 .6rem;
    border: 0;
    border-bottom: 1pt solid #000;
  }
  .results-heading { font-size: 20pt; color: #000; }
  .results-kicker,
  .results-sub { color: #000; }

  .results-grid { border-top: 0; }
  .candidate {
    padding: .5rem 0;
    border-bottom: 1pt dotted #666;
    break-inside: avoid;
  }
  .candidate-name { font-size: 13pt; color: #000; }
  .candidate-links { display: none; } /* links aren't useful on paper */
  .party-swatch { border: .5pt solid #000; }

  /* Next steps — show only the polling-station address link (not share) */
  .next-steps {
    margin-top: 1rem;
    padding-top: .5rem;
    border-top: 1pt solid #000;
    display: block;
  }
  .next-step-button { display: none; }
  .next-step-link {
    display: block;
    padding: 0;
    border: 0 !important;
    color: #000;
  }
  .next-step-link:hover { background: none; }
  .next-step-label { font-size: 12pt; }
  .next-step-host { color: #666; font-size: 10pt; }
  .next-step-link::after {
    content: " (" attr(href) ")";
    font-size: 9pt;
    color: #666;
    font-family: var(--sans);
  }

  /* Parties section — keep but simplified */
  .parties-section {
    margin-top: 1rem;
    padding-top: .5rem;
    border-top: 1pt solid #000;
    page-break-before: avoid;
  }
  .parties-heading { font-size: 14pt; color: #000; }
  .parties-grid { display: block; border: 0; }
  .party-card {
    padding: .6rem 0;
    border: 0;
    border-bottom: 1pt dotted #666;
    break-inside: avoid;
  }
  .party-card:nth-child(even) { padding-left: 0; padding-right: 0; }
  .party-card-name { color: #000; font-size: 12pt; }
  .party-card-summary { color: #000; font-size: 10pt; }
  .party-card-themes, .party-card-link { display: none; }

  /* Browse-page council list on paper: show council names + counts only */
  .council-wards { display: none; }
  .council-toggle {
    padding: .35rem 0;
    cursor: auto;
  }
  .council-chevron { display: none; }
  .council-name { font-size: 11pt; }
  .council-meta { font-size: 9pt; color: #000; }
}
