/* ===== ANIMATION BASE ===== */
[data-animate] {
  opacity: 0;
  transition: opacity 0.7s ease, transform 0.7s ease;
  will-change: opacity, transform;
}

[data-animate="fade-up"]    { transform: translateY(40px); }
[data-animate="fade-left"]  { transform: translateX(-50px); }
[data-animate="fade-right"] { transform: translateX(50px); }
[data-animate="fade-in"]    { transform: scale(0.96); }
[data-animate="zoom-in"]    { transform: scale(0.85); }

[data-animate].visible {
  opacity: 1;
  transform: translate(0) scale(1);
}

/* Stagger delays for grid children */
[data-animate][data-delay="1"] { transition-delay: 0.1s; }
[data-animate][data-delay="2"] { transition-delay: 0.2s; }
[data-animate][data-delay="3"] { transition-delay: 0.3s; }
[data-animate][data-delay="4"] { transition-delay: 0.4s; }
[data-animate][data-delay="5"] { transition-delay: 0.5s; }
[data-animate][data-delay="6"] { transition-delay: 0.6s; }

/* ===== HERO LOAD ANIMATIONS ===== */
.hero-badge {
  opacity: 0;
  transform: translateY(-20px);
  animation: slideDown 0.6s ease 0.2s forwards;
}
.hero-content h1 {
  opacity: 0;
  transform: translateX(-40px);
  animation: slideRight 0.8s ease 0.4s forwards;
}
.hero-sub {
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.7s ease 0.6s forwards;
}
.hero-btns {
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.7s ease 0.8s forwards;
}
.hero-reassurance {
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.7s ease 1.0s forwards;
}

@keyframes slideDown {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideRight {
  to { opacity: 1; transform: translateX(0); }
}
@keyframes slideUp {
  to { opacity: 1; transform: translateY(0); }
}

/* ===== FLOATING WHATSAPP PULSE ===== */
.whatsapp-float {
  animation: pulse 2.5s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4); }
  50%       { box-shadow: 0 4px 32px rgba(37, 211, 102, 0.8); }
}
