/* ── Reset / Base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  background: #f5f5f5;
  color: #222;
  margin: 0;
}

/* ── Nav ──────────────────────────────────────────────────────────────────── */
.nav {
  display: flex;
  align-items: center;
  padding: 0.6rem 1.5rem;
  background: #1a1a2e;
  color: #eee;
}
.nav-brand { color: #fff; text-decoration: none; font-weight: 700; font-size: 1.1rem; }
.nav-spacer { flex: 1; }
.nav-link { color: #ccc; text-decoration: none; margin-left: 1.5rem; }
.nav-link:hover { color: #fff; }

/* ── Main container ───────────────────────────────────────────────────────── */
.main { max-width: 960px; margin: 2rem auto; padding: 0 1rem; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.card {
  background: #fff;
  border-radius: 6px;
  padding: 1.5rem 2rem;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
  margin-bottom: 1.5rem;
}
.card h2 { margin-top: 0; }

/* ── Flash messages ───────────────────────────────────────────────────────── */
.flash {
  padding: 0.7rem 1rem;
  border-radius: 4px;
  margin-bottom: 0.8rem;
  font-weight: 500;
}
.flash-error   { background: #fee2e2; color: #991b1b; }
.flash-success { background: #dcfce7; color: #166534; }
.flash-info    { background: #dbeafe; color: #1e40af; }

/* ── Forms ────────────────────────────────────────────────────────────────── */
label { display: block; margin-bottom: 0.2rem; font-weight: 500; }
input[type="text"], input[type="url"], input[type="password"],
input[type="file"], select, textarea {
  display: block;
  width: 100%;
  padding: 0.4rem 0.6rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 0.95rem;
  margin-bottom: 1rem;
}
input[type="radio"], input[type="checkbox"] {
  display: inline;
  width: auto;
  margin-right: 0.4rem;
}
fieldset { border: 1px solid #ddd; border-radius: 4px; padding: 0.8rem 1rem; margin-bottom: 1rem; }
legend { font-weight: 600; padding: 0 0.4rem; }
.hint { color: #666; font-size: 0.88rem; margin: -0.5rem 0 1rem; }
.google-status { font-size: 0.9rem; margin: 0 0 0.75rem; }
.google-ok   { color: #16a34a; }
.google-warn { color: #b45309; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn-primary, .btn-secondary, .btn-accept, .btn-reject, .btn-skip, .btn-back {
  display: inline-block;
  padding: 0.5rem 1.2rem;
  border: none;
  border-radius: 4px;
  font-size: 0.95rem;
  font-weight: 600;
  font-family: inherit;
  line-height: 1.2;
  cursor: pointer;
  text-decoration: none;
  margin: 0.3rem 0.3rem 0.3rem 0;
  box-sizing: border-box;
}
.btn-primary   { background: #1a1a2e; color: #fff; }
.btn-secondary { background: #e2e8f0; color: #1a1a2e; }
.btn-accept    { background: #16a34a; color: #fff; }
.btn-reject    { background: #dc2626; color: #fff; }
.btn-skip      { background: #9ca3af; color: #fff; }
.btn-back      { background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1; }
.btn-primary:hover   { background: #2d2d4e; }
.btn-secondary:hover { background: #cbd5e1; }
.btn-accept:hover    { background: #15803d; }
.btn-reject:hover    { background: #b91c1c; }
.btn-skip:hover      { background: #6b7280; }
.btn-back:hover      { background: #e2e8f0; }

/* ── Login page ───────────────────────────────────────────────────────────── */
.login-page { display: flex; justify-content: center; align-items: center; min-height: 100vh; }
.login-box {
  background: #fff;
  padding: 2rem 2.5rem;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
  width: 100%;
  max-width: 380px;
}
.login-box h1 { margin-top: 0; text-align: center; }
.login-box button {
  width: 100%;
  padding: 0.6rem;
  background: #1a1a2e;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
}

/* ── Progress bar ─────────────────────────────────────────────────────────── */
.progress-wrap {
  height: 24px;
  background: #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  margin: 1.5rem 0 0.5rem;
}
.progress-bar {
  height: 100%;
  background: #16a34a;
  transition: width 0.4s ease;
}

/* ── Tier table ───────────────────────────────────────────────────────────── */
.tier-table { border-collapse: collapse; width: 100%; margin: 1rem 0; }
.tier-table th, .tier-table td { padding: 0.5rem 0.8rem; text-align: left; border-bottom: 1px solid #e5e7eb; }
.tier-table th { background: #f8fafc; font-weight: 700; }
.tier-high td:first-child        { color: #16a34a; font-weight: 700; }
.tier-high-resolved td:first-child { color: #0284c7; font-weight: 700; }
.tier-review-single td:first-child { color: #d97706; font-weight: 700; }
.tier-review-multi td:first-child  { color: #ea580c; font-weight: 700; }
.tier-no-match td:first-child     { color: #6b7280; }

/* ── Review layout ────────────────────────────────────────────────────────── */
.review-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
  align-items: start;   /* let columns size independently so sticky works */
}
@media (max-width: 680px) { .review-layout { grid-template-columns: 1fr; } }

.review-panel {
  background: #fff;
  border-radius: 6px;
  padding: 1.2rem 1.4rem;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.petition-panel {
  position: sticky;
  top: 1rem;
}
.review-panel h3 { margin-top: 0; font-size: 1rem; color: #64748b; text-transform: uppercase; letter-spacing: .05em; }

dl { display: grid; grid-template-columns: auto 1fr; gap: 0.2rem 0.8rem; }
dt { font-weight: 600; color: #64748b; white-space: nowrap; }
dd { margin: 0; word-break: break-word; }

.sig-name { font-size: 1.15rem; font-weight: 700; }
.vf-name  { font-size: 1.1rem; font-weight: 700; }

.sim-row { display: flex; gap: 1rem; margin-top: 0.8rem; font-size: 0.9rem; color: #555; }
.review-disclaimer { text-align: center; font-size: 0.82rem; color: #92400e; background: #fffbeb; border: 1px solid #fde68a; border-radius: 4px; padding: 0.4rem 1rem; margin: 0 auto 0.75rem; max-width: 600px; }
.match-labels { display: flex; flex-direction: column; gap: 0.2rem; margin-top: 0.8rem; font-size: 0.9rem; color: #374151; font-weight: 500; }
.match-note { background: #fffbeb; border-left: 3px solid #d97706; padding: 0.5rem 0.8rem; font-size: 0.88rem; margin-top: 0.8rem; }

/* ── Decision form ────────────────────────────────────────────────────────── */
.decision-form { display: flex; gap: 0.6rem; justify-content: center; margin: 1rem 0; flex-wrap: wrap; }

/* ── Party badges ─────────────────────────────────────────────────────────── */
.party { display: inline-block; padding: 0 0.4rem; border-radius: 3px; font-weight: 700; font-size: 0.85rem; }
.party-dem { background: #dbeafe; color: #1e40af; }
.party-rep { background: #fee2e2; color: #991b1b; }
.party-blk { background: #f3f4f6; color: #374151; }

/* ── Candidate cards (REVIEW_MULTI) ──────────────────────────────────────── */
.candidate-card {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 0.8rem;
  border: 2px solid #e5e7eb;
  border-radius: 6px;
  margin-bottom: 0.6rem;
  cursor: pointer;
  font-weight: normal;
}
.candidate-card:has(input:checked) { border-color: #16a34a; background: #f0fdf4; }
.candidate-card input { margin-top: 0.2rem; }
.candidate-info { display: flex; flex-direction: column; gap: 0.15rem; font-size: 0.93rem; }
.sim-tag { color: #16a34a; font-weight: 600; }
.emsid-tag { color: #9ca3af; font-size: 0.82rem; }

/* ── Dashboard extras ─────────────────────────────────────────────────────── */
.meta { color: #64748b; margin-top: -0.5rem; margin-bottom: 1rem; }
.review-status { margin: 1rem 0; }
.badge-pending { background: #fef3c7; color: #92400e; padding: 0.2rem 0.6rem; border-radius: 999px; font-size: 0.85rem; margin-left: 0.5rem; }
.badge-done    { background: #dcfce7; color: #166534; padding: 0.2rem 0.6rem; border-radius: 999px; font-size: 0.85rem; margin-left: 0.5rem; }
.action-row { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 1.2rem; }
