$overlay-color-dark: #000 !default;
$overlay-color-light: #fff !default;
$overlay-opacity: .75 !default;
$thumbnailActiveOutline: 3px solid #fff !default;
$thubmnailAspectRatio: 1 !default;
$thumbnailBackgroundColor: #000 !default;
$thumbnailBorderRadius: .25rem !default;
$thumbnailColor: #fff !default;
$thumbnailIconWidth: 2rem !default;
$thumbnailIconHeight: 2rem !default;
$thumbnailHeight: 60px !default;

.dimbox-container {
    position: fixed;
    inset: 0 0 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    padding: 56px;
    opacity: 0;
    transition: opacity .5s;
    z-index: 99999;
}

.dimbox-container.dimbox-light {
    color: #000;
}

.dimbox-container.show {
    opacity: 1;
}

.dimbox-container.close-on-overlay-click,
.dimbox-container.close-on-overlay-click .dimbox-figure,
.dimbox-container.close-on-overlay-click .dimbox-video-container,
.dimbox-container.close-on-overlay-click .dimbox-iframe-container,
.dimbox-container.close-on-overlay-click .dimbox-ajax-container,
.dimbox-container.close-on-overlay-click:not(.dimbox-loaded) .dimbox-image {
    cursor: pointer;
}

.dimbox-container * {
    box-sizing: border-box;
}

.dimbox-container::before {
    content: '';
    display: block;
    position: absolute;
    inset: 0 0 0 0;
    background-color: $overlay-color-dark;
    opacity: $overlay-opacity;
}

.dimbox-container.dimbox-light::before {
    background-color: $overlay-color-light;
}

.dimbox-container *:active,
.dimbox-container *:focus,
.dimbox-container *:focus-visible {
    outline-style: dotted;
    outline-color: #fff;
    outline-offset: 4px;
}

.dimbox-container.dimbox-light *:active,
.dimbox-container.dimbox-light *:focus,
.dimbox-container.dimbox-light *:focus-visible {
    outline-color: #000;
}

.dimbox-loader {
    position: fixed;
    top: 50%;
    left: 50%;
    width: 32px;
    height: 32px;
    margin-top: -16px;
    margin-left: -16px;
    border: 4px solid #fff;
    border-right-color: transparent;
    border-radius: 50%;
    opacity: .5;
    animation: spin 1s linear infinite;
}

.dimbox-container.dimbox-light .dimbox-loader {
    border-color: #000;
    border-right-color: transparent;
}

.dimbox-container.dimbox-loaded .dimbox-loader {
    display: none;
}

[class^="dimbox-btn"] {
    position: absolute;
    width: 32px;
    height: 32px;
    display: inline-block;
    background-color: transparent;
    color: #fff;
    padding: 0;
    border: none;
    opacity: .5;
    cursor: pointer;
}

.dimbox-container.dimbox-light [class^="dimbox-btn"] {
    color: #000;
}

.dimbox-buttons {
    position: absolute;
    top: 16px;
    right: 16px;
    display: flex;
}

.dimbox-buttons [class^="dimbox-btn"] {
    position: static;
    margin: 0 8px;
}

.dimbox-btn-download {
    order: 1;
}

.dimbox-btn-fullscreen {
    order: 2;
}

.dimbox-btn-close {
    order: 3;
}

[class^="dimbox-btn"]:hover,
[class^="dimbox-btn"]:active,
[class^="dimbox-btn"]:focus {
    color: #fff;
    opacity: 1;
}

.dimbox-container.dimbox-light [class^="dimbox-btn"]:hover,
.dimbox-container.dimbox-light [class^="dimbox-btn"]:active,
.dimbox-container.dimbox-light [class^="dimbox-btn"]:focus {
    color: #000;
}

.dimbox-btn-prev,
.dimbox-btn-next {
    top: 50%;
}

.dimbox-btn-prev {
    left: 8px;
    transform: rotate(180deg) translateY(50%);
}

.dimbox-btn-next {
    right: 8px;
    transform: translateY(-50%);
}

[class^="dimbox-btn"] svg {
    width: 32px;
    height: 32px;
}

.dimbox-sequence {
    position: absolute;
    top: 16px;
    left: 16px;
}

.dimbox-thumbnails {
    position: absolute;
    bottom: 16px;
    left: 50%;
    display: flex;
    justify-content: center;
    transition: margin-left .5s;
}

.dimbox-thumbnails a {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: $thumbnailBackgroundColor;
    color: $thumbnailColor;
    text-decoration: none;
    height: $thumbnailHeight;
    aspect-ratio: $thubmnailAspectRatio;
    border-radius: $thumbnailBorderRadius;
    overflow: hidden;
    margin-left: 1rem;
}

