/*============================================================================
   Mündigkeit — Civic UI Styles  R-2.0
   Full rewrite targeting canonical prototype-game.jsx.
   Prefix: .civ-   |   Tokens: var(--*) only, no hardcoded px/colors.
   design-tokens.css is NOT modified.
   ============================================================================ */

/* scoped reset */
.civ-page *,
.civ-game-area *,
.civ-intro * {
  box-sizing: border-box;
}

/* page shell */
.civ-page {
  background: var(--paper);
  color: var(--navy-900);
  font-family: var(--font-sans);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* visually-hidden utility */
.civ-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;
}

/* ============================================================================
   INTRO SCREEN
   ============================================================================ */

.civ-intro {
  position: relative;
  padding: var(--s-10) var(--s-10) var(--s-18);
  max-width: 1080px;
  margin: 0 auto;
}

/* mesh gradient backdrop */
.civ-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(80% 50% at 50% 0%,  rgba(184,115,51,0.06), transparent 60%),
    radial-gradient(60% 40% at 12% 10%, rgba(11,24,52,0.05),   transparent 70%),
    radial-gradient(50% 35% at 92% 18%, rgba(20,33,61,0.06),   transparent 70%);
  z-index: 0;
}
.civ-intro > * { position: relative; z-index: 1; }

/* header */
.civ-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s-14);
}
.civ-header__logo {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
}
.civ-t-logo {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.4px;
  color: var(--navy-900);
}
.civ-t-logo-meta {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--brass-600);
  border-left: 1px solid var(--brass-400);
  padding-left: var(--s-2);
  transform: translateY(-1px);
}

/* quality legend pill */
.civ-quality-legend {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: var(--s-2) 14px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.6);
  border: var(--hair);
  font-size: var(--t-caption);
  color: var(--navy-700);
}
.civ-quality-legend__label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--navy-500);
}
.civ-quality-legend__item {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
}

/* step navigator */
.step-nav {
  display: flex;
  justify-content: center;
  margin-block: var(--s-3) var(--s-4);
}
.step-nav__list {
  display: inline-flex;
  gap: 0;
  list-style: none;
  padding: 4px;
  margin: 0;
  background: var(--cream-50);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.step-nav__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  color: var(--navy-500);
  transition: background 0.15s ease, color 0.15s ease;
}
.step-nav__item[aria-current="step"] {
  background: var(--navy-900);
  color: var(--paper);
}
.step-nav__num,
.step-nav__label,
.step-nav__sep {
  display: inline-block;
}
[data-screen="intro"] .civ-header__logo { display: none; }

/* translation quality details */
.civic-tquality {
  margin-block: var(--s-4) var(--s-3);
}
.civic-tquality__summary {
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--navy-500);
  padding: 8px 12px;
  list-style: none;
}
.civic-tquality__summary::-webkit-details-marker { display: none; }
.civic-tquality__summary::before { content: "\25B8 "; }
.civic-tquality[open] .civic-tquality__summary::before { content: "\25BE "; }
.civic-tquality__body { padding: 12px; }

/* hero section */
.civ-hero-section {
  text-align: center;
  margin-bottom: var(--s-10);
  overflow-x: hidden;
}
.civ-t-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--t-body);
  line-height: 1.5;
  color: var(--navy-600);
  max-width: 640px;
  margin: 0 auto var(--s-1);
  letter-spacing: 0.1px;
}
.civ-t-quote-attr {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--navy-500);
  margin: 0 0 var(--s-6);
}
.civ-t-hero {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.25rem, 10vw, 6.5rem);
  line-height: 0.95;
  letter-spacing: -4px;
  color: var(--navy-900);
  margin: 0 0 var(--s-4);
  max-width: 100%;
  overflow-wrap: break-word;
}
.civ-t-hero[style] { font-size: clamp(2.25rem, 10vw, 6.5rem) !important; }
.civ-t-sub {
  font-size: 17px;
  line-height: 1.5;
  color: var(--navy-700);
  max-width: 540px;
  margin: 0 auto;
  font-weight: 400;
}

/* stat cards */
.civ-stats {
  display: flex;
  gap: var(--s-4);
  margin-bottom: var(--s-10);
}
.civ-stat-card {
  flex: 1;
  min-width: 0;
  background: var(--cream-50);
  border: 1px solid rgba(11,24,52,0.08);
  border-radius: var(--r-lg);
  padding: 26px var(--s-6) 22px;
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.civ-stat-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--navy-700);
  opacity: 0.18;
}
.civ-stat-card--accent::before { background: var(--brass-500); opacity: 1; }
.civ-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: rgba(11,24,52,0.18);
}
.civ-stat-card__n {
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-stat);
  line-height: 1;
  letter-spacing: -2px;
  color: var(--navy-900);
  font-variant-numeric: tabular-nums;
}
.civ-stat-card--accent .civ-stat-card__n { color: var(--brass-600); }
.civ-stat-card__label {
  margin-top: 14px;
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--navy-600);
}
.civ-stat-card__sub {
  margin-top: var(--s-1);
  font-size: var(--t-meta);
  line-height: 1.45;
  color: var(--navy-500);
}

