:root {
    --gallery-gap: 45px;
    --gallery-radius: 20px;
}


/* Base grid styling */
.gallery-grid {
    display: grid;
    gap: var(--gallery-gap);
}

/* TOP GRID: big left + two stacked right */
.gallery-grid--top {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr);
    grid-auto-rows: minmax(160px, auto);
    margin-bottom: var(--gallery-gap);
}

.gallery-grid--top:last-child {
    margin-bottom: 0;
}

.gallery-grid--top .gallery-card--hero {
    grid-row: span 2;
}

/* BOTTOM GRID: two stacked left + tall right */
.gallery-grid--bottom {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 2fr);
    grid-auto-rows: minmax(160px, auto);
}

.gallery-grid--bottom:has(+ .gallery-grid--top) {
    margin-bottom: var(--gallery-gap);
}

/* Card styles */
.gallery-card {
    border-radius: var(--gallery-radius);
    overflow: hidden;
    background-color: #ddd;
    display: block;
}

.gallery-card--tall {
    grid-row: span 2;
}

/* Image behavior */
.gallery-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 360ms ease-in-out;
    transform-origin: center;
    transform: scale(1.05);
}

.gallery-card a {
    position: relative;

    &:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        background: rgb(205, 127, 50, 20%);
        transition: all .5s ease-in-out;
        -webkit-transition: .5s ease-in-out;
        -o-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        z-index: 1;
        opacity: 0;
    }

    /* &::after {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 72px;
        height: 72px;
        background: url() no-repeat;
        background-size: contain;
        transition: all .5s ease-in-out;
        -webkit-transition: .5s ease-in-out;
        -o-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        opacity: 0;
    } */
}

.gallery-card:hover a {
    & img {
        transform: scale(1);
    }

    &:before {
        opacity: 1;
    }
}


/* ---------- RESPONSIVE ---------- */
@media (max-width: 768px) {

    :root {
        --gallery-gap: 20px;
    }

    .gallery-grid {
        gap: var(--gallery-gap);
    }

    .gallery-grid--top,
    .gallery-grid--bottom {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
    }

    .gallery-grid--top .gallery-card--hero,
    .gallery-card--tall {
        grid-row: auto;
    }
}