Simplify layouts with CSS display: contents

Visual example of CSS display: contents simplifying a layout

Did you know CSS has a hidden gem called display: contents?

It’s a powerful tool that helps simplify layouts without adding extra DOM elements. It removes an element from the layout while keeping its children intact.

Why is this so powerful?

  • It lets you restructure layouts without adding extra wrappers.
  • It works seamlessly with Flexbox and Grid, making designs more flexible.
  • It pairs perfectly with order to rearrange content without duplication.

On desktop, blocks 2 and 3 sit next to block 1 inside a container. On mobile, block 2 moves above block 1, and block 3 drops below it.

Normally, this would require workarounds: extra markup, hacks, or even duplicated content.

With display: contents, it’s just one line of CSS.

Browser support is already at 97%! But be aware, this property has some accessibility issues, especially with screen readers.

<section>
	<div class="first"></div>

	<div class="container">
		<div class="second"></div>
		<div class="third"></div>
	</div>
</section>
section {
	grid-template-columns: 1fr;
}
.container {
	display: contents;
}
.first {
	order: 2;
}
.second {
	order: 1;
}
.third {
	order: 3;
}

Full code available here: https://codepen.io/emgarf/pen/KwPZGQQ

To learn more tips about CSS, make sure to join my newsletter below ❤️

    No strings attached, unsubscribe anytime!