/* language picker */
.civ-lang-picker { margin-bottom: var(--s-10); }
.civ-t-lang-lead {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-h2);
  line-height: 1.25;
  margin: 0 0 var(--s-1);
  color: var(--navy-900);
  letter-spacing: -0.3px;
  text-align: center;
}
.civ-t-lang-sub {
  font-size: var(--t-meta);
  color: var(--navy-500);
  margin: 0 0 14px;
  text-align: center;
}
.civ-lang-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: center;
  max-width: 720px;
  margin: 0 auto;
}
.civ-lang-tile {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 9px 14px 9px 12px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(11,24,52,0.14);
  background: var(--cream-50);
  color: var(--navy-800);
  font-weight: 500;
  font-size: var(--t-body);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: all var(--dur-base) ease;
  font-family: inherit;
}
.civ-lang-tile.civ-is-active {
  border-color: var(--navy-800);
  background: var(--navy-900);
  color: var(--cream-50);
  font-weight: 600;
  box-shadow: var(--shadow-md);
}
.civ-lang-expand {
  display: block;
  margin: var(--s-3) auto 0;
  padding: 9px 14px;
  border-radius: var(--r-pill);
  border: 1px dashed rgba(11,24,52,0.25);
  background: transparent;
  color: var(--navy-600);
  font-size: var(--t-meta);
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
}
.civ-lang-expand:hover {
  border-color: var(--navy-500);
  color: var(--navy-800);
}

/* mode selector grid */
.civ-modes { margin-bottom: var(--s-10); }
.civ-modes-head {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--navy-500);
  text-align: center;
  margin-bottom: 14px;
}
.civ-modes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
.civ-mode-card {
  text-align: left;
  padding: 16px 18px 18px;
  border-radius: var(--r-lg);
  border: 1px solid rgba(11,24,52,0.12);
  background: rgba(252,250,243,0.55);
  cursor: pointer;
  transition: all var(--dur-base) ease;
  outline: none;
  font-family: inherit;
}
.civ-mode-card:hover { border-color: var(--navy-300); }
.civ-mode-card.civ-is-active {
  border: 1.5px solid var(--navy-800);
  background: var(--cream-50);
  box-shadow: var(--shadow-md);
}
.civ-mode-card.civ-is-active[data-mode="vollpruefung"] {
  border-color: var(--brass-500);
  background: var(--brass-50);
}
.civ-mode-card-top {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  margin-bottom: var(--s-1);
}
.civ-mode-radio {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1.5px solid rgba(11,24,52,0.30);
  background: transparent;
  flex: none;
}
.civ-is-active .civ-mode-radio {
  border-color: var(--navy-800);
  background: radial-gradient(circle, var(--navy-800) 40%, transparent 45%);
}
.civ-mode-card.civ-is-active[data-mode="vollpruefung"] .civ-mode-radio {
  border-color: var(--brass-500);
  background: radial-gradient(circle, var(--brass-500) 40%, transparent 45%);
}
.civ-t-mode-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-h3);
  color: var(--navy-900);
  letter-spacing: -0.2px;
}
.civ-t-mode-desc {
  font-size: var(--t-meta);
  color: var(--navy-700);
  line-height: 1.4;
}
.civ-t-mode-meta {
  margin-top: var(--s-3);
  font-size: var(--t-mono);
  color: var(--navy-500);
  font-family: var(--font-mono);
  letter-spacing: 0.2px;
}
.civ-mode-badge {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--brass-700);
  background: var(--brass-100);
  padding: 2px var(--s-1);
  border-radius: var(--r-sm);
  flex: none;
}

/* primary CTA */
.civ-cta-section { text-align: center; margin-bottom: var(--s-10); }
.civ-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: var(--s-5) var(--s-10);
  border-radius: var(--r-pill);
  border: none;
  background: var(--navy-900);
  color: var(--cream-50);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.2px;
  box-shadow: var(--shadow-cta);
  cursor: pointer;
  transition: transform var(--dur-quick) ease;
}
.civ-cta:hover    { transform: translateY(-2px); }
.civ-cta:active   { transform: translateY(1px); }
.civ-t-cta-sub {
  margin-top: 12px;
  font-size: var(--t-caption);
  color: var(--navy-500);
}

/* trust footer */
.civ-trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: center;
  padding-top: var(--s-6);
  border-top: var(--hair);
}
.civ-trust__chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  padding: var(--s-1) 12px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(11,24,52,0.16);
  background: rgba(252,250,243,0.6);
  font-size: var(--t-caption);
  font-weight: 500;
  color: var(--navy-700);
}
.civ-powered-by {
  margin-top: var(--s-6);
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.1px;
  text-transform: uppercase;
  color: var(--navy-300);
}

/* ============================================================================
   SIZE SELECT SCREEN
   ============================================================================ */
