@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Montserrat:wght@400;500;600;700;800&display=swap');

/* Gallery Page Styles */

.gallery-sec1-container {
    width: 100%;
}

.gallery-sec1-header {
    background-image: url('../img/home-section2-pattern.svg');
    background-size: cover;
    background-position: top center;
    background-repeat: no-repeat;
    padding: 80px 0 60px 0;
}

.gallery-sec1-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 42px;
    line-height: 48px;
    letter-spacing: 0%;
    text-align: center;
    color: #D45052;
}

.gallery-sec1-subtitle {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: #323031;
}

/* Grid Layout for Flat Bottoms */
.gallery-container {
    max-width: 1400px;
    margin: 0 auto;
}

.gallery-grid {
    display: grid;
    /* Using 15 columns (LCM of 3 and 5) allows exact splits:
       Row of 5: span 3 each
       Row of 3: span 5 each */
    grid-template-columns: repeat(15, 1fr);
    grid-auto-rows: 250px;
    grid-auto-flow: dense;
    gap: 20px;
}

/* Organic pattern for varied widths that matches grid perfectly */
.gallery-item {

    overflow: hidden;
}

/* Row 1: 5 images (normal) */
.gallery-item:nth-child(1),
.gallery-item:nth-child(2),
.gallery-item:nth-child(3),
.gallery-item:nth-child(4),
.gallery-item:nth-child(5) {
    grid-column: span 3;
}

/* Row 2: 3 images (1st is large) */
.gallery-item:nth-child(6) {
    grid-column: span 9;
}
.gallery-item:nth-child(7),
.gallery-item:nth-child(8) {
    grid-column: span 3;
}

/* Row 3: 5 images (normal) */
.gallery-item:nth-child(9),
.gallery-item:nth-child(10),
.gallery-item:nth-child(11),
.gallery-item:nth-child(12),
.gallery-item:nth-child(13) {
    grid-column: span 3;
}

/* Row 4: 5 images (normal) */
.gallery-item:nth-child(14),
.gallery-item:nth-child(15),
.gallery-item:nth-child(16),
.gallery-item:nth-child(17),
.gallery-item:nth-child(18) {
    grid-column: span 3;
}

/* Row 5: 3 images (3rd is large) */
.gallery-item:nth-child(19),
.gallery-item:nth-child(20) {
    grid-column: span 3;
}
.gallery-item:nth-child(21) {
    grid-column: span 9;
}

/* Row 6: 5 images (normal) */
.gallery-item:nth-child(22),
.gallery-item:nth-child(23),
.gallery-item:nth-child(24),
.gallery-item:nth-child(25),
.gallery-item:nth-child(26) {
    grid-column: span 3;
}

/* Row 7: 3 images (1st is large) */
.gallery-item:nth-child(27) {
    grid-column: span 9;
}
.gallery-item:nth-child(28),
.gallery-item:nth-child(29) {
    grid-column: span 3;
}
@media (max-width: 1199px) {
    .gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .gallery-item {
        grid-column: span 1 !important;
        grid-row: span 1 !important;
    }
}

@media (max-width: 767px) {
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 575px) {
    .gallery-grid {
        grid-template-columns: 1fr;
    }
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;

    transition: transform 0.3s ease;
}

.gallery-item img:hover {
    transform: scale(1.02);
}

/* Shimmer Loading Animation */
.loading-shimmer {
    background: #f6f7f8;
    background-image: linear-gradient(to right,
            #f6f7f8 0%,
            #edeef1 20%,
            #f6f7f8 40%,
            #f6f7f8 100%);
    background-repeat: no-repeat;
    background-size: 200% 100%;
    position: relative;
    overflow: hidden;
    animation: shimmer 1.5s infinite linear;
}

.loading-shimmer img {
    opacity: 0;
}

@keyframes shimmer {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}