.dimbox-thumbnails a:first-child {
    margin-left: 0;
}

.dimbox-thumbnails img,
.dimbox-thumbnails svg {
    height: $thumbnailHeight;
    aspect-ratio: $thubmnailAspectRatio;
    object-fit: cover;
    //opacity: .5;
}

.dimbox-thumbnails svg {
    width: $thumbnailIconWidth;
    height: $thumbnailIconHeight;
}

.dimbox-thumbnails > a.current {
    outline: $thumbnailActiveOutline;
    outline-offset: 0;
}

.dimbox-thumbnails > a.current:active,
.dimbox-thumbnails > a.current:focus,
.dimbox-thumbnails > a.current:focus-visible {
    outline-width: 1px;
    outline-style: dotted;
    outline-color: #fff;
    outline-offset: 4px;
}

.dimbox-thumbnails > a.current img,
.dimbox-thumbnails > a.current svg {
    opacity: 1;
}

.dimbox-content {
    position: relative;
    max-height: 100%;
    z-index: 1;
    opacity: 0;
    transition: opacity .5s;
    cursor: default;
}

.dimbox-container.show .dimbox-content {
    opacity: 1;
}

.dimbox-container.dimbox-gallery .dimbox-content.dimbox-transition-left {
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity .5s, transform .5s;
}

.dimbox-container.dimbox-gallery .dimbox-content.dimbox-transition-right {
    transform: translateX(50%);
    opacity: 0;
    transition: opacity .5s, transform .5s;
}

.dimbox-figure,
.dimbox-video-container,
.dimbox-iframe-container {
    margin: 0;
    opacity: 0;
    transition: opacity .5s;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-height: calc(100vh - 88px);
    transition: width .5s, height .5s;
}

.dimbox-container.has-thumbnails .dimbox-figure,
.dimbox-container.has-thumbnails .dimbox-video-container,
.dimbox-container.has-thumbnails .dimbox-iframe-container {
    max-height: calc(100vh - 88px - $thumbnailHeight);
    margin-top: calc(0px - $thumbnailHeight / 2);
}

.dimbox-iframe-container {
    width: calc(100vw - 112px);
    height: calc(100vh - 88px);
}

.dimbox-ajax-container {
    display: flex;
    flex-direction: column;
}

.dimbox-container.dimbox-loaded .dimbox-figure,
.dimbox-container.dimbox-loaded .dimbox-video-container,
.dimbox-container.dimbox-loaded .dimbox-iframe-container {
    opacity: 1;
}

.dimbox-ajax-content,
.dimbox-inline-content {
    background-color: #fff;
    color: #000;
    max-width: 768px;
    max-height: calc(100vh - 88px);
    padding: 16px;
    overflow: auto;
}

.dimbox-image,
.dimbox-video,
.dimbox-iframe {
    display: block;
    min-width: 0;
    min-height: 0;
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: 100%;
    cursor: default;
    transition: width .5s, height .5s;
}

.dimbox-image,
.dimbox-video {
    object-fit: contain;
}

.dimbox-caption {
    color: #fff;
    font-size: .85rem;
    text-align: center;
    margin: 8px auto 0 auto;
    cursor: default;
}

.dimbox-container.dimbox-light .dimbox-caption {
    color: #000;
}

.dimbox-iframe {
    border: none;
}

.dimbox-iframe.ratio-16x9 {
    aspect-ratio: 16/9;
}

.dimbox-iframe.ratio-4x3 {
    aspect-ratio: 4/3;
}

.dimbox-iframe.ratio-1x1 {
    aspect-ratio: 1/1;
}

.dimbox-iframe.ratio-9x16 {
    aspect-ratio: 9/16;
}

.dimbox-noscroll {
    overflow: hidden !important;
}

.dimbox-error {
    position: relative;
}

.dimbox-d-none {
    display: none !important;
}

@media (orientation: portrait) {
    .dimbox-container {
        padding: 56px 16px;
    }
    .dimbox-figure, 
    .dimbox-video-container {
        max-width: 100%;
        height: 100%;
    }
    .dimbox-iframe-container,
    .dimbox-ajax-container {
        width: 100%;
        height: calc(100vh - 112px);
    }
    .dimbox-inline-content {
        max-height: calc(100vh - 112px);
    }
    .dimbox-image,
    .dimbox-video {       
        width: 100%;
        height: auto;
    }
    .dimbox-btn-prev,
    .dimbox-btn-next {
        top: auto;
        bottom: 0;
    }
    .dimbox-container.has-thumbnails .dimbox-btn-prev,
    .dimbox-container.has-thumbnails .dimbox-btn-next {
        bottom: calc($thumbnailHeight + 8px);
    }
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}