#size-select-screen {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--s-10) var(--s-4) var(--s-8);
}
.civ-size-area {
  background: var(--cream-50);
  border: var(--hair);
  border-radius: var(--r-lg);
  padding: var(--s-8) var(--s-6);
  box-shadow: var(--shadow-lg);
}
.civ-size-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--s-3);
  border: 0;
  margin: 0 0 var(--s-6);
  padding: 0;
}
.civ-size-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: var(--s-5) var(--s-4);
  border-radius: var(--r-lg);
  border: 1px solid rgba(11,24,52,0.12);
  background: var(--cream-50);
  cursor: pointer;
  font-family: var(--font-display);
  transition: border-color var(--dur-base) ease, box-shadow var(--dur-base) ease;
  min-height: 96px;
  position: relative;
}
.civ-size-card:hover { border-color: var(--navy-300); }
.civ-size-card:has(input:checked) {
  border: 1.5px solid var(--navy-800);
  box-shadow: var(--shadow-md);
}
.civ-size-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.civ-size-card__radio {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1.5px solid rgba(11,24,52,0.30);
  background: transparent;
}
.civ-size-card:has(input:checked) .civ-size-card__radio {
  border-color: var(--navy-800);
  background: radial-gradient(circle, var(--navy-800) 40%, transparent 45%);
}
.civ-size-card__n {
  font-size: 36px;
  font-weight: 500;
  color: var(--navy-900);
  letter-spacing: -0.02em;
  line-height: 1;
}

/* ============================================================================
   QUIZ SCREEN
   ============================================================================ */
