.grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 1.5rem;
}

label {
	cursor : pointer;
}

.pointer {cursor: pointer;}

@media screen and (min-width: 768px) {
    .grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media screen and (min-width: 992px) {
    .grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

//Pretty annoying
.grid {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
}

//Absolutely delightful
.grid {
    grid-template-columns: repeat(12, 1fr);
}

.grid a img {
    transition: all .2s ease-in;
    filter: grayscale(100%);
}

.grid a:hover img {
    filter: grayscale(0);
}

#menu-toggle:checked + #menu {
	display: block;
}