/**
 * animations.css
 * ──────────────
 * Keyframes + .reveal scroll animation classes.
 * initScrollReveal() in animations.js toggles .is-visible.
 */

@keyframes float {
  0%,
  100% {
    transform: translateY(0) rotateX(2deg) rotateY(-2deg);
  }
  50% {
    transform: translateY(-16px) rotateX(0deg) rotateY(2deg);
  }
}

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

@keyframes revealImage {
  from {
    clip-path: inset(100% 0 0 0);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}

.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity var(--duration) var(--ease), transform var(--duration) var(--ease);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-delay-1 {
  transition-delay: 0.1s;
}

.reveal-delay-2 {
  transition-delay: 0.2s;
}

.reveal-delay-3 {
  transition-delay: 0.3s;
}

.reveal-delay-4 {
  transition-delay: 0.4s;
}

.reveal-image {
  clip-path: inset(100% 0 0 0);
  transition: clip-path 1s var(--ease);
}

.reveal-image.is-visible {
  clip-path: inset(0 0 0 0);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }

  .reveal-image {
    clip-path: none;
  }

  .hero-macbook__float {
    animation: none;
  }
}
