/* Base resets and shared styles */
*, *::before, *::after {
  box-sizing: border-box;
}

/* Form runner animations — used in Phase 3 */
.question-slide-enter {
  opacity: 0;
  transform: translateY(40px);
}
.question-slide-enter-active {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 300ms ease, transform 300ms ease;
}
.question-slide-exit {
  opacity: 1;
  transform: translateY(0);
}
.question-slide-exit-active {
  opacity: 0;
  transform: translateY(-40px);
  transition: opacity 300ms ease, transform 300ms ease;
}
