/* ======================================
   ANIMATIONS - Animações e Efeitos
   ====================================== */

/* Definição de Animações Keyframes */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(60px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-60px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(60px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Classes de Animação Reutilizáveis */

/* Fade In Up - Padrão para elementos que vêm de baixo */
.animate-fadeInUp {
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.animate-fadeInUp.active {
  opacity: 1;
  transform: translateY(0);
}

/* Fade In Down - Para elementos que vêm de cima */
.animate-fadeInDown {
  opacity: 0;
  transform: translateY(-60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.animate-fadeInDown.active {
  opacity: 1;
  transform: translateY(0);
}

/* Fade In Left - Para elementos que vêm da esquerda */
.animate-fadeInLeft {
  opacity: 0;
  transform: translateX(-60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.animate-fadeInLeft.active {
  opacity: 1;
  transform: translateX(0);
}

/* Fade In Right - Para elementos que vêm da direita */
.animate-fadeInRight {
  opacity: 0;
  transform: translateX(60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.animate-fadeInRight.active {
  opacity: 1;
  transform: translateX(0);
}

/* Fade In - Apenas opacidade */
.animate-fadeIn {
  opacity: 0;
  transition: opacity 1s ease-out;
}

.animate-fadeIn.active {
  opacity: 1;
}

/* Scale In - Zoom suave */
.animate-scaleIn {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.animate-scaleIn.active {
  opacity: 1;
  transform: scale(1);
}

/* Suporte para delay - pode ser aplicado via data-delay ou inline */
.animate-delay-1 { transition-delay: 0.1s; }
.animate-delay-2 { transition-delay: 0.2s; }
.animate-delay-3 { transition-delay: 0.3s; }
.animate-delay-4 { transition-delay: 0.4s; }
.animate-delay-5 { transition-delay: 0.5s; }

/* Animação Imediata (para elementos visíveis no primeiro carregamento) */
.animate-immediate {
  animation-duration: 0.8s;
  animation-fill-mode: both;
}

.animate-immediate.animate-fadeInUp {
  animation-name: fadeInUp;
}

.animate-immediate.animate-fadeInDown {
  animation-name: fadeInDown;
}

.animate-immediate.animate-fadeInLeft {
  animation-name: fadeInLeft;
}

.animate-immediate.animate-fadeInRight {
  animation-name: fadeInRight;
}

.animate-immediate.animate-fadeIn {
  animation-name: fadeIn;
}

.animate-immediate.animate-scaleIn {
  animation-name: scaleIn;
}

/* Hover Effects - Efeitos ao passar o mouse */
.animate-hover-lift {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.animate-hover-lift:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.animate-hover-scale {
  transition: transform 0.3s ease;
}

.animate-hover-scale:hover {
  transform: scale(1.05);
}

.animate-hover-color {
  transition: color 0.3s ease;
}

/* Responsividade - Desabilitar animações em conexões lentas */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
