/* ============================================================
   Onboarding Screen — multi-step welcome flow
   ============================================================ */

.screen-onboarding {
  min-height: 100dvh;
  padding: var(--space-8) var(--space-4) var(--space-4);
  padding-bottom: var(--space-4); /* No nav bar during onboarding */
  display: flex;
  flex-direction: column;
}

/* Step container with transition */
.onboarding-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  animation: slideUp var(--duration-slow) var(--ease-out) forwards;
}

.onboarding-step__logo {
  font-family: var(--font-sans);
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  color: var(--brand-gold);
  margin-bottom: var(--space-2);
  letter-spacing: -0.03em;
}

.onboarding-step__logo-semi {
  color: var(--text-muted);
  font-weight: var(--weight-regular);
}

.onboarding-step__title {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-2);
}

.onboarding-step__subtitle {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-8);
}

/* Topics step scrollable area */
.onboarding-step__topics {
  flex: 1;
  overflow-y: auto;
  margin-bottom: var(--space-6);
  padding-right: var(--space-1);
}

/* Fixed bottom actions */
.onboarding-actions {
  position: sticky;
  bottom: 0;
  padding: var(--space-4) 0;
  border-top: 1px solid var(--border-subtle);
  background-color: var(--surface-primary);
  z-index: 10;
}

.onboarding-actions__count {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-bottom: var(--space-3);
}

/* Progress dots */
.onboarding-progress {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}

.onboarding-progress__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--border-default);
  transition: background-color var(--duration-fast) var(--ease-out);
}

.onboarding-progress__dot--active {
  background-color: var(--brand-gold);
}

/* Welcome step hero */
.onboarding-hero {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.onboarding-hero__tagline {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  max-width: 320px;
  margin: 0 auto var(--space-8);
}
