/* ============================================================
   components.css — buttons, cards, pills, badges, forms
   Module Six web app
   ============================================================ */

/* ── Buttons ── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: 8px var(--space-4);
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, opacity 0.15s, transform 0.1s;
  white-space: nowrap;
  line-height: 1;
}

.btn:active { transform: scale(0.98); }

.btn--primary {
  background: var(--color-primary);
  color: white;
}

.btn--primary:hover {
  background: var(--color-primary-hover);
  color: white;
  text-decoration: none;
}

.btn--ghost {
  background: transparent;
  color: var(--color-text-secondary);
  border: 0.5px solid var(--color-border-strong);
}

.btn--ghost:hover {
  background: var(--color-bg-subtle);
  color: var(--color-text-primary);
  text-decoration: none;
}

.btn--outline-blue {
  background: transparent;
  color: var(--color-primary);
  border: 0.5px solid var(--color-primary-border);
}

.btn--outline-blue:hover {
  background: var(--color-primary-light);
  text-decoration: none;
}

.btn--sm {
  font-size: var(--font-size-xs);
  padding: 4px 10px;
}

.btn--lg {
  font-size: var(--font-size-md);
  padding: 11px var(--space-6);
}

.btn--full { width: 100%; }

.btn--danger {
  background: var(--color-danger-light);
  color: var(--color-danger);
  border: 0.5px solid #F09595;
}

/* ── Cards ── */

.card {
  background: var(--color-bg-surface);
  border: 0.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.card--bordered-blue {
  border-color: var(--color-primary);
  border-width: 1.5px;
}

.card--subtle {
  background: var(--color-bg-subtle);
  border: 0.5px dashed var(--color-border-strong);
}

/* ── KPI / stat cards ── */

.kpi-card {
  background: var(--color-bg-surface);
  border: 0.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.kpi-card__label {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.kpi-card__value {
  font-size: var(--font-size-3xl);
  font-weight: 500;
  color: var(--color-text-primary);
  line-height: 1;
  margin-bottom: var(--space-1);
}

.kpi-card__sub {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.kpi-card__sub--good    { color: var(--color-primary); }
.kpi-card__sub--warning { color: var(--color-warning); }
.kpi-card__sub--danger  { color: var(--color-danger); }

/* ── Pills and badges ── */

.pill {
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-xs);
  font-weight: 500;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
}

.pill--blue    { background: var(--color-primary-light); color: var(--color-primary); }
.pill--green   { background: var(--color-success-light); color: var(--color-success); }
.pill--amber   { background: var(--color-warning-light); color: var(--color-warning); }
.pill--red     { background: var(--color-danger-light);  color: var(--color-danger); }
.pill--neutral { background: var(--color-bg-subtle); color: var(--color-text-secondary); border: 0.5px solid var(--color-border); }

/* ── Section headers ── */

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.section-header__title {
  font-size: var(--font-size-base);
  font-weight: 500;
  color: var(--color-text-primary);
}

.section-header__link {
  font-size: var(--font-size-xs);
  color: var(--color-primary);
  cursor: pointer;
  background: none;
  border: none;
  font-family: var(--font-sans);
}

/* ── Callout block ── */

.callout {
  border-left: 2px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  background: var(--color-primary-light);
  padding: var(--space-3) var(--space-4);
  margin: var(--space-4) 0;
}

.callout__label {
  font-size: var(--font-size-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  margin-bottom: var(--space-1);
}

.callout__text {
  font-size: var(--font-size-base);
  color: var(--blue-800);
  line-height: 1.65;
}

.callout--warning {
  border-left-color: #EF9F27;
  background: var(--color-warning-light);
}

.callout--warning .callout__label { color: var(--color-warning); }
.callout--warning .callout__text  { color: #78350F; }

/* ── Page header ── */

.page-header {
  margin-bottom: var(--space-5);
}

.page-header__title {
  font-size: var(--font-size-xl);
  font-weight: 500;
  color: var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.page-header__sub {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
}

/* ── Breadcrumb ── */

.breadcrumb {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.breadcrumb a {
  color: var(--color-primary);
}

/* ── Topic status dot ── */

.topic-status {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1.5px solid var(--color-border-strong);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--color-text-hint);
}

.topic-status--done {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
}

.topic-status--current {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* ── Mode toggle ── */

.mode-toggle {
  display: flex;
  border: 0.5px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.mode-toggle__btn {
  font-size: var(--font-size-xs);
  font-weight: 500;
  padding: 5px 14px;
  cursor: pointer;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  font-family: var(--font-sans);
  transition: background 0.15s, color 0.15s;
}

.mode-toggle__btn--active {
  background: var(--color-primary);
  color: white;
}

/* ── Answer options (questions) ── */

.answer-option {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 0.5px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  cursor: pointer;
  background: var(--color-bg-surface);
  transition: border-color 0.15s, background 0.15s;
}

.answer-option:hover {
  border-color: var(--color-border-strong);
}

.answer-option--selected {
  border-color: var(--color-primary);
  border-width: 1.5px;
  background: var(--color-primary-light);
}

.answer-option--correct {
  border-color: var(--color-success);
  border-width: 1.5px;
  background: var(--color-success-light);
}

.answer-option--wrong {
  border-color: var(--color-danger);
  border-width: 1.5px;
  background: var(--color-danger-light);
}

.answer-option__radio {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--color-border-strong);
  flex-shrink: 0;
  margin-top: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
}

.answer-option--selected .answer-option__radio {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
}

.answer-option--correct .answer-option__radio {
  background: var(--color-success);
  border-color: var(--color-success);
  color: white;
}

.answer-option--wrong .answer-option__radio {
  background: var(--color-danger);
  border-color: var(--color-danger);
  color: white;
}

.answer-option__text {
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  line-height: 1.55;
}

/* ── Feedback box ── */

.feedback-box {
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-top: var(--space-4);
}

.feedback-box--correct {
  background: var(--color-success-light);
  border: 0.5px solid #86EFAC;
}

.feedback-box--wrong {
  background: var(--color-primary-light);
  border: 0.5px solid var(--color-primary-border);
}

.feedback-box__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.feedback-box__text {
  font-size: var(--font-size-base);
  line-height: 1.65;
}

.feedback-box--correct .feedback-box__text { color: #14532D; }
.feedback-box--wrong   .feedback-box__text { color: var(--blue-800); }

/* ── Continue card (dashboard) ── */

.continue-card {
  background: var(--color-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.15s;
}

.continue-card:hover { opacity: 0.92; text-decoration: none; }

.continue-card__kicker {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,0.7);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.continue-card__title {
  font-size: var(--font-size-md);
  font-weight: 500;
  color: white;
  margin-bottom: 2px;
}

.continue-card__meta {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,0.65);
}

.continue-card__btn {
  background: white;
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: 8px var(--space-4);
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Module card (dashboard grid) ── */

.module-card {
  background: var(--color-bg-surface);
  border: 0.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  cursor: pointer;
  transition: border-color 0.15s;
  text-decoration: none;
  display: block;
}

.module-card:hover {
  border-color: var(--color-primary);
  text-decoration: none;
}

.module-card--active {
  border-color: var(--color-primary);
  border-width: 1.5px;
}

.module-card__num {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}

.module-card__title {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
  line-height: 1.4;
}

.module-card__meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-top: var(--space-2);
}

.module-card__lock {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-text-hint);
}
