/* 
 * ANIMAZIONI DINAMICHE ALLO SCROLL (Stile Wix/GSAP) 
 * Implementate tramite IntersectionObserver e classi CSS native.
 */

/* Stato base per elementi che devono animarsi */
.reveal-up,
.reveal-down,
.reveal-left,
.reveal-right,
.reveal-fade,
.reveal-scale {
    opacity: 0;
    transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: opacity, transform;
}

/* Transformazioni di partenza */
.reveal-up {
    transform: translateY(40px);
}
.reveal-down {
    transform: translateY(-40px);
}
.reveal-left {
    transform: translateX(40px);
}
.reveal-right {
    transform: translateX(-40px);
}
.reveal-fade {
    transform: scale(0.98);
}
.reveal-scale {
    transform: scale(0.85);
}

/* Stato attivo quando l'elemento entra nella viewport */
.is-revealed {
    opacity: 1 !important;
    transform: translate(0, 0) scale(1) !important;
}

/* Delay helpers per stagger effect */
.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }
.delay-400 { transition-delay: 400ms; }
.delay-500 { transition-delay: 500ms; }

/* Parallax Container e Element */
.parallax-container {
    position: relative;
    overflow: hidden;
}

.parallax-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 130%; /* Altezza extra per lo scrolling */
    object-fit: cover;
    z-index: -1;
    will-change: transform;
    /* La transizione è disabilitata sul parallax per evitare juddering */
    transition: none; 
}

/* --- VIEW TRANSITIONS API (Cross-document) --- */
/* Abilita transizioni di pagina fluide tra tutte le pagine dello stesso sito (Chrome 126+) */
@view-transition {
    navigation: auto;
}
