/* ============================================
   MADHVAN — ANIMATIONS
   ============================================ */

/* ---- REVEAL ANIMATIONS ---- */
.reveal-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal-up.visible,
.reveal-left.visible {
  opacity: 1;
  transform: translate(0);
}

/* Stagger delays for grid children */
.features-grid .feature-card:nth-child(1) { transition-delay: 0s; }
.features-grid .feature-card:nth-child(2) { transition-delay: 0.1s; }
.features-grid .feature-card:nth-child(3) { transition-delay: 0.2s; }
.features-grid .feature-card:nth-child(4) { transition-delay: 0.3s; }
.features-grid .feature-card:nth-child(5) { transition-delay: 0.4s; }
.features-grid .feature-card:nth-child(6) { transition-delay: 0.5s; }

.rooms-grid .room-card:nth-child(1) { transition-delay: 0s; }
.rooms-grid .room-card:nth-child(2) { transition-delay: 0.15s; }
.rooms-grid .room-card:nth-child(3) { transition-delay: 0.3s; }

.exp-grid .exp-card:nth-child(1) { transition-delay: 0s; }
.exp-grid .exp-card:nth-child(2) { transition-delay: 0.1s; }
.exp-grid .exp-card:nth-child(3) { transition-delay: 0.2s; }
.exp-grid .exp-card:nth-child(4) { transition-delay: 0.3s; }

.gallery-masonry .gm-item:nth-child(1) { transition-delay: 0s; }
.gallery-masonry .gm-item:nth-child(2) { transition-delay: 0.08s; }
.gallery-masonry .gm-item:nth-child(3) { transition-delay: 0.16s; }
.gallery-masonry .gm-item:nth-child(4) { transition-delay: 0.24s; }
.gallery-masonry .gm-item:nth-child(5) { transition-delay: 0.32s; }
.gallery-masonry .gm-item:nth-child(6) { transition-delay: 0.40s; }

/* Hero content stagger */
.hero-tag    { transition-delay: 0.3s; }
.hero-title  { transition-delay: 0.5s; }
.hero-desc   { transition-delay: 0.7s; }
.hero-ctas   { transition-delay: 0.9s; }

/* Page load auto-trigger for hero */
@keyframes heroReveal {
  to { opacity: 1; transform: translateY(0); }
}
.hero .reveal-up {
  animation: heroReveal 0.8s ease forwards;
}
