/* Default animation styles */  
.fade-in,
.fade-in-left,
.fade-in-right,
.fade-in-top,
.fade-in-bottom {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 0.8s ease-out;
  will-change: opacity, transform;
}

.fade-in {
  transform: translateY(20px);
}

.fade-in-left {
  transform: translateX(-20px);
}

.fade-in-right {
  transform: translateX(20px);
}

.fade-in-top {
  transform: translateY(-20px);
}

.fade-in-bottom {
  transform: translateY(20px);
}

.animate-in {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
}

/* Accessible: Disable animations for users with reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  .fade-in,
  .fade-in-left,
  .fade-in-right,
  .fade-in-top,
  .fade-in-bottom,
  .animate-in {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}