.civ-game-area {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 0 var(--s-8);
}
.civ-quiz-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-3) var(--s-5);
  border-bottom: var(--hair);
  background: var(--paper);
}
.civ-quiz-header__brand {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
}
.civ-quiz-header__brand-main {
  font-family: var(--font-display);
  font-size: var(--t-h2);
  color: var(--navy-900);
  letter-spacing: -0.01em;
}
.civ-quiz-header__pills {
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.civ-quiz-pill {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  border: var(--hair);
  white-space: nowrap;
}
.civ-quiz-pill--lang {
  background: var(--cream-50);
  color: var(--navy-800);
}
.civ-quiz-pill--mode {
  background: var(--navy-900);
  color: var(--cream-50);
  border-color: var(--navy-900);
}
.civ-mute-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(11,24,52,0.10);
  background: transparent;
  cursor: pointer;
  color: var(--navy-600);
  padding: 0;
  margin-left: var(--s-1);
  transition: background var(--dur-quick), color var(--dur-quick);
}
.civ-mute-btn:hover { background: var(--navy-50); color: var(--navy-800); }
.civ-mute-btn[aria-pressed="true"] { color: var(--navy-400); }
.civ-progress-section {
  padding: var(--s-4) var(--s-5) var(--s-3);
}
.civ-progress-section__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tracking-mono);
  color: var(--navy-800);
  text-transform: uppercase;
}
.civ-progress-track {
  height: 6px;
  background: var(--brass-50);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.civ-progress-fill {
  height: 100%;
  background: var(--brass-500);
  transition: width var(--dur-base) var(--ease-out);
}
.civ-timer {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin: 0;
  padding: var(--s-2) 14px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(11,24,52,0.14);
  background: rgba(252,250,243,0.7);
  font-family: var(--font-mono);
  font-size: var(--t-body);
  font-weight: 700;
  color: var(--navy-800);
  font-variant-numeric: tabular-nums;
  min-width: 7em;
}
.civ-timer--warning {
  border-color: var(--bad-500);
  background: var(--bad-100);
  color: var(--bad-700);
}
.civ-progress-section__head .civ-timer {
  padding: 0 0 0 var(--s-2);
  border: none;
  background: none;
  border-radius: 0;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  min-width: 4.5em;
}
.civ-progress-section__head .civ-timer--warning {
  background: none;
  border: none;
  color: var(--bad-700);
}
.civ-card {
  background: var(--cream-50);
  border: var(--hair);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  box-shadow: var(--shadow-lg);
  margin: 0 var(--s-4);
}
.civ-card--exam {
  border: 1.5px solid var(--navy-800);
}
.civ-card-meta-row {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.civ-card-meta-row__nr {
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: var(--tracking-mono);
  color: var(--navy-800);
  text-transform: uppercase;
}
.civ-kategorie-chip {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-pill);
  background: var(--brass-50);
  color: var(--brass-600);
  border: 1px solid var(--brass-500);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  font-weight: 600;
}
.civ-card-meta-row__themenbereich {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: var(--tracking-mono);
  color: var(--navy-800);
  text-transform: uppercase;
}
.civ-quality-dot {
  width: var(--s-2); height: var(--s-2);
  border-radius: 50%;
  display: inline-block;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.10);
  flex: none;
}
.civ-quality-dot--verified   { background: var(--good-500); }
.civ-quality-dot--auto       { background: var(--tier-amber); }
.civ-quality-dot--lazy       { background: var(--tier-red); }
.civ-quality-dot--unverified { background: var(--tier-amber); }
.civ-stem-row {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
}
.civ-t-stem {
  font-family: var(--font-display);
  font-size: var(--t-h2);
  font-weight: 500;
  line-height: 1.4;
  margin: 0;
  flex: 1;
}
.civ-stem-row__stem { flex: 1; margin: 0; }
.civ-tts-btn--stem  { flex-shrink: 0; margin-top: var(--s-1); }
.civ-tts-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(11,24,52,0.10);
  background: rgba(255,255,255,0.7);
  cursor: pointer;
  color: var(--navy-600);
  transition: background var(--dur-quick);
  flex: none;
  padding: 0;
}
.civ-tts-btn:hover { background: var(--brass-100); color: var(--brass-600); }
.civ-audio-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--brass-300);
  background: rgba(255,255,255,0.85);
  cursor: pointer;
  color: var(--brass-500);
  transition: background var(--dur-quick), color var(--dur-quick);
  flex: none;
  padding: 0;
  margin-left: var(--s-1);
}
.civ-audio-btn:hover {
  background: var(--brass-80);
  color: var(--brass-700);
  border-color: var(--brass-400);
}
.civ-audio-btn--stem { flex-shrink: 0; margin-top: var(--s-1); }
.civ-option-wrapper {
  display: flex;
  align-items: stretch;
  gap: 0;
}
.civ-option-wrapper .civ-option-row {
  flex: 1;
  margin-right: 0;
  align-self: stretch;
}
.civ-option-wrapper .civ-audio-btn {
  align-self: center;
}
.civ-options-fieldset {
  border: 0;
  padding: 0;
  margin: 0 0 var(--s-4);
}
.civ-options { display: grid; grid-template-columns: 1fr; grid-auto-rows: 1fr; gap: var(--s-2); min-height: 340px; }
.civ-card--bildfrage-options .civ-options { min-height: 520px; }
.civ-option-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: var(--r-md);
  border: 1.5px solid rgba(11,24,52,0.14);
  background: var(--cream-50);
  color: var(--navy-800);
  cursor: pointer;
  transition: all var(--dur-quick) ease;
  font-size: var(--t-body);
  line-height: 1.45;
  min-height: 72px;
}
.civ-option-row:hover { border-color: rgba(11,24,52,0.30); }
.civ-option-row[data-opt-state=""]:has(input:checked) {
  border-color: var(--navy-800);
  background: var(--cream-50);
  font-weight: 500;
}
.civ-opt-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  min-width: 26px;
  border-radius: 50%;
  border: 1.5px solid rgba(11,24,52,0.20);
  background: transparent;
  color: var(--navy-700);
  font-family: var(--font-mono);
  font-size: var(--t-caption);
  font-weight: 700;
  transition: all var(--dur-quick) ease;
  flex: none;
}
.civ-option-row[data-opt-state=""]:has(input:checked) .civ-opt-label {
  border-color: var(--navy-800);
  background: var(--navy-800);
  color: var(--cream-50);
}
.civ-option-row[data-opt-state="correct"]        { border-color: var(--good-500); background: var(--good-100); color: var(--good-700); }
.civ-option-row[data-opt-state="incorrect"]      { border-color: var(--bad-500);  background: var(--bad-100);  color: var(--bad-700);  }
.civ-option-row[data-opt-state="locked-correct"] { border-color: var(--good-500); background: var(--good-100); color: var(--good-700); }
.civ-option-row[data-opt-state="locked"]         { border-color: rgba(11,24,52,0.10); background: transparent; color: var(--navy-300); cursor: default; }
.civ-option-row[data-opt-state="correct"]        .civ-opt-label,
.civ-option-row[data-opt-state="locked-correct"] .civ-opt-label { border-color: var(--good-500); background: var(--good-500); color: var(--cream-50); }
.civ-option-row[data-opt-state="incorrect"]      .civ-opt-label { border-color: var(--bad-500);  background: var(--bad-500);  color: var(--cream-50); }
.civ-opt-text { flex: 1; }
.civ-exam-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono);
  color: var(--navy-700);
  background: var(--navy-100);
  border: 1px solid var(--navy-300);
}
.civ-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-6);
  font-family: var(--font-sans);
  font-size: var(--t-body);
  font-weight: 600;
  border: 1.5px solid transparent;
  border-radius: var(--r-pill);
  cursor: pointer;
  min-height: 56px;
  transition: transform var(--dur-quick), box-shadow var(--dur-quick);
}
.civ-btn--full {
  width: 100%;
  border-radius: var(--r-md);
}
.civ-btn-primary {
  background: var(--navy-900);
  color: var(--cream-50);
  box-shadow: var(--shadow-cta);
}
.civ-btn-primary:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 18px 36px -14px rgba(11,24,52,0.5); }
.civ-btn-primary:active:not(:disabled){ transform: translateY(0); }
.civ-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.civ-btn-secondary {
  background: transparent;
  color: var(--navy-800);
  border-color: var(--navy-800);
}
.civ-btn-secondary:hover:not(:disabled) { background: var(--navy-100); }
.civ-btn-secondary:disabled { opacity: 0.5; cursor: not-allowed; }
#civ-check-btn { margin-top: var(--s-2); }
#civ-next-btn  { margin-top: var(--s-3); }
.civ-action-zone { margin-top: var(--s-4); }
.civ-feedback {
  margin-top: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-md);
  font-family: var(--font-sans);
  font-size: var(--t-body);
  line-height: 1.45;
}
.civ-feedback--correct  { background: var(--good-100); color: var(--good-700); border: 1px solid var(--good-500); }
.civ-feedback--incorrect{ background: var(--bad-100);  color: var(--bad-700);  border: 1px solid var(--bad-500);  }
.civ-erklaerung {
  margin-top: var(--s-3);
  padding: 12px 14px;
  border-left: 4px solid var(--brass-500);
  background: var(--brass-50);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.civ-erklaerung-label {
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brass-700);
}
.civ-erklaerung-body {
  font-size: var(--t-body);
  line-height: 1.6;
  color: var(--navy-900);
  white-space: pre-wrap;
}
.civ-erklaerung-fallback-note {
  margin-top: 8px;
  font-size: var(--t-meta);
  color: var(--navy-500);
  font-style: italic;
}
.civ-hint {
  margin-top: var(--s-4);
  border: 1px solid var(--brass-200);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: background var(--dur-base) ease;
}
.civ-hint[data-hint-open="true"]  { background: var(--brass-50); }
.civ-hint[data-hint-open="false"] { background: transparent; }
.civ-hint-toggle {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  width: 100%;
  padding: 12px 16px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--t-body);
  font-weight: 500;
  color: var(--brass-700);
  text-align: left;
}
.civ-hint-toggle::before {
  content: "\1F4A1";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--brass-100);
  font-size: var(--t-meta);
  flex: none;
}
.civ-hint-toggle:hover { background: var(--brass-100); }
.civ-hint-hint-cap {
  flex: 1;
  font-size: 11.5px;
  color: var(--navy-500);
  font-style: italic;
  line-height: 1.35;
  text-align: right;
}
.civ-chevron {
  flex: none;
  transition: transform var(--dur-base) ease;
}
.civ-hint[data-hint-open="true"] .civ-chevron { transform: rotate(180deg); }
.civ-hint-body {
  display: none;
  padding: 0 var(--s-4) var(--s-4);
  border-top: 1px solid var(--brass-200);
}
.civ-hint[data-hint-open="true"] .civ-hint-body { display: block; }
.civ-hint-label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--brass-700);
  margin: var(--s-4) 0 var(--s-2);
}
.civ-hint-stem {
  margin: 0 0 var(--s-3);
  font-size: var(--t-body);
  line-height: 1.5;
  color: var(--navy-800);
  font-weight: 500;
}
.civ-hint-opts { display: flex; flex-direction: column; gap: var(--s-1); }
.civ-hint-opt-row {
  display: flex;
  gap: var(--s-3);
  font-size: var(--t-meta);
  line-height: 1.5;
  color: var(--navy-700);
}
.civ-hint-opt-key {
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--brass-600);
  flex: none;
}
.civ-de-original {
  margin-top: var(--s-4);
  border: var(--hair);
  border-radius: var(--r-md);
  overflow: hidden;
}
.civ-de-original__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0; height: 0;
}
.civ-de-original__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px var(--s-4);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--good-700);
  background: var(--good-100);
  user-select: none;
}
.civ-de-original__header:hover { filter: brightness(0.96); }
.civ-de-original__body {
  display: none;
  padding: var(--s-4);
  border-top: var(--hair);
  background: var(--cream-50);
}
.civ-de-original__input:checked ~ .civ-de-original__body { display: block; }
.civ-de-original__input:checked ~ .civ-de-original__header .civ-chevron { transform: rotate(180deg); }
.civ-de-original__stem {
  margin: 0 0 var(--s-3);
  font-size: var(--t-body);
  line-height: 1.5;
  color: var(--navy-800);
}
.civ-de-original__opts { display: flex; flex-direction: column; gap: var(--s-1); }
.civ-de-original__opt-key {
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--navy-600);
  flex: none;
}

