/* Quiz Runner Layout */
.quiz-container {
  max-width: 720px;
  margin: 0 auto;
}

/* Quiz Config */
.quiz-config {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  padding: var(--space-2xl);
}

.quiz-config__form {
  display: grid;
  gap: var(--space-lg);
}

.form-group label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-sm);
}

.form-group select,
.form-group input {
  width: 100%;
  padding: 0.625rem var(--space-md);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  color: var(--color-text);
  transition: border-color var(--transition-fast);
}

.form-group select:focus,
.form-group input:focus {
  outline: none;
  border-color: var(--color-primary);
}

/* Toggle switch */
.toggle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.toggle__input {
  appearance: none;
  width: 44px;
  height: 24px;
  background: var(--color-border);
  border-radius: var(--radius-full);
  position: relative;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.toggle__input::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: white;
  border-radius: 50%;
  transition: transform var(--transition-fast);
  box-shadow: var(--shadow-sm);
}

.toggle__input:checked {
  background: var(--color-primary);
}

.toggle__input:checked::after {
  transform: translateX(20px);
}

.toggle__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* Quiz Active State */
.quiz-active {
  position: relative;
  overflow: hidden;
}

.quiz-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
}

.quiz-counter {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
}

.quiz-timer {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  font-family: var(--font-mono);
}

.quiz-timer.warning {
  color: var(--color-warning);
}

.quiz-timer.danger {
  color: var(--color-danger);
  animation: pulse 1s ease infinite;
}

/* Timer Ring SVG */
.timer-ring {
  width: 48px;
  height: 48px;
}

.timer-ring__bg {
  fill: none;
  stroke: var(--color-border-light);
  stroke-width: 3;
}

.timer-ring__progress {
  fill: none;
  stroke: var(--color-accent);
  stroke-width: 3;
  stroke-linecap: round;
  transform: rotate(-90deg);
  transform-origin: center;
  transition: stroke-dashoffset 1s linear, stroke 0.5s;
}

.timer-ring__progress.warning {
  stroke: var(--color-warning);
}

.timer-ring__progress.danger {
  stroke: var(--color-danger);
}

/* Question */
.quiz-question {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  padding: var(--space-2xl);
  margin-bottom: var(--space-lg);
}

.quiz-question__text {
  font-size: var(--text-lg);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  margin-bottom: var(--space-xl);
  line-height: var(--leading-relaxed);
}

.quiz-question__topic {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Answer choices */
.quiz-choices {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.quiz-choice {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  text-align: left;
  width: 100%;
}

.quiz-choice:hover:not(.disabled) {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

.quiz-choice.selected {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

.quiz-choice.correct {
  border-color: var(--color-accent);
  background: var(--color-accent-bg);
}

.quiz-choice.incorrect {
  border-color: var(--color-danger);
  background: var(--color-danger-bg);
  animation: shake 0.5s ease;
}

.quiz-choice.disabled {
  cursor: default;
  opacity: 0.7;
}

.quiz-choice__letter {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-border-light);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  flex-shrink: 0;
  transition: all var(--transition-fast);
}

.quiz-choice.selected .quiz-choice__letter {
  background: var(--color-primary);
  color: white;
}

.quiz-choice.correct .quiz-choice__letter {
  background: var(--color-accent);
  color: white;
}

.quiz-choice.incorrect .quiz-choice__letter {
  background: var(--color-danger);
  color: white;
}

/* Explanation */
.quiz-explanation {
  margin-top: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-primary-bg);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--color-primary);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  animation: fadeSlideUp 0.3s ease;
}

/* Flag button */
.quiz-flag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: var(--font-sans);
}

.quiz-flag:hover,
.quiz-flag.flagged {
  background: var(--color-warning-bg);
  border-color: var(--color-warning);
  color: var(--color-warning);
}

/* Navigation */
.quiz-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-xl);
}

/* Progress dots */
.quiz-progress {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: var(--space-lg);
}

.quiz-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-border);
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
  padding: 0;
}

.quiz-dot.current {
  background: var(--color-primary);
  transform: scale(1.3);
}

.quiz-dot.answered {
  background: var(--color-primary-light);
}

.quiz-dot.correct {
  background: var(--color-accent);
}

.quiz-dot.incorrect {
  background: var(--color-danger);
}

.quiz-dot.flagged {
  box-shadow: 0 0 0 2px var(--color-warning);
}

/* Results */
.quiz-results {
  text-align: center;
}

.quiz-score {
  font-size: var(--text-5xl);
  font-weight: var(--weight-bold);
  margin: var(--space-lg) 0;
}

.quiz-score.pass {
  color: var(--color-accent);
}

.quiz-score.fail {
  color: var(--color-danger);
}

.quiz-result-label {
  display: inline-block;
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-full);
  font-weight: var(--weight-semibold);
  font-size: var(--text-lg);
  margin-bottom: var(--space-xl);
}

.quiz-result-label.pass {
  background: var(--color-accent-bg);
  color: var(--color-accent-dark);
}

.quiz-result-label.fail {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

/* Topic breakdown */
.topic-breakdown {
  text-align: left;
  margin-top: var(--space-xl);
}

.topic-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
}

.topic-row__name {
  flex: 0 0 200px;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  text-align: right;
}

.topic-row__bar {
  flex: 1;
  height: 24px;
  background: var(--color-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
}

.topic-row__fill {
  height: 100%;
  border-radius: var(--radius-md);
  transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  padding-left: var(--space-sm);
}

.topic-row__fill.good { background: var(--color-accent); }
.topic-row__fill.ok { background: var(--color-warning); }
.topic-row__fill.poor { background: var(--color-danger); }

.topic-row__score {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: white;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .topic-row {
    flex-direction: column;
    align-items: stretch;
  }

  .topic-row__name {
    text-align: left;
    flex: none;
  }
}

/* ===== Mobile Form Fixes ===== */
@media (max-width: 768px) {
  /* Prevent iOS auto-zoom on focus by ensuring 16px minimum */
  .form-group select,
  .form-group input {
    font-size: max(var(--text-base), 16px);
    padding: 0.75rem var(--space-md);
    border-radius: var(--radius-lg);
  }

  /* Larger touch area for toggle */
  .toggle {
    min-height: var(--touch-target-min);
    padding: var(--space-xs) 0;
  }

  .toggle__input {
    width: 52px;
    height: 28px;
  }

  .toggle__input::after {
    width: 24px;
    height: 24px;
  }

  .toggle__input:checked::after {
    transform: translateX(24px);
  }

  /* Quiz config layout: more spacing */
  .quiz-config {
    padding: var(--space-lg);
  }

  .quiz-config__form {
    gap: var(--space-xl);
  }

  /* Full-width start button */
  .quiz-config .btn-lg {
    width: 100%;
    justify-content: center;
    padding: var(--space-md) var(--space-lg);
    font-size: var(--text-base);
    min-height: 48px;
  }

  /* Quiz question padding */
  .quiz-question {
    padding: var(--space-lg);
  }

  /* Touch-friendly quiz dots */
  .quiz-dot {
    position: relative;
  }

  .quiz-dot::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: var(--touch-target-min);
    height: var(--touch-target-min);
  }

  /* Quiz choice touch targets */
  .quiz-choice {
    padding: var(--space-md);
    min-height: var(--touch-target-min);
  }

  /* Quiz flag touch target */
  .quiz-flag {
    min-height: var(--touch-target-min);
    padding: var(--space-sm) var(--space-lg);
  }
}
