/* Anime.js Specific Utility Classes */

/* Hides elements initially before they are revealed by Anime.js via IntersectionObserver */
.anime-hidden {
    opacity: 0;
    visibility: hidden;
}

/* Ensure the transform origin is correct for scaling effects */
.anime-scale-hover {
    transform-origin: center center;
    will-change: transform;
}

/* Custom underline animation wrapper */
.anime-link-underline {
    position: relative;
    text-decoration: none !important;
    display: inline-block;
}

.anime-link-underline::after {
    content: '';
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 1px;
    bottom: 0;
    left: 0;
    background-color: currentColor;
    transform-origin: bottom right;
    transition: transform 0.4s cubic-bezier(0.86, 0, 0.07, 1);
}

.anime-link-underline:hover::after {
    transform: scaleX(1);
    transform-origin: bottom left;
}

/* Base states for cards and buttons before Anime.js overrides */
.anime-btn, .anime-card {
    will-change: transform, box-shadow;
}

/* Ensure smooth sticky navbar transition base */
.luxe-navbar {
    transition: padding 0.5s cubic-bezier(0.25, 1, 0.5, 1), background-color 0.5s ease, box-shadow 0.5s ease;
}

/* Page Transition Overlay */
.page-transition-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--color-champagne); /* Use theme color */
    z-index: 9999;
    pointer-events: none;
    transform-origin: top;
    transform: scaleY(0);
}
