Skip to content
W3C Design System
  • Home
  • Settings
  • Styles
  • Layouts
  • Components
  • Scripts
  • Templates
  • Box
  • Center
  • Cluster
  • Frame
  • Sidebar
  • Switcher

Cluster

The cluster layout suits any group of elements that differ in length, are liable to wrap and need even spacing between them, e.g. lists of tags or groups of buttons. It uses the class .l-cluster.

The cluster layout needs an inner flexbox container - in the following example it's provided by the <ul>. Flexbox gives us control of the alignment of items inside.

The cluster items - <li> in this example - sit within this container. Each item has a margin on all sides.

The flexbox container has a negative margin of the same size as the cluster items, creating even spacing between them. overflow: hidden; is used to tidy up the edges.

Open this Cluster layout in a new tab

HTML:

<div class="l-cluster">
	<ul class="clean-list">
		<li><a href="#1">Item One</a></li>
		<li><a href="#2">Item Two</a></li>
		<li><a href="#3">Item Three</a></li>
		<li><a href="#4">Item Four</a></li>
		<li><a href="#5">Item Five</a></li>
		<li><a href="#6">Item Six</a></li>
		<li><a href="#7">Item Seven</a></li>
		<li><a href="#8">Item Eight</a></li>
		<li><a href="#9">Item Nine</a></li>
		<li><a href="#10">Item Ten</a></li>
	</ul>
</div>

If elements in the cluster do not have the same height, you can align them vertically by using the class .l-cluster--vertical-align.

Open this Cluster layout vertical align in a new tab

HTML:

<div class="l-cluster l-cluster--vertical-align">
	<div>
		<a href="" class="button button--alt">Button</a>
		<p>Paragraph</p>
		<a href="">Link</a>
	</div>
</div>

Copyright © 2025 W3C - generated 17 Oct 2025, 13:29:14 UTC

Feedback is welcome and can be submitted as a GitHub issue.