/* ============================================================================
   ERGEBNIS / RESULT SCREEN
   ============================================================================ */
.civ-result { max-width: 960px; margin: 0 auto; padding-bottom: var(--s-8); }
.civ-result-hero {
  background: var(--cream-50);
  border: var(--hair);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  margin: var(--s-4) var(--s-4) var(--s-6);
}
.civ-result-hero__accent {
  height: 5px;
  width: 100%;
}
.civ-result-hero__inner {
  padding: var(--s-6) var(--s-6) var(--s-8);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.civ-result-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  padding: var(--s-2) var(--s-5);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  font-weight: 700;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  margin-bottom: var(--s-4);
}
.civ-result-badge--pass { background: var(--good-100);  color: var(--good-700); }
.civ-result-badge--fail { background: var(--bad-100);   color: var(--bad-700);  }
.civ-result-score {
  display: flex;
  align-items: baseline;
  gap: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-stat);
  line-height: 1;
  letter-spacing: -2px;
  font-variant-numeric: tabular-nums;
  margin: 0 0 var(--s-2);
}
.civ-result-score__correct { color: var(--navy-900); }
.civ-result-score__sep     { color: var(--navy-300); font-weight: 300; padding: 0 4px; }
.civ-result-score__total   { color: var(--navy-300); }
.civ-result-pct {
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--navy-700);
  margin: 0 0 var(--s-5);
}
.civ-result-meta {
  display: flex;
  gap: var(--s-8);
  justify-content: center;
  align-items: flex-start;
  padding-top: var(--s-4);
  border-top: var(--hair);
  width: 100%;
}
.civ-result-meta__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-1);
}
.civ-result-meta__val {
  display: flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-display);
  font-size: var(--t-h2);
  font-weight: 500;
  color: var(--navy-900);
}
.civ-result-meta__of {
  font-family: var(--font-sans);
  font-size: var(--t-body);
  color: var(--navy-500);
  font-weight: 400;
}
.civ-result-meta__label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--navy-500);
}
.civ-result-review {
  margin: 0 var(--s-4) var(--s-6);
}
.civ-result-review__title {
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--brass-600);
  margin: 0 0 var(--s-3);
  font-weight: 600;
}
.civ-result-review__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-2);
}
.civ-result-review-item {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  border-radius: var(--r-md);
  border: var(--hair);
  background: var(--cream-50);
  box-shadow: var(--shadow-sm);
}
.civ-result-review-item--ok   { border-color: rgba(45,134,89,0.20); }
.civ-result-review-item--fail { border-color: rgba(184,64,76,0.20); }
.civ-result-review-item__icon {
  flex: none;
  display: flex;
  align-items: center;
}
.civ-result-review-item__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.civ-result-review-item__nr {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  font-weight: 700;
  color: var(--navy-800);
  letter-spacing: 0.3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.civ-result-review-item__kat {
  font-family: var(--font-sans);
  font-size: 10px;
  color: var(--navy-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.civ-result-review-item__hint {
  flex: none;
  font-size: 12px;
  line-height: 1;
}
.civ-result-cta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
  margin: 0 var(--s-4) var(--s-6);
}
.civ-result-cta .civ-btn { min-height: 56px; border-radius: var(--r-lg); }
.civ-result-cta .civ-btn-primary { font-family: var(--font-display); font-size: 18px; }
.civ-result-trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: center;
  padding: var(--s-5) var(--s-4);
  border-top: var(--hair);
}
.civ-result-card  { display: none; }
.civ-result-actions { display: none; }

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width: 768px) {
  .civ-modes-grid { grid-template-columns: 1fr; }
  .civ-stats      { flex-direction: column; }
  .civ-intro      { padding: var(--s-6) var(--s-4) var(--s-10); }
  .civ-t-hero     { font-size: clamp(2rem, 9vw, 4rem) !important; letter-spacing: -2.5px; }
  .civ-header     { flex-direction: column; align-items: flex-start; gap: var(--s-3); margin-bottom: var(--s-8); }
  .civ-result-review__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .civ-card          { margin: 0 var(--s-3); padding: var(--s-4); }
  .civ-result-hero   { margin: var(--s-3); }
  .civ-result-review { margin: 0 var(--s-3) var(--s-5); }
  .civ-result-cta    { grid-template-columns: 1fr; margin: 0 var(--s-3) var(--s-5); }
  .civ-result-review__grid { grid-template-columns: repeat(2, 1fr); }
  .civ-result-meta   { gap: var(--s-5); }
  .civ-size-grid     { grid-template-columns: 1fr; }
  .civ-lang-row      { flex-wrap: wrap; }
  .civ-cta           { padding: var(--s-4) var(--s-8); font-size: 19px; }
}
.civ-size-accent {
  height: 5px;
  width: 100%;
  background: var(--brass-500);
}
.civ-size-mode-intro {
  font-size: var(--t-meta);
  color: var(--navy-500);
  text-align: center;
  margin: 0 0 var(--s-5);
  line-height: 1.4;
}
.civ-size-subtitle {
  display: block;
  font-size: var(--t-meta);
  color: var(--navy-500);
  margin-top: var(--s-1);
  font-weight: 400;
}
.civ-quiz-meta .civ-progress-bar { display: none; }

