@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scale(1.1); /* ligero zoom */
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.animate-fadeIn {
  animation: fadeIn 1.2s ease-out forwards;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.animate-fadeInUp {
  animation: fadeInUp 0.8s ease-out 1s forwards;
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-40px) scale(0.9);
  }
  to {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

@keyframes fadeInLeftScale {
  from {
    opacity: 0;
    transform: translateX(-400px) scale(0);
  }
  to {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

.animate-fadeInLeftScale {
  animation: fadeInLeftScale 0.9s ease-out 0.3s forwards;
  /* duración: 0.9s, delay: 0.3s */
}

@keyframes fadeInRightScale {
  from {
    opacity: 0;
    transform: translateX(400px) scale(0); /* empieza a la derecha y tamaño 0 */
  }
  to {
    opacity: 1;
    transform: translateX(0) scale(1); /* posición final y tamaño normal */
  }
}

.animate-fadeInRightScale {
  animation: fadeInRightScale 0.9s ease-out 0.3s forwards;
}
