body { background: #eee; } header { border-bottom: 1px solid #aaa; display: flex; flex-wrap: wrap; & > * { flex-grow: 1; } span { flex-grow: 5; padding-left: 1em; text-align: right; } } div.group { display: flex; flex-flow: row wrap; .item { background: #ccc; border: 1px solid #333; display: flex; flex-basis: 210px; flex-flow: column; flex-grow: 1; justify-content: space-between; margin: .2em; padding: 1ex; text-align: center; h2, p { margin: .2em; } img { box-shadow: 0 .2em 1em -.2em #000; } } } ul.alltags, ul.allpeople, ul.allplaces { -moz-column-width: 13em; column-width: 13em; }