/* ============================================================================
   R-4.16 — Language Picker Modal
   ============================================================================ */
.civic-langpicker-modal__backdrop {
  position: fixed; inset: 0;
  background: rgba(11,24,52,0.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 10000;
  animation: civ-lpm-fadein var(--dur-quick) var(--ease-out);
}
@keyframes civ-lpm-fadein { from { opacity: 0; } to { opacity: 1; } }
.civic-langpicker-modal__container {
  background: var(--cream-50);
  max-width: 640px; width: calc(100vw - var(--s-8));
  max-height: 82vh;
  padding: var(--s-8);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column;
  animation: civ-lpm-slideup var(--dur-base) var(--ease-out);
}
@keyframes civ-lpm-slideup { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.civic-langpicker-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s-5);
}
.civic-langpicker-modal__title {
  font-family: var(--font-display);
  font-size: var(--t-h3);
  font-weight: 500;
  color: var(--navy-900);
  margin: 0;
}
.civic-langpicker-modal__close {
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  border: var(--hair);
  background: transparent;
  color: var(--navy-500);
  font-size: 18px; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-quick);
  padding: 0; font-family: inherit;
}
.civic-langpicker-modal__close:hover { background: var(--navy-100); }
.civic-langpicker-modal__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-2);
  overflow-y: auto;
  padding-right: var(--s-1);
}
.civic-langpicker-modal__btn {
  padding: var(--s-2) var(--s-3);
  border-radius: var(--r-sm);
  border: var(--hair);
  background: transparent;
  color: var(--navy-800);
  font-size: var(--t-meta);
  font-weight: 500;
  cursor: pointer;
  text-align: center;
  transition: all var(--dur-quick);
  font-family: var(--font-sans);
}
.civic-langpicker-modal__btn:hover {
  background: var(--navy-100);
  border-color: var(--navy-500);
}
.civic-langpicker-modal__btn.civ-is-active {
  background: var(--navy-900);
  color: var(--cream-50);
  border-color: var(--navy-900);
}

@media (max-width: 480px) {
  .civic-langpicker-modal__container { max-width: calc(100vw - var(--s-4)); padding: var(--s-5); }
  .civic-langpicker-modal__grid { grid-template-columns: repeat(3, 1fr); }
}

/* ============================================================================
   R-4.14 — Confirm Quit Modal
   ============================================================================ */
.civic-confirm-modal__backdrop {
  position: fixed; inset: 0;
  background: rgba(11,24,52,0.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 10001;
}
.civic-confirm-modal__container {
  background: var(--cream-50);
  max-width: 420px; width: calc(100vw - var(--s-8));
  padding: var(--s-8);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  animation: civ-cfm-slideup var(--dur-base) var(--ease-out);
}
@keyframes civ-cfm-slideup { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.civic-confirm-modal__body {
  font-family: var(--font-display);
  font-size: var(--t-h3);
  font-weight: 400;
  color: var(--navy-900);
  line-height: 1.4;
  margin: 0 0 var(--s-6);
}
.civic-confirm-modal__actions {
  display: flex;
  gap: var(--s-3);
  justify-content: flex-end;
}
.civic-confirm-modal__btn {
  padding: var(--s-3) var(--s-6);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--t-body);
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all var(--dur-quick);
}
.civic-confirm-modal__btn:focus-visible { outline: 2px solid var(--navy-800); outline-offset: 2px; }
.civic-confirm-modal__btn--cancel {
  background: transparent;
  border: var(--hair-strong);
  color: var(--navy-800);
}
.civic-confirm-modal__btn--cancel:hover { background: var(--navy-100); }
.civic-confirm-modal__btn--ok {
  background: var(--navy-900);
  color: var(--cream-50);
}
.civic-confirm-modal__btn--ok:hover { background: var(--navy-800); }

@media (max-width: 480px) {
  .civic-confirm-modal__container { max-width: calc(100vw - var(--s-4)); padding: var(--s-5); }
  .civic-confirm-modal__actions { flex-direction: column-reverse; }
  .civic-confirm-modal__btn { width: 100%; text-align: center; }
}

/* ============================================================================
   R-4.26.1 Claude Design size hotfix
   ============================================================================ */
@media (max-width: 768px) {
  .civ-t-hero { font-size: clamp(2.5rem, 11vw, 5rem) !important; }
}
.civ-stat-card__n { font-size: clamp(2.5rem, 11vw, 3.5rem); }
@media (max-width: 480px) {
  .civ-quiz-header__brand-main { font-size: 1.35rem; }
  .civ-t-stem { font-size: 1.35rem; }
  .civ-option-row { font-size: 0.9rem; }
  .civ-btn { font-size: 0.95rem; padding: 14px 20px; min-height: 48px; }
  .civ-quiz-pill { font-size: 10px; letter-spacing: 1px; padding: 3px 10px; }
  .civ-exam-badge { display: none; }
}

/* ============================================================================
   R-4.26.2 — mobile lang picker top-5
   ============================================================================ */
@media (max-width: 480px) {
  .civ-lang-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    max-width: 360px;
  }
  .civ-lang-tile {
    justify-content: center;
  }
  .civ-lang-picker .civ-lang-tile[data-lang]:not([data-lang="de"]):not([data-lang="en"]):not([data-lang="fr"]):not([data-lang="tr"]):not([data-lang="ar"]) {
    display: none;
  }
}

