/* ── Kadence Media Gallery – Frontend Styles ───────────────────────────── */

/* ─── Wrapper ─────────────────────────────────────────────────────────── */
.kmg-gallery-wrapper {
    position: relative;
    width: 100%;
}

/* ─── Grid ────────────────────────────────────────────────────────────── */
.kmg-layout-grid .kmg-grid,
.kmg-layout-masonry .kmg-grid {
    display: grid;
    grid-template-columns: repeat(var(--kmg-columns, 3), 1fr);
    gap: var(--kmg-gap, 16px);
}

@media (max-width: 1024px) {
    .kmg-layout-grid .kmg-grid,
    .kmg-layout-masonry .kmg-grid {
        grid-template-columns: repeat(var(--kmg-columns-tablet, 2), 1fr);
    }
}
@media (max-width: 767px) {
    .kmg-layout-grid .kmg-grid,
    .kmg-layout-masonry .kmg-grid {
        grid-template-columns: repeat(var(--kmg-columns-mobile, 1), 1fr);
    }
}

/* ─── Masonry ─────────────────────────────────────────────────────────── */
.kmg-layout-masonry .kmg-grid {
    display: block;
    columns: var(--kmg-columns, 3);
    column-gap: var(--kmg-gap, 16px);
}
.kmg-layout-masonry .kmg-item {
    break-inside: avoid;
    margin-bottom: var(--kmg-gap, 16px);
    display: inline-block;
    width: 100%;
}
.kmg-layout-masonry .kmg-aspect-ratio {
    aspect-ratio: unset !important;
}
.kmg-layout-masonry .kmg-img {
    height: auto !important;
}
@media (max-width: 1024px) {
    .kmg-layout-masonry .kmg-grid { columns: var(--kmg-columns-tablet, 2); }
}
@media (max-width: 767px) {
    .kmg-layout-masonry .kmg-grid { columns: var(--kmg-columns-mobile, 1); }
}

/* ─── Aspect Ratio Container ──────────────────────────────────────────── */
.kmg-aspect-ratio {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: var(--kmg-radius, 8px);
    background: #111;

    img, iframe {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
}

/* ─── Item ────────────────────────────────────────────────────────────── */
.kmg-item {
    position: relative;
}

.kmg-item-image {
    cursor: pointer;

    .kmg-aspect-ratio::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0,0,0,0);
        transition: background .2s ease;
        border-radius: inherit;
        pointer-events: none;
    }

    &:hover .kmg-aspect-ratio::after {
        background: rgba(0,0,0,.18);
    }
}

.kmg-img {
    transition: transform .35s ease;
}
.kmg-item-image:hover .kmg-img {
    transform: scale(1.04);
}

/* ─── Caption ─────────────────────────────────────────────────────────── */
.kmg-caption {
    font-size: .875rem;
    color: var(--global-palette5, #6b7280);
    text-align: center;
    margin: 8px 0 0;
    line-height: 1.4;
}

/* ─── Play Button ─────────────────────────────────────────────────────── */
.kmg-item-video {
    cursor: pointer;

    .kmg-aspect-ratio img {
        transition: transform .35s ease, filter .2s;
    }
    &:hover .kmg-aspect-ratio img {
        transform: scale(1.04);
        filter: brightness(.85);
    }
}

.kmg-play-btn {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 2;
    transition: transform .2s ease;

    &:hover { transform: scale(1.08); }

    svg {
        width: clamp(44px, 8%, 68px);
        height: auto;
        filter: drop-shadow(0 2px 6px rgba(0,0,0,.5));
    }
}

.kmg-play-bg  { fill: rgba(20,20,20,.82); }
.kmg-play-icon { fill: #fff; }

/* ─── Inline video iframe ────────────────────────────────────────────── */
.kmg-inline-iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
    border-radius: var(--kmg-radius, 8px);
    z-index: 3;
}

/* ─── Slider ──────────────────────────────────────────────────────────── */
.kmg-layout-slider .kmg-slider-track {
    position: relative;
    overflow: hidden;
    border-radius: var(--kmg-radius, 8px);
}

.kmg-layout-slider .kmg-slider-inner {
    display: flex;
    transition: transform .45s cubic-bezier(.4,0,.2,1);
    will-change: transform;
}

.kmg-layout-slider .kmg-item {
    flex: 0 0 100%;
    width: 100%;
}

.kmg-slider-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    background: rgba(255,255,255,.9);
    border: none;
    border-radius: 50%;
    width: 42px;
    height: 42px;
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    transition: background .15s, transform .15s;

    &:hover {
        background: #fff;
        transform: translateY(-50%) scale(1.08);
    }
}

.kmg-slider-prev { left: 12px; }
.kmg-slider-next { right: 12px; }

.kmg-slider-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 12px;
}

.kmg-slider-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--global-palette5, #d1d5db);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s;

    &.is-active {
        background: var(--global-palette1, #1a1a2e);
        transform: scale(1.25);
    }
}

/* ─── Lightbox ────────────────────────────────────────────────────────── */
.kmg-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .25s ease;

    &[hidden] { display: none; }
    &.is-open { opacity: 1; }
}

.kmg-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.88);
    cursor: pointer;
}

.kmg-lightbox-content {
    position: relative;
    z-index: 1;
    width: min(90vw, 1100px);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.kmg-lightbox-media {
    width: 100%;
    border-radius: 6px;
    overflow: hidden;
    background: #000;
    box-shadow: 0 16px 60px rgba(0,0,0,.6);

    img {
        display: block;
        width: 100%;
        height: auto;
        max-height: 85vh;
        object-fit: contain;
    }

    iframe {
        width: 100%;
        aspect-ratio: 16/9;
        border: none;
        display: block;
    }
}

.kmg-lightbox-caption {
    color: rgba(255,255,255,.75);
    font-size: .9rem;
    margin: 12px 0 0;
    text-align: center;
}

.kmg-lightbox-close,
.kmg-lightbox-prev,
.kmg-lightbox-next {
    position: absolute;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s, transform .15s;
    backdrop-filter: blur(4px);

    &:hover {
        background: rgba(255,255,255,.25);
        transform: scale(1.1);
    }
}

.kmg-lightbox-close {
    top: -18px;
    right: -18px;
    width: 38px;
    height: 38px;
    font-size: 22px;
    line-height: 1;
}

.kmg-lightbox-prev,
.kmg-lightbox-next {
    top: 50%;
    transform: translateY(-50%);
    width: 46px;
    height: 46px;
    font-size: 20px;

    &:hover { transform: translateY(-50%) scale(1.1); }
}

.kmg-lightbox-prev { left: -58px; }
.kmg-lightbox-next { right: -58px; }

@media (max-width: 767px) {
    .kmg-lightbox-prev { left: 4px; }
    .kmg-lightbox-next { right: 4px; }
    .kmg-lightbox-close { top: 4px; right: 4px; }
    .kmg-lightbox-content { width: 96vw; }
}
