[data-fade] > img, [data-fade] > video{
    opacity:0;
}

[data-contains] > img, [data-contains] > video{
    width: calc(100% + 2px);
}

[data-contains]{
    position: relative;
    display:flex;
    justify-content: center;
    align-items: center;
}

[data-size]{
    aspect-ratio: 1/1;
    transition: .4s ease-in-out;
}

[data-open] > img{
    scale: 1.001;
    transition: scale .45s ease-in-out;
}

[data-open="video"]{
    position: relative;
}

.media-opener{
    inset: 0;
    position: absolute;
}

.media-loading-overlay{
    inset:0;
    background: grey;
    position: absolute;
    animation: loading-state-animation 2s ease-in-out infinite;
    transition: opacity .35s ease-out;
}

.loading-state{
    animation: loading-state-animation 2s ease-in-out infinite;
    background-color: rgba(128, 128, 128,.7) !important;
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.video-wrapper{
    width: 100%;
    overflow: hidden;
    border-radius: 10px;
    object-fit: cover;
    border-radius: var(--border-radius);
    box-shadow: var(--box-shadow);
}

.video-wrapper > .click-to-play-video-messages{
    inset: 12px 12px auto auto;
}

.image-wrapper{
    width: 100%;
    overflow: hidden;
    border-radius: var(--border-radius);
    box-shadow: var(--box-shadow);
}

.click-to-play-video-messages{
    position: absolute;
    inset:8px 7.3px auto auto;
    color: white;
    font-size: 14px;
    height: 28px;
    gap: 4px;
    border-radius: 5px;
    pointer-events: none;
    font-family: var(--main-font);
    padding: 0 7.5px 0 7.5px;
    background: rgba(1, 1, 1, .3);
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
}

@media (pointer: fine){

    [data-open]:hover > img{
        scale: 1.03;
    }

    [data-open="video"]:hover{
        filter: brightness(.65);
    }
    
}

@keyframes loading-state-animation {
    50%{
        filter: brightness(.6)
    }
}

/* video controls ------------------------------------------------------------ */
