/* ==========================================================
   KLACHT-MATCHER · quiz-specifiek
   ========================================================== */

#km-app {
  max-inline-size: 640px;
  margin-inline: auto;
}

/* ── Progress ── */
.km-progress {
  position: relative;
  block-size: 28px;
  margin-block-end: var(--sp-5);
  background: var(--bg-soft);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.km-progress__bar {
  block-size: 100%;
  background: linear-gradient(90deg, var(--brand), var(--c-blue-600));
  border-radius: var(--r-pill);
  transition: inline-size var(--dur-slow) var(--ease-out-expo);
}
.km-progress__label {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text);
  mix-blend-mode: difference;
  filter: invert(1);
}

/* ── Card ── */
.km-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: clamp(var(--sp-5), 4vw, var(--sp-8));
  box-shadow: var(--shadow-md);
}

.km-q {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin-block-end: var(--sp-6);
}

/* ── Options ── */
.km-opts {
  display: grid;
  gap: var(--sp-3);
}
.km-opt {
  display: grid;
  grid-template-columns: 40px 1fr 24px;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  background: var(--surface);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-lg);
  font-family: var(--font-body);
  font-size: var(--text-md);
  color: var(--text);
  text-align: start;
  cursor: pointer;
  transition:
    border-color var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out),
    transform var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.km-opt:hover,
.km-opt:focus-visible {
  border-color: var(--brand);
  background: var(--brand-weak);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.km-opt:active { transform: scale(0.98); }

.km-opt__icon {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--brand);
  inline-size: 40px;
  text-align: center;
}
.km-opt__label {
  font-weight: var(--fw-medium);
  line-height: var(--leading-snug);
}
.km-opt__arrow {
  color: var(--text-dim);
  transition: transform var(--dur-fast), color var(--dur-fast);
}
.km-opt:hover .km-opt__arrow,
.km-opt:focus-visible .km-opt__arrow {
  transform: translateX(4px);
  color: var(--brand);
}

/* ── Back-button ── */
.km-back {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  margin-block-start: var(--sp-5);
  padding: var(--sp-2) var(--sp-3);
  background: transparent;
  color: var(--text-dim);
  font-size: var(--text-sm);
  cursor: pointer;
  border-radius: var(--r-sm);
  transition: color var(--dur-fast);
}
.km-back:hover { color: var(--brand); }

/* ── Result ── */
.km-result__eyebrow {
  display: inline-block;
  padding: var(--sp-1) var(--sp-3);
  background: var(--brand-weak);
  color: var(--brand);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-block-end: var(--sp-4);
}
.km-result__title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
}
.km-result__title em {
  color: var(--brand);
  font-style: italic;
}
.km-result__desc {
  font-size: var(--text-md);
  color: var(--text-soft);
  line-height: var(--leading-body);
  margin-block-start: var(--sp-3);
}

.km-result__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--sp-4);
  margin-block: var(--sp-6);
  padding-block: var(--sp-5);
  border-block: 1px solid var(--border);
}
.km-result__meta > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.km-result__meta span {
  font-size: var(--text-xs);
  color: var(--text-dim);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}
.km-result__meta strong {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--text);
}

.km-result__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-block-start: var(--sp-4);
}

.km-result__alt {
  margin-block-start: var(--sp-6);
  padding: var(--sp-4);
  background: var(--bg-soft);
  border-radius: var(--r-md);
}
.km-result__alt small {
  display: block;
  margin-block-end: var(--sp-2);
}
.km-result__alt-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-2) var(--sp-3);
  color: var(--text);
  text-decoration: none;
  border-radius: var(--r-sm);
  transition: background var(--dur-fast);
}
.km-result__alt-link:hover {
  background: var(--surface);
  color: var(--brand);
}
.km-result__alt-link span {
  font-size: var(--text-sm);
  color: var(--text-dim);
}

/* ── Entry animation ── */
.km-card {
  animation: kmFade 420ms var(--ease-out-expo);
}
@keyframes kmFade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .km-card { animation: none; }
  .km-progress__bar { transition: none; }
}
