.foto-gallery {
    position: relative;
    padding: 0 1rem;

    .masonry {


        div {
            flex: 1 0 auto;
            break-inside: avoid;
            overflow: hidden;
            margin: .5rem;
            width: calc(33% - 1rem);

            &.hidden {
                visibility: hidden;
            }

            img {
                border-radius: var(--block-border-radius);
                width: 100%;
                height: 100%;
                object-fit: cover;
            }

            a {
                display: block;
                width: 100%;
                height: 100%;
            }
        }
    }
}

.spinner__container {
    display: none;
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 5rem 0;
    background: #fff;
}

@media (min-width: 576px) {

}

@media (min-width: 768px) {

}

@media (min-width: 992px) {
    .foto-gallery {
        .masonry {
            div {
                width: calc(25% - 1rem);
            }
        }
    }
}
@media (min-width: 1200px) {
    .foto-gallery {
        .masonry {
            div {
                width: calc(25% - 1rem);
            }
        }
    }
}
@media (min-width: 1400px) {
    .foto-gallery {
        .masonry {
            div {
                width: calc(20% - 1rem);
            }
        }
    }
}
@media (min-width: 1600px) {
    .foto-gallery {
        .masonry {
            div {
                width: calc(16.6% - 1rem);
            }
        }
    }
}