.image-container {
    display: flex;
    position: relative;
    max-width: 400px;
}

.image-container img {
    width: 100%;
    height: auto;
    /* aspect-ratio: 4/3; */
    object-fit: cover;
    object-position: center;
}



.dpg-appear {
    opacity: 0;
    transform: translate(0) scale(0.8);
    transition: opacity .5s ease-out, transform 1.1s ease;
}

.dpg-appear .image-container {
    overflow: hidden;
}

.dpg-border-left {
    border-radius: 38% 4px 4px 4px;
    border-radius: 38% 0 0 0;
}

.dpg-border-round {
    border-radius: 50% 50% 4px 4px;
    border-radius: 50% 50% 0 0;
}

.dpg-border-right {
    border-radius: 4px 38% 4px 4px;
    border-radius: 0 38% 0 0;
}

.dpg-border-angle {
    border-radius: 38% 4px 38% 4px;
    border-radius: 38% 0 38% 0;
}

.dpg-border-reverse-angle {
    border-radius: 4px 38% 4px 38%;
    border-radius: 0 38% 0 38%;
}

.dpg-border-circle {
    border-radius: 46% 46% 46% 46%;
}

.dpg-appear .image-container img {
    animation: dpg-appear-image 1.5s ease;
    animation-fill-mode: both;
}

.dpg-appeared.dpg-appear {
    opacity: 1;
    transform: translate(0) scale(1);
}

/* Slide Up (dal basso verso l'alto) */
.dpg-appear-slide-up {
    transform: translateY(30%) scale(0.8);
}

/* Slide Right (da sinistra verso destra) */
.dpg-appear-slide-right {
    transform: translateX(30%) scale(0.8);
}

/* Slide Left (da destra verso sinistra) */
.dpg-appear-slide-left {
    transform: translateX(-30%) scale(0.8);
}

@keyframes dpg-appear-image {
    0% {
        transform: scale(1.3) translateY(-5%);
    }
    100% {
        transform: scale(1) translateY(0);
    }
}

.dpg-appear.dpg-appear-no-transform {
    transform: translate(0) scale(1);
}

.dpg-phrase,
.dpg-word,
.dpg-char {
    display: inline-flex;
}

.dpg-phrase {
    text-transform: uppercase;
    font-size: 28px;
    font-family: Lora, serif;
    gap: .3em;
}

.dpg-word {
    gap: 2px;
}

.dpg-char {
    overflow: hidden;
}

.dpg-appear.dpg-appeared .dpg-char-inner {
    opacity: 1;
    transform: translateX(0);
    transition-delay: calc(var(--dpg-i)* .075s);
}

.dpg-appear .dpg-char-inner {
    transform: translateX(100%);
    transition: opacity .35s, transform .75s cubic-bezier(.36,.07,.2,.93);
    opacity: .5;
}