/* Scroll reveal animations */
.reveal {
    opacity: 0;
    transform: translateY(2rem);
    transition:
        opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}

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

.reveal-left {
    transform: translateX(-2rem);
}

.reveal-left.is-visible {
    transform: translateX(0);
}

.reveal-right {
    transform: translateX(2rem);
}

.reveal-right.is-visible {
    transform: translateX(0);
}

.reveal-scale {
    transform: translateY(1.5rem) scale(0.96);
}

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

.reveal-stagger {
    transition-delay: calc(var(--reveal-delay, 0) * 90ms);
}

/* Hero load animations (no scroll needed) */
.hero-animate {
    animation: heroFadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.hero-animate-delay-1 {
    animation-delay: 0.15s;
}

.hero-animate-delay-2 {
    animation-delay: 0.3s;
}

.hero-animate-delay-3 {
    animation-delay: 0.45s;
}

@keyframes heroFadeUp {
    from {
        opacity: 0;
        transform: translateY(1.75rem);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Subtle float on hero image overlay */
.hero-bg-zoom {
    animation: heroBgZoom 18s ease-in-out infinite alternate;
}

@keyframes heroBgZoom {
    from {
        transform: scale(1);
    }
    to {
        transform: scale(1.06);
    }
}

@media (prefers-reduced-motion: reduce) {
    .reveal,
    .reveal-left,
    .reveal-right,
    .reveal-scale {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .hero-animate,
    .hero-bg-zoom {
        animation: none;
    }
}

/* Hero banner headings */
.hero-heading__white {
    color: #fff;
}

.hero-heading__muted {
    color: rgba(255, 255, 255, 0.58);
}

.hero-heading {
    display: block;
}
