/* Animations des boutons */
.p-btn-animation-border-move {
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.p-btn-animation-border-move::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: all 0.5s ease;
}

.p-btn-animation-border-move:hover::before {
    left: 100%;
}

.p-btn-animation-rollover {
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.p-btn-animation-rollover::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--bloglo-primary);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    z-index: -1;
}

.p-btn-animation-rollover:hover {
    color: #fff;
}

.p-btn-animation-rollover:hover::before {
    transform: translateX(0);
}

/* Animations d'apparition des blocs */
.scroll-animation {
    opacity: 0;
    transition: all 0.6s ease;
}

.scroll-animation.is-visible {
    opacity: 1;
}

.scroll-animation-left {
    transform: translateX(-50px);
    opacity: 0;
    transition: all 0.6s ease;
}

.scroll-animation-right {
    transform: translateX(50px);
    opacity: 0;
    transition: all 0.6s ease;
}

.scroll-animation-zoom {
    transform: scale(0.8);
    opacity: 0;
    transition: all 0.6s ease;
}

.scroll-animation-fade {
    opacity: 0;
    transition: all 0.6s ease;
}

.scroll-animation-left.is-visible,
.scroll-animation-right.is-visible,
.scroll-animation-zoom.is-visible,
.scroll-animation-fade.is-visible {
    transform: translateX(0) scale(1);
    opacity: 1;
} 