/* ═══════════════════════════════════════════════════════════════
   SOLONAS Animations — Scroll-reveal + micro-interactions
   ═══════════════════════════════════════════════════════════════ */

/* ── Scroll-triggered reveal ───────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--duration-slow) var(--ease-out),
              transform var(--duration-slow) var(--ease-out);
}

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

/* Staggered delays */
[data-reveal="delay-1"] { transition-delay: 0.1s; }
[data-reveal="delay-2"] { transition-delay: 0.2s; }
[data-reveal="delay-3"] { transition-delay: 0.3s; }
[data-reveal="delay-4"] { transition-delay: 0.4s; }

/* ── Hero entrance ─────────────────────────────────────── */
.hero-fade-in {
  opacity: 0;
  transform: translateY(20px);
  animation: heroFadeIn 0.8s var(--ease-out) forwards;
}

.hero-fade-in-delay-1 { animation-delay: 0.15s; }
.hero-fade-in-delay-2 { animation-delay: 0.3s; }
.hero-fade-in-delay-3 { animation-delay: 0.5s; }

@keyframes heroFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Reduced motion ────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  .hero-fade-in {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
  }
}
