/* ============================================
   OUT OF THIN AIR — Animations
   ============================================ */

/* === SCROLL REVEAL === */
.reveal {
  opacity: 0; transform: translateY(40px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

.reveal-left {
  opacity: 0; transform: translateX(-60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.22,1,0.36,1);
}
.reveal-left.visible { opacity: 1; transform: translateX(0); }

.reveal-right {
  opacity: 0; transform: translateX(60px);
  transition: opacity 1s ease-out, transform 1s cubic-bezier(0.22,1,0.36,1);
}
.reveal-right.visible { opacity: 1; transform: translateX(0); }

.reveal-scale {
  opacity: 0; transform: scale(0.9);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.reveal-scale.visible { opacity: 1; transform: scale(1); }

/* === STAGGER === */
.stagger.visible > * { opacity: 1; transform: translateY(0); }
.stagger > * {
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.stagger.visible > *:nth-child(1) { transition-delay: 0s; }
.stagger.visible > *:nth-child(2) { transition-delay: 0.08s; }
.stagger.visible > *:nth-child(3) { transition-delay: 0.16s; }
.stagger.visible > *:nth-child(4) { transition-delay: 0.24s; }
.stagger.visible > *:nth-child(5) { transition-delay: 0.32s; }
.stagger.visible > *:nth-child(6) { transition-delay: 0.40s; }
.stagger.visible > *:nth-child(7) { transition-delay: 0.48s; }
.stagger.visible > *:nth-child(8) { transition-delay: 0.56s; }

/* === KEYFRAMES === */
@keyframes shimmer {
  0%, 100% { transform: translateX(-100%); }
  50% { transform: translateX(100%); }
}

@keyframes pulse-dot {
  0%, 100% { transform: scale(1); opacity: 0.7; }
  50% { transform: scale(1.4); opacity: 1; }
}

@keyframes pulse-glow {
  0%, 100% { transform: scale(1); opacity: 0.5; }
  50% { transform: scale(1.1); opacity: 1; }
}

/* === MOBILE — simpler animations === */
@media (max-width: 600px) {
  .reveal-left, .reveal-right {
    transform: translateY(20px) !important;
    transition: opacity 0.5s ease-out, transform 0.5s ease-out !important;
  }
  .reveal-left.visible, .reveal-right.visible {
    transform: translateY(0) !important;
  }
  .reveal { transition-duration: 0.5s !important; }
  .reveal-scale { transition-duration: 0.4s !important; }
  .stagger > * { transition-duration: 0.3s !important; }
}