/* ============================================================================
   R-4.26.4 — INTRO mobile wide
   ============================================================================ */
@media (max-width: 480px) {
  .civ-intro[style] { padding: var(--s-6) var(--s-4) var(--s-10) !important; }
  .civ-t-quote[style],
  .civ-t-sub[style] { max-width: none !important; }
}
.civ-stat-card__n { font-size: clamp(2.75rem, 12vw, 3.8rem); }

/* ============================================================================
   R-4.26.5 — hero Mundigkeit serif mobile viewport wide
   ============================================================================ */
@media (max-width: 480px) {
  .civ-t-hero {
    font-size: clamp(3.5rem, 19vw, 7rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.02em !important;
    text-align: center;
  }
}

/* ============================================================================
   R-4.26.6 — hero wide specificity fix
   ============================================================================ */
@media (max-width: 480px) {
  .civ-t-hero[style] {
    font-size: clamp(2.75rem, 15vw, 4.5rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.015em !important;
    text-align: center;
  }
}

/* ============================================================================
   R-4.47 — Civic UX SFX and Auto-play animations
   ============================================================================ */
@media (prefers-reduced-motion: no-preference) {
  .civ-summary__score {
    animation: civ-score-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  }
  @keyframes civ-score-pop {
    0%   { transform: scale(0.95); opacity: 0; }
    60%  { transform: scale(1.15); opacity: 1; }
    100% { transform: scale(1.00); }
  }
  .civ-summary--passed .civ-summary__score {
    color: var(--brass-600);
    text-shadow: 0 0 24px var(--brass-50);
  }
  .civ-confetti {
    position: absolute;
    top: 0;
    width: 8px; height: 12px;
    border-radius: 2px;
    animation: civ-confetti-fall 1.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
  }
  @keyframes civ-confetti-fall {
    0%   { transform: translate(var(--x, 0), -20px) rotate(0deg); opacity: 1; }
    100% { transform: translate(var(--x, 0), 100vh) rotate(720deg); opacity: 0; }
  }
}
@media (prefers-reduced-motion: reduce) {
  .civ-summary__score { animation: none; }
  .civ-confetti { display: none; }
}
.civ-summary--failed .civ-summary__score {
  animation: civ-score-pulse 1.2s ease-out;
}
@keyframes civ-score-pulse {
  0%, 100% { color: var(--navy-800); }
  50%      { color: var(--navy-500); }
}

/* ============================================================================
   R-4.27 Bildfrage image styles
   ============================================================================ */
.civ-stem-img {
  margin-bottom: var(--s-4);
}
.civ-question__image {
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  border-radius: var(--r-md, 8px);
  display: block;
}
.civ-option__image {
  max-width: 100%;
  max-height: 120px;
  object-fit: contain;
  display: block;
  border-radius: var(--r-sm, 4px);
}
@media (max-width: 480px) {
  .civ-option__image { max-height: 80px; }
}

/* ============================================================================
   R-13.1 — Scope segment control inside Lernmodus card
   ============================================================================ */

.civ-mode-column {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.civ-scope-segment {
  padding: 8px 12px 10px;
  background: var(--cream-50);
  border: 1px solid rgba(11,24,52,0.10);
  border-radius: var(--r-lg);
}

.civ-scope-segment__label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--navy-500);
  margin-bottom: 6px;
}

.civ-scope-segment__buttons {
  display: flex;
  gap: 4px;
}

.civ-scope-segment__button {
  flex: 1;
  padding: 5px 8px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(11,24,52,0.16);
  background: transparent;
  color: var(--navy-700);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  font-weight: 500;
  cursor: pointer;
  transition: all var(--dur-quick) ease;
  white-space: nowrap;
}

.civ-scope-segment__button:hover:not(:disabled) {
  border-color: var(--navy-400);
  background: var(--navy-50);
}

.civ-scope-segment__button.civ-is-active {
  background: var(--navy-900);
  color: var(--cream-50);
  border-color: var(--navy-900);
}

.civ-scope-segment__button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  background: transparent;
  color: var(--navy-400);
}

.civ-scope-segment__button--star:disabled {
  opacity: 0.55;
}

.civ-scope-segment__hint {
  margin: 6px 0 0;
  font-size: 10px;
  color: var(--navy-500);
  font-style: italic;
  line-height: 1.35;
}

/* ============================================================================
   R-13.2 — Bookmark star toggle on quiz card
   ============================================================================ */

.civ-bookmark-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(11,24,52,0.14);
  background: transparent;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  color: var(--navy-400);
  padding: 0;
  flex: none;
  transition: all var(--dur-quick);
  margin-left: auto;
}

.civ-bookmark-btn:hover {
  border-color: var(--brass-500);
  color: var(--brass-500);
}

.civ-bookmark-btn--active {
  border-color: var(--brass-500);
  color: var(--brass-500);
  background: var(--brass-50);
}

.civ-bookmark-btn:focus-visible {
  outline: 2px solid var(--navy-500);
  outline-offset: 2px;
}