/* =============================================================================
   Wegwijs met AI — Component Library (Handoff)
   =============================================================================
   Herbruikbare UI-klassen, gedistilleerd uit de design-system preview-kaarten.
   Alle tokens komen uit tokens.css (laad dat eerst).

   Volgorde:
   1. Buttons
   2. Forms (input, textarea, select, checkbox-card, toggle)
   3. Badges & chips (level, status, lesson-type, reward)
   4. Cards (generic, continue-card, lesson-row)
   5. Progress (bar, ring)
   6. Quiz feedback (correct / almost — niet-bestraffend)
   7. Utilities (.sr-only, .reading-max, focus ring helpers)

   BELANGRIJK:
   - Gebruik __geen__ hover-lift op knoppen (minder animatie-ruis tijdens leren).
   - Minimum 44px hoogte op alle interactieve elementen (touch-target).
   - Focus-ring zichtbaar op alle varianten (keyboard-nav voor senioren).
   ============================================================================= */


/* =============================================================================
   1. BUTTONS
   ============================================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 44px;
  padding: 0 var(--space-5);
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  letter-spacing: -0.005em;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background var(--transition-fast),
              border-color var(--transition-fast),
              color var(--transition-fast),
              box-shadow var(--transition-fast);
}
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(79,70,229,0.45); }
.btn svg { flex-shrink: 0; }

.btn-primary { background: var(--brand-primary); color: #fff; border-color: var(--brand-primary); }
.btn-primary:hover  { background: var(--brand-primary-hover); border-color: var(--brand-primary-hover); box-shadow: 0 2px 6px rgba(79,70,229,0.18); }
.btn-primary:active { background: #3730a3; border-color: #3730a3; box-shadow: none; }

.btn-secondary { background: #fff; color: var(--fg1); border-color: #94a3b8; }
.btn-secondary:hover  { background: var(--surface-subtle); border-color: var(--fg3); }
.btn-secondary:active { background: var(--surface-bg); }

.btn-ghost { background: transparent; color: var(--fg3); border-color: transparent; }
.btn-ghost:hover { background: var(--surface-bg); color: var(--fg1); }
.btn-ghost:focus-visible { box-shadow: 0 0 0 3px rgba(79,70,229,0.35); }

.btn-success { background: #059669; color: #fff; border-color: #059669; }
.btn-success:hover { background: #047857; border-color: #047857; }
.btn-success:focus-visible { box-shadow: 0 0 0 3px rgba(5,150,105,0.4); }

.btn-danger { background: #dc2626; color: #fff; border-color: #dc2626; }
.btn-danger:hover { background: #b91c1c; border-color: #b91c1c; }
.btn-danger:focus-visible { box-shadow: 0 0 0 3px rgba(220,38,38,0.4); }

.btn-sm  { min-height: 36px; padding: 0 var(--space-3) 0 var(--space-3); font-size: var(--font-size-sm); border-radius: 6px; gap: 6px; }
.btn-lg  { min-height: 52px; padding: 0 var(--space-6); font-size: var(--font-size-base); border-radius: 10px; gap: 10px; }
.btn-block { width: 100%; }

.btn-icon { width: 44px; padding: 0; }
.btn-sm.btn-icon { width: 36px; }

.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.45; cursor: not-allowed; box-shadow: none !important; pointer-events: none;
}

/* Spinner (gebruik in loading-state: <span class="btn-spinner"></span>) */
.btn-spinner {
  width: 14px; height: 14px;
  border: 2px solid currentColor; border-right-color: transparent;
  border-radius: 999px;
  animation: wm-spin 600ms linear infinite;
}
@keyframes wm-spin { to { transform: rotate(360deg); } }


/* =============================================================================
   2. FORMS
   ============================================================================= */
.form-group { margin-bottom: 14px; }
.form-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--fg2);
  margin-bottom: 6px;
}
.form-label .req { color: var(--color-error); margin-left: 2px; }
.form-label .opt { font-weight: 500; color: var(--fg4); margin-left: 6px; font-size: var(--font-size-xs); }

.input, .form-select, .form-textarea {
  display: block; width: 100%; box-sizing: border-box;
  padding: 10px 14px;
  font-family: inherit; font-size: var(--font-size-base); line-height: 1.4;
  color: var(--fg1);
  background: var(--surface-input);
  border: 1px solid var(--border-strong); border-radius: var(--radius-md);
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
}
.input::placeholder, .form-textarea::placeholder { color: var(--fg4); }
.input:hover, .form-select:hover, .form-textarea:hover { border-color: #94a3b8; }
.input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px rgba(79,70,229,0.18);
}
.input:disabled, .form-select:disabled, .form-textarea:disabled {
  background: var(--surface-subtle); color: var(--fg4); cursor: not-allowed;
  border-color: var(--border-default);
}
.form-textarea { min-height: 84px; resize: vertical; }

.input.is-error, .form-textarea.is-error { border-color: var(--color-error); }
.input.is-error:focus { box-shadow: 0 0 0 3px rgba(239,68,68,0.18); }
.input.is-success { border-color: var(--color-success); }
.input.is-success:focus { box-shadow: 0 0 0 3px rgba(16,185,129,0.18); }

.form-help {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--font-size-xs); color: var(--fg3); margin-top: 6px;
}
.form-help.err { color: var(--color-error); }
.form-help.ok  { color: #059669; }

/* Select chevron */
.form-select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  padding-right: 36px;
}

/* Checkbox/radio cards */
.check {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--border-default); border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
}
.check:hover { border-color: var(--border-strong); background: #fafbff; }
.check input { margin: 0; accent-color: var(--brand-primary); width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; }
.check.sel { border-color: var(--brand-primary); background: var(--brand-primary-light); }
.check-body .t { font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); color: var(--fg1); }
.check-body .d { font-size: var(--font-size-xs); color: var(--fg3); margin-top: 2px; }

/* Toggle */
.toggle-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--border-default); border-radius: var(--radius-md);
}
.toggle { position: relative; width: 38px; height: 22px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle .slider {
  position: absolute; inset: 0;
  background: var(--border-strong); border-radius: 999px;
  transition: background 150ms; cursor: pointer;
}
.toggle .slider::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px; border-radius: 999px;
  background: #fff; transition: transform 150ms;
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}
.toggle input:checked + .slider { background: var(--brand-primary); }
.toggle input:checked + .slider::after { transform: translateX(16px); }


/* =============================================================================
   3. BADGES & CHIPS
   ============================================================================= */
/* Niveau */
.badge-level {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
}
.badge-level .dot { width: 6px; height: 6px; border-radius: 999px; }
.badge-level.beginner { background: #ecfdf5; color: #047857; }
.badge-level.beginner .dot { background: var(--color-success); }
.badge-level.middle   { background: #fffbeb; color: #b45309; }
.badge-level.middle .dot { background: var(--brand-accent); }
.badge-level.advanced { background: #fef2f2; color: #b91c1c; }
.badge-level.advanced .dot { background: var(--color-error); }

/* Les-status */
.badge-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px 3px 5px; border-radius: 999px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
}
.badge-status svg { width: 14px; height: 14px; }
.badge-status.done   { background: var(--color-success-light); color: #065f46; padding: 3px 9px; }
.badge-status.active { background: var(--brand-primary-light); color: var(--brand-primary-hover); }
.badge-status.active .adot { width: 6px; height: 6px; border-radius: 999px; background: var(--brand-primary); margin: 0 3px 0 4px; }
.badge-status.locked { background: var(--surface-bg); color: var(--fg4); }
.badge-status.new    { background: #fce7f3; color: #9d174d; padding: 3px 9px; }

/* Lestype — principe #9: vaste kleur per type */
.badge-type {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px 3px 5px; border-radius: 6px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  background: var(--surface-bg); color: var(--fg3);
}
.badge-type svg { width: 14px; height: 14px; }
.badge-type.video { background: #eff6ff; color: #1d4ed8; }
.badge-type.quiz  { background: var(--brand-accent-light); color: #92400e; }
.badge-type.text  { background: var(--surface-bg); color: var(--fg3); }
.badge-type.live  { background: #fee2e2; color: #991b1b; }

/* Rewards / gamification */
.badge-reward {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px 5px 7px; border-radius: 999px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  border: 1px solid;
}
.badge-reward svg { width: 16px; height: 16px; }
.badge-reward.streak { background: #fff7ed; color: #9a3412; border-color: #fed7aa; }
.badge-reward.xp     { background: #fffbeb; color: #92400e; border-color: #fde68a; }
.badge-reward.cert   { background: #f5f3ff; color: #6d28d9; border-color: #ddd6fe; }

/* Catalogus-filters */
.filter-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px 7px 10px; border-radius: 999px;
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  background: #fff; color: var(--fg2);
  border: 1px solid var(--border-default);
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.filter-chip svg { width: 18px; height: 18px; }
.filter-chip:hover { border-color: var(--border-strong); }
.filter-chip.active {
  background: var(--brand-primary-light);
  color: #312e81;
  border-color: var(--brand-primary-muted);
  font-weight: var(--font-weight-semibold);
}
.filter-chip .count {
  background: var(--surface-bg); color: var(--fg3);
  padding: 1px 7px; border-radius: 999px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
}
.filter-chip.active .count { background: var(--brand-primary-muted); color: #312e81; }


/* =============================================================================
   4. CARDS
   ============================================================================= */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

/* Continue-card — dashboard hero. Principe #1: voortgang is hoofdpersoon. */
.continue-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: 14px;
  padding: var(--space-6);
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: var(--space-5);
  align-items: center;
  box-shadow: var(--shadow-sm);
}
.continue-card .thumb {
  width: 64px; height: 64px; border-radius: 12px;
  background: var(--brand-primary-light);
  display: flex; align-items: center; justify-content: center;
}
.continue-card .eyebrow {
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg3);
  margin-bottom: 10px;
}
.continue-card .title {
  font-size: 17px; font-weight: var(--font-weight-semibold); color: var(--fg1);
  margin-bottom: 10px; letter-spacing: -0.01em; line-height: 1.35;
}
.continue-card .meta {
  font-size: var(--font-size-xs); color: var(--fg3);
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.continue-card .meta .sep { opacity: 0.5; }

/* Lesson-row — lijst-item in cursus-sidebar. Principe #9 + #7. */
.lesson-list {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-2);
  box-shadow: var(--shadow-sm);
}
.lesson-row {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  min-height: 56px;  /* touch-target */
}
.lesson-row + .lesson-row { border-top: 1px solid var(--surface-bg); }
.lesson-row:hover { background: var(--surface-subtle); }
.lesson-row.active { background: var(--brand-primary-light); }
.lesson-row.done .title { color: var(--fg3); }
.lesson-row.locked { opacity: 0.55; cursor: not-allowed; }

.lesson-row .chip {
  width: 36px; height: 36px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.lesson-row .chip.video { background: var(--brand-primary-light); }
.lesson-row .chip.text  { background: var(--surface-bg); }
.lesson-row .chip.quiz  { background: var(--brand-accent-light); }
.lesson-row .chip.live  { background: #fce7f3; }

.lesson-row .body { flex: 1; min-width: 0; }
.lesson-row .title {
  font-size: var(--font-size-md); font-weight: var(--font-weight-medium);
  color: var(--fg1); margin: 0;
}
.lesson-row.active .title { color: var(--brand-primary); font-weight: var(--font-weight-semibold); }
.lesson-row .meta {
  font-size: var(--font-size-xs); color: var(--fg3); margin-top: 2px;
  display: inline-flex; align-items: center; gap: 5px;
}


/* =============================================================================
   5. PROGRESS
   ============================================================================= */
.progress-bar {
  background: var(--border-default);
  border-radius: 9999px;
  height: 6px;
  overflow: hidden;
}
.progress-bar > .fill {
  background: var(--color-success);
  height: 100%; border-radius: 9999px;
  transition: width 400ms var(--ease-out);
}
.progress-bar.indigo > .fill { background: var(--brand-primary); }

/* Progress ring — gebruik als: <div class="progress-ring" data-pct="65"> ... </div>
   met inline SVG. Styling voor voorkeur-kleuren. */
.progress-ring { position: relative; display: inline-block; }
.progress-ring svg { transform: rotate(-90deg); display: block; }
.progress-ring .ring-bg { stroke: var(--border-default); fill: none; }
.progress-ring .ring-fg {
  fill: none;
  stroke: var(--brand-primary);
  stroke-linecap: round;
  transition: stroke-dashoffset 400ms var(--ease-out);
}
.progress-ring.done .ring-fg { stroke: var(--color-success); }
.progress-ring .ring-label {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-weight: var(--font-weight-bold); color: var(--fg1);
}


/* =============================================================================
   6. QUIZ FEEDBACK — principe #3 (niet-bestraffend, amber i.p.v. rood)
   ============================================================================= */
.quiz-question {
  font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold);
  color: var(--fg1); margin-bottom: 14px; line-height: 1.4;
}
.quiz-option {
  display: flex; align-items: center; gap: var(--space-3);
  padding: 14px var(--space-4);
  border: 1.5px solid var(--border-default); border-radius: 10px;
  font-size: var(--font-size-base); color: var(--fg1);
  min-height: 52px;
  background: #fff;
  margin-bottom: var(--space-2);
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.quiz-option:hover { border-color: var(--border-strong); }
.quiz-option .letter {
  width: 26px; height: 26px; border-radius: 9999px;
  background: var(--surface-bg); color: var(--fg2);
  display: flex; align-items: center; justify-content: center;
  font-weight: var(--font-weight-semibold); font-size: var(--font-size-xs);
  flex-shrink: 0;
}
.quiz-option .status {
  margin-left: auto; font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  display: inline-flex; align-items: center; gap: 4px;
}

.quiz-option.correct { border-color: var(--color-success); }
.quiz-option.correct .letter { background: var(--color-success); color: #fff; }
.quiz-option.correct .status { color: #047857; }

/* AMBER voor "fout" — niet rood. Rood is alleen voor echte errors. */
.quiz-option.almost { border-color: var(--brand-accent); }
.quiz-option.almost .letter { background: var(--brand-accent); color: #fff; }
.quiz-option.almost .status { color: #b45309; }

.quiz-explanation {
  background: #fff;
  border: 1px solid var(--border-default);
  border-left: 3px solid transparent;
  border-radius: var(--radius-md);
  padding: var(--space-3) 14px;
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
  line-height: 1.55;
  color: var(--fg2);
}
.quiz-explanation.correct { border-left-color: var(--color-success); }
.quiz-explanation.almost  { border-left-color: var(--brand-accent); }
.quiz-explanation strong {
  display: block; color: var(--fg1);
  margin-bottom: 2px; font-weight: var(--font-weight-semibold);
}


/* =============================================================================
   7. UTILITIES
   ============================================================================= */

/* Lees-breedte — principe #8: max 680px voor lestekst */
.reading-max {
  max-width: var(--content-reading-max);
  margin-left: auto;
  margin-right: auto;
}

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

/* Skip-to-content link — toegankelijkheid */
.skip-to-content {
  position: absolute; top: -40px; left: 8px;
  background: var(--brand-primary); color: #fff;
  padding: 8px 16px; border-radius: var(--radius-md);
  text-decoration: none; font-weight: var(--font-weight-semibold);
  z-index: 10000;
  transition: top var(--transition-fast);
}
.skip-to-content:focus { top: 8px; }

/* Focus-ring helper voor custom interactieve elementen */
.focus-ring:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.45);
  border-radius: var(--radius-md);
}
