/* ===========================
   PROGRAMAS — ANIMATIONS
   =========================== */

/* Initial hidden state for reveal animations */
[data-reveal="up"].reveal-hidden,
[data-reveal-idx="up"].reveal-hidden,
[data-reveal="left"].reveal-hidden,
[data-reveal="right"].reveal-hidden {
  opacity: 0;
  transform: translateY(30px);
}

[data-reveal="left"].reveal-hidden {
  transform: translateX(-30px);
}

[data-reveal="right"].reveal-hidden {
  transform: translateX(30px);
}

/* Visible state - trigger animation */
[data-reveal="up"].visible {
  animation: fadeInUp 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

[data-reveal-idx="up"].visible {
  animation: fadeInUp 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Fade in from left */
[data-reveal="left"].visible {
  animation: fadeInLeft 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Fade in from right */
[data-reveal="right"].visible {
  animation: fadeInRight 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Stagger delay for multiple elements */
[data-reveal-idx="up"]:nth-child(1).visible { animation-delay: 0.1s; }
[data-reveal-idx="up"]:nth-child(2).visible { animation-delay: 0.2s; }
[data-reveal-idx="up"]:nth-child(3).visible { animation-delay: 0.3s; }
[data-reveal-idx="up"]:nth-child(4).visible { animation-delay: 0.4s; }
[data-reveal-idx="up"]:nth-child(5).visible { animation-delay: 0.5s; }
[data-reveal-idx="up"]:nth-child(6).visible { animation-delay: 0.6s; }

/* Hero animations */
.programas-hero-animate [data-reveal="up"]:nth-child(1).visible {
  animation-delay: 0.2s;
}

.programas-hero-animate [data-reveal="up"]:nth-child(2).visible {
  animation-delay: 0.4s;
}

.programas-hero-animate [data-reveal="up"]:nth-child(3).visible {
  animation-delay: 0.6s;
}

/* Floating animation for blobs */
@keyframes floatBlob1 {
  0%, 100% { transform: translate(0, 0); }
  33% { transform: translate(30px, -50px); }
  66% { transform: translate(-20px, 30px); }
}

@keyframes floatBlob2 {
  0%, 100% { transform: translate(0, 0); }
  33% { transform: translate(-40px, 20px); }
  66% { transform: translate(25px, -35px); }
}

.programas-hero-blob--1 {
  animation: floatBlob1 15s ease-in-out infinite;
}

.programas-hero-blob--2 {
  animation: floatBlob2 18s ease-in-out infinite;
}

/* Keyframes for reveal animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
