/* Default grid (desktop: auto-fit images) */
.wcigl-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 15px 0;
}

/* Ensure items shrink properly */
.wcigl-item {
    flex: 1 1 calc(25% - 5px); /* 4 per row on large screens */
    box-sizing: border-box;
    border: 0.5px solid #40579d;
    border-radius: 4px;
    overflow: hidden;
}

/* Tablet (2–3 per row) */
@media (max-width: 768px) {
    .wcigl-item {
        flex: 1 1 calc(50% - 5px); /* 2 per row on tablets */
    }
}

/* Mobile (2 per row) */
@media (max-width: 480px) {
    .wcigl-item {
        flex: 1 1 calc(50% - 5px); /* 2 per row on phones */
    }
}
.wcigl-item img {
    display: block;
    width: 100%;
    aspect-ratio: auto;
    height: auto;
    object-fit: cover;
    object-position: center center;
    cursor: pointer;
    transition: transform 0.2s ease;
}
.wcigl-item img:hover {
    transform: scale(1.03);
}

.wcigl-slider-wrap {
    position: relative;
    display: grid;
    gap: 0.85rem;
    margin: 15px 0;
}

.wcigl-slider {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 15px) / 4);
    gap: 5px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    width: 100%;
    max-width: 44rem;
    margin: 0 auto;
    padding-bottom: 0.15rem;
    scrollbar-width: none;
}

.wcigl-slider::-webkit-scrollbar {
    display: none;
}

.wcigl-slide {
    scroll-snap-align: start;
    border: 0.5px solid #40579d;
    border-radius: 4px;
    overflow: hidden;
}

.wcigl-slide a,
.wcigl-slide img {
    display: block;
    width: 100%;
}

.wcigl-slide img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center center;
}

.wcigl-slider-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.wcigl-slider-dot {
    width: 0.65rem;
    height: 0.65rem;
    border: 0;
    border-radius: 999px;
    background: rgba(64, 87, 157, 0.28);
    padding: 0;
    cursor: pointer;
    transition: transform 0.18s ease, background 0.18s ease;
}

.wcigl-slider-dot.is-active {
    background: #40579d;
    transform: scale(1.15);
}

/* Lightbox overlay */
#wcigl-lightbox {
    display: none;
    position: fixed;
    z-index: 9999;
    inset: 0;
    background: rgba(0,0,0,0.85);
    justify-content: center;
    align-items: center;
    padding: 1rem;
}
#wcigl-lightbox.is-open {
    display: flex;
}
#wcigl-lightbox img {
    display: block;
    max-width: min(92vw, 1100px);
    max-height: 88vh;
    border-radius: 8px;
}
/* Close button inside lightbox */
#wcigl-lightbox .wcigl-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 2.75rem;
    height: 2.75rem;
    border: 0;
    border-radius: 999px;
    background: rgba(17, 24, 39, 0.8);
    color: white;
    cursor: pointer;
    font-size: 2rem;
    line-height: 1;
    font-weight: bold;
    z-index: 10000;
}
body.wcigl-lightbox-open {
    overflow: hidden;
}

@media (max-width: 640px) {
    .wcigl-slider {
        max-width: 100%;
        grid-auto-columns: 100%;
    }

    .wcigl-slider-dots {
        gap: 0.4rem;
    }

    .wcigl-slider-dot {
        width: 0.58rem;
        height: 0.58rem;
    }

    #wcigl-lightbox {
        padding: 0.75rem;
    }

    #wcigl-lightbox .wcigl-close {
        top: 0.75rem;
        right: 0.75rem;
        width: 2.5rem;
        height: 2.5rem;
        font-size: 1.75rem;
    }

    #wcigl-lightbox img {
        max-width: 100%;
        max-height: 84vh;
    }
}

@media (max-width: 991px) and (min-width: 641px) {
    .wcigl-slider {
        grid-auto-columns: calc((100% - 5px) / 2);
    }
}
