:root {
    --y: 3.5rem;
    --x: 3.5rem;
}

.reveal--up,
.reveal--left,
.reveal--right,
.reveal--sliding,
.reveal--scale {
    animation-duration: 1ms;
    animation-timing-function: ease;

    animation-timeline: view();
    animation-range: entry 34% cover 100%;
    animation-name: reveal;

    opacity: 0;
}

.reveal--scale {
    animation-name: reveal-scale;
    transform: scale(0.6);
}

.reveal--up {
    --x: 0;
}

.reveal--left,
.reveal--sliding {
    --x: -3.5rem;
    --y: 0;
}

.reveal--right {
    --y: 0;
}

@media (min-width: 992px) {
    .reveal--sliding {
        animation-name: reveal-sliding;
    }
}

@keyframes reveal {
    0% {
        opacity: 0;
        transform: translate3d(var(--x), var(--y), 0);
    }
    40% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    76% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        transform: translate3d(0, -2rem, 0);
    }
}

@keyframes reveal-sliding {
    0% {
        opacity: 0;
        transform: translate3d(var(--x), var(--y), 0);
    }
    13% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    93% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        transform: translate3d(0, -2rem, 0);
    }
}

@keyframes reveal-scale {
    0% {
        opacity: 0;
        transform: scale(0.6);
    }
    40% {
        opacity: 1;
        transform: scale(1);
    }
    76% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        transform: translate3d(0, -2rem, 0);
    }
}

@supports not (animation-timeline: view()) {
    .reveal--up,
    .reveal--left,
    .reveal--right,
    .reveal--sliding,
    .reveal--scale {
        opacity: 1;
        transform: scale(1);
        transform: none;
        animation: none;
    }
}

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