.dp-gallery[class*="mosaic-beta"] ul {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3,1fr);
    grid-auto-rows: 1fr;
    list-style: none;
    padding: 0;
    margin: 0;
}

.dp-gallery[class*="mosaic-beta"].align-text-left ul {
    justify-content: flex-start;
}

.dp-gallery[class*="mosaic-beta"].align-text-right ul {
    justify-content: flex-end;
}

.dp-gallery[class*="mosaic-beta"] li {
    flex: 0 1 100%;
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    cursor: pointer;
}

.dp-gallery[class*="mosaic-beta"] li.grid-cols-1 { grid-column: span 1; }
.dp-gallery[class*="mosaic-beta"] li.grid-cols-2 { grid-column: span 2; }
.dp-gallery[class*="mosaic-beta"] li.grid-cols-3 { grid-column: span 3; }
.dp-gallery[class*="mosaic-beta"] li.grid-cols-4 { grid-column: span 4; }

.dp-gallery[class*="mosaic-beta"] li.grid-rows-1 { grid-row: span 1; }
.dp-gallery[class*="mosaic-beta"] li.grid-rows-2 { grid-row: span 2; }
.dp-gallery[class*="mosaic-beta"] li.grid-rows-3 { grid-row: span 3; }
.dp-gallery[class*="mosaic-beta"] li.grid-rows-4 { grid-row: span 4; }


.dp-gallery[class*="mosaic-beta"] .dp-gallery-item-inner {
    height: 250px;
}

.dp-gallery[class*="mosaic-beta"] .image-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: calc(105%);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform 0.3s ease-out;
    overflow: hidden;
}

.dp-gallery[class*="mosaic-beta"] li:hover .image-wrapper {
    transform: translateY(-5%);
}

.dp-gallery[class*="mosaic-beta"] img.dp-gallery-image {
    position: absolute;
    top: -1px;
    left: -1px;
    width: 1px;
    height: 1px;
}

.dp-gallery[class*="mosaic-beta"] .hover-icon-wrapper {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease-out;
}

.dp-gallery[class*="mosaic-beta"] li:hover .hover-icon-wrapper {
    transform: translateY(-100%);
}

.dp-gallery[class*="mosaic-beta"] .hover-overlay {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.3);
    transition: transform 0.3s ease-out;
}

.dp-gallery[class*="mosaic-beta"] li:hover .hover-overlay {
    transform: translateY(-100%);
}

.dp-gallery[class*="grid-beta"] li.has-caption .hover-overlay {
    display: none;
}

.dp-gallery[class*="mosaic-beta"] .caption-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.dp-gallery[class*="mosaic-beta"] .caption-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 0;
    background-color: rgba(0,0,0,0.3);
    color: #ffffff;
    font-size: 16px;
    line-height: 1.3;
    text-align: center;
    text-transform: uppercase;
    padding: 10px 15px;
    transition: all 0.3s ease-in-out;
}

.dp-gallery[class*="mosaic-beta"] li:hover .caption-inner {
    flex: 1;
}

.dp-gallery[class*="mosaic-beta"] .caption-wrapper p {
    margin: 0;
}

.dp-gallery[class*="mosaic-beta"] a {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {

    .dp-gallery[class*="mosaic-beta"] li {
        flex-basis: calc((100% - 10px) / 2);
    }

    .dp-gallery[class*="mosaic-beta"] li.m-grid-cols-1 { grid-column: span 1; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-cols-2 { grid-column: span 2; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-cols-3 { grid-column: span 3; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-cols-4 { grid-column: span 4; }

    .dp-gallery[class*="mosaic-beta"] li.m-grid-rows-1 { grid-row: span 1; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-rows-2 { grid-row: span 2; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-rows-3 { grid-row: span 3; }
    .dp-gallery[class*="mosaic-beta"] li.m-grid-rows-4 { grid-row: span 4; }


}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {

    .dp-gallery[class*="mosaic-beta"] li {
        flex-basis: calc((100% - 20px) / 3);
    }

    .dp-gallery[class*="mosaic-beta"] li.xl-grid-cols-1 { grid-column: span 1; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-cols-2 { grid-column: span 2; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-cols-3 { grid-column: span 3; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-cols-4 { grid-column: span 4; }

    .dp-gallery[class*="mosaic-beta"] li.xl-grid-rows-1 { grid-row: span 1; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-rows-2 { grid-row: span 2; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-rows-3 { grid-row: span 3; }
    .dp-gallery[class*="mosaic-beta"] li.xl-grid-rows-4 { grid-row: span 4; }
    
}