.home-body {
    min-height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.grid {
    display: grid;
    width: 100%;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0;
    padding-left: 3vw;
    padding-right: 3vw;
}

@media (max-width: 900px) {
    .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
            margin: auto;
        padding-left: 1vw !important;
        padding-right: 1vw !important;

    }
}

@media (max-width: 600px) {
    .grid {
        grid-template-columns: 1fr;
        gap: 5px !important;
        margin-top: 0 !important;
        margin-bottom: auto !important;
        padding-bottom: 3vw;
        padding-left: 1vw !important;
        padding-right: 1vw !important;
    }

    .card {
        aspect-ratio: unset !important;
        width: 100% !important;
        max-height: 20vw !important;
    }

    .overlay-box {
        width: 100% !important;
        font-size: 5vw !important;
    }

    .home-body {
        display: flex;
        padding-bottom: 10vw !important;
        justify-content: center;
        align-items: center;
    }

}

.card {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 10px;
    text-decoration: none;
}

.card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: filter .2s ease;
}

.overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 248, 235, 0.85);
    opacity: 0;
    transition: opacity .2s ease;
}


.overlay-box {
    width: 75%;
    padding: 2vw 2.25vw;
    background: color-mix(in srgb, var(--light-brown) 50%, transparent);
    color: var(--background);
    border-radius: 6px;
    text-align: center;
    font-size: 1.5vw;
}

.overlay-box strong {
    display: block;
    margin-bottom: 6px;
}

.card:hover img {
    filter: brightness(.6);
}

.card:hover .overlay {
    opacity: 1;
}