/* GSAP-ready animation utility classes */

/* Initial hidden states (GSAP will animate these) */
.gsap-hidden {
  opacity: 0;
  visibility: hidden;
}

.gsap-from-bottom {
  opacity: 0;
  transform: translateY(40px);
}

.gsap-from-left {
  opacity: 0;
  transform: translateX(-40px);
}

.gsap-from-right {
  opacity: 0;
  transform: translateX(40px);
}

.gsap-scale-in {
  opacity: 0;
  transform: scale(0.92);
}

/* CSS-only fallback animations (when GSAP unavailable or reduced-motion) */
@media (prefers-reduced-motion: no-preference) {
  .anim-fade-up {
    animation: fadeUp 0.7s cubic-bezier(0.4, 0, 0.2, 1) both;
  }

  .anim-fade-up[data-delay="1"] { animation-delay: 0.1s; }
  .anim-fade-up[data-delay="2"] { animation-delay: 0.2s; }
  .anim-fade-up[data-delay="3"] { animation-delay: 0.3s; }
  .anim-fade-up[data-delay="4"] { animation-delay: 0.4s; }
  .anim-fade-up[data-delay="5"] { animation-delay: 0.5s; }
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

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

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

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

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

/* Number counter animation base */
.counter-number {
  display: inline-block;
}

/* Navbar scroll highlight */
.navbar__link.is-current {
  color: var(--verde-claro);
}

/* Page loader eliminado */
