body {
    font-family: sans-serif;
    background-color: #1b1b1b;
}

.grid-layout {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    grid-gap: 10px;
    grid-auto-rows: minmax(180px, auto);
    grid-auto-flow: dense;
    padding: 10px;
}

.grid-item {
    border-radius: 6px;
}

.span-2 {
    grid-column-end: span 2;
    grid-row-end: span 2;
}

.span-3 {
    grid-column-end: span 3;
    grid-row-end: span 4;
}

img{
    height: 100%;
    width:  100%;
    object-fit: cover;
    border-radius: 6px;
    filter:grayscale(100%);
}

img:hover{
    transition: filter .5s ease-in-out;
    filter: none;
}