html,
body {
    height: 100%;
    background: #f2f2f2;
}

*,
*:before,
*:after {
    box-sizing: border-box;
}

/* Container
---------------------------------------------------------------------- */

.container {
    padding: 1rem .5rem;
    overflow: hidden;
}

/* Target Elements
---------------------------------------------------------------------- */

.mix {
    float: left;
    margin: 0 .5rem 1rem;
    background: #fff;
    border-radius: 2px;
    position: relative;
}

.mix:before {
    content: '';
    display: inline-block;
    padding-top: 56.25%;
}

/* Grid Breakpoints
---------------------------------------------------------------------- */

/* 2 Columns */

.mix {
    width: calc(50% - 1rem);
}

/* 3 Columns */

@media screen and (min-width: 541px) {
    .mix {
        width: calc(100%/3 - 1rem);
    }
}

/* 4 Columns */

@media screen and (min-width: 961px) {
    .mix,
    .gap {
        width: calc(100%/4 - 1rem);
    }
}

/* 5 Columns */

@media screen and (min-width: 1281px) {
    .mix,
    .gap {
        width: calc(100%/5 - 1rem);
    }
}


