body {
    min-height: 100vh;
}

.gallery-layout {
    width: min(98vw, 93.75rem);
    margin: 0 auto 2vw;
    display: grid;
    grid-template-columns: clamp(13rem, 18vw, 17.5rem) minmax(0, 1fr) clamp(13rem, 18vw, 17.5rem);
    align-items: start;
    gap: 0;
}

.gallery-layout #kazalo {
    width: auto;
    border-right: 0;
}

.gallery-wrap {
    min-height: 70vh;
    padding: clamp(1.8rem, 4vw, 2.6rem) clamp(1rem, 2vw, 1.8rem) 2rem;
    background: #9bd7e4;
    border: 4px solid #050505;
}

.mailing {
    padding: clamp(1rem, 2vw, 1.5rem);
    background: #9bd7e4;
    border: 4px solid #050505;
    border-left: 0;
}

.mailing h3 {
    margin: 0 0 .8rem;
    font-size: clamp(1.4rem, 2vw, 1.8rem);
    text-transform: uppercase;
}

.mailing input,
.mailing button {
    width: 100%;
    padding: .7rem;
    margin-bottom: .7rem;
    border: 3px solid #050505;
    font: inherit;
    background: #bff4ff;
}

.mailing button {
    cursor: pointer;
    background: #8be5bf;
    font-weight: 700;
    text-transform: uppercase;
}

.mailing button:hover {
    background: #fff200;
}

.gallery-wrap h2 {
    margin: 0 0 1.6rem;
    font-size: clamp(3rem, 7vw, 5.1rem);
    line-height: 0.9;
    font-weight: 400;
    text-transform: uppercase;
}

.bento {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-flow: dense;
    gap: clamp(.8rem, 1.2vw, 1.1rem);
}

.tile {
    min-height: 18vh;
    overflow: hidden;
    background: #bff4ff;
    border: 4px solid #050505;
}

.tile img {
    transition: transform .25s;
}

.tile:hover img {
    transform: scale(1.08);
}

.tile.hero,
.tile.feature {
    grid-column: span 2;
    grid-row: span 2;
}

.tile.wide {
    grid-column: span 2;
}

.tile.portrait {
    grid-row: span 2;
}

.tile.square {
    aspect-ratio: 1 / 1;
}

.tile.wide,
.tile.feature {
    aspect-ratio: 16 / 10;
}

.tile.hero,
.tile.portrait {
    aspect-ratio: 3 / 4;
}

.bento img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    filter: saturate(1.12) contrast(1.04);
}

.tile.hero img {
    object-position: right center;
}

@media (max-width: 1100px) {
    .gallery-layout {
        width: 96vw;
        grid-template-columns: 12rem minmax(0, 1fr);
    }

    .mailing {
        grid-column: 1 / -1;
        border-left: 4px solid #050505;
        border-top: 0;
    }

    .bento {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 650px) {
    .gallery-layout {
        display: block;
    }

    .gallery-layout #kazalo,
    .gallery-wrap,
    .mailing {
        margin-top: .9rem;
    }

    .gallery-wrap,
    .mailing {
        padding: 1.8rem 1rem;
    }

    .bento {
        grid-template-columns: 1fr;
    }

    .tile,
    .tile.hero,
    .tile.feature,
    .tile.wide,
    .tile.portrait {
        grid-column: auto;
        grid-row: auto;
        aspect-ratio: 4 / 3;
    }
}
