Centered layout wrappers
Note: container
is simply used for adding a container query context — it doesn’t add any constraints.
Labels (see decoration)
Buttons
Full width button inside wrapper-sm
Up to four column grid layouts
A malleable grid without setting equalization on cell widths. In this example, for sm
up, columns will adopt whatever width they require for their content. Specify where you want your grid items using column placement classes — then CSS grid will figure out how many columns you need.
grid gap-1
sm:col-1
A narrow columnsm:col-2
This will expand to become a wide column because it has a lot of content. This will expand to become a wide column because it has a lot of content. This will expand to become a wide column because it has a lot of content.sm:col-3
Another narrow columnUsing equal-
modifiers on the grid wrapper will both equalize column width and specify the number of columns. Then for simple layouts (e.g. galleries), you won’t need column placement classes.
grid sm:equal-2-cols gap-2
grid sm:equal-2-cols md:equal-3-cols gap-2
sm:col-span-2
sm:grid
takes effect at 640px up. Below 640px, gap-2
will have no effect.
sm:grid sm:equal-4-cols gap-2
sm:col-span-2
sm:col-span-3
sm:col-4 sm:row-1 sm:row-span-2
Text sizes
See typography: making text bigger. t-long-read
and t-display
involve a clamp()
.
Default | t-long-read wrapper |
t-display wrapper |
---|---|---|
Heading 1Heading 2Heading 3Heading 4Heading 5Heading 6Paragraph. Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque? |
Heading 1Heading 2Heading 3Heading 4Heading 5Heading 6Paragraph. Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque? |
Heading 1Heading 2Heading 3Heading 4Heading 5Heading 6Paragraph. Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque? |
Example “research article” page layout using grid
grid md:equal-3-cols lg:equal-4-cols gap-3
md:col-2 md:col-span-2
Title of This Article
md:col-2 md:col-span-2 lg:col-4 lg:row-span-2 relative
sticky top
On this page TOC
- Abstract
- Materials and Methods
- Discussion
- Conclusion
md:col-2 md:col-span-2
Abstract
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Materials and Methods
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Discussion
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Conclusion
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
md:col-1 md:row-1 md:rows-1-3 lg:rows-1-2
Navigation menu
- Page One
- Page Two
- Page Three
Content-grid layouts
Title of this content-grid
demo
content-grid
is intended for long-form articles. Its 7-column grid places the content in column 4, where each immediate-child elment will be its own grid item. popout
spans rows 3-5. expand
spans rows 2-6. full-bleed
spans rows 1-7.
Here’s a styled <p class="popout">
:
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Here’s a styled <div class="expand">
:
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Here’s a styled <p class="full-bleed">
:
full-bleed
— expands to the full width of the avilable space. If there are no sidebars, it will reach the sides of the viewport.
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum. Natus debitis quisquam, expedita accusantium quos cumque?
Example components
Styled by utility classes.
Without *-dark-invert
With *-dark-invert
Card title
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Magni rem animi quaerat accusantium illum architecto, nemo, ex harum voluptatum adipisci eum blanditiis dolorum.
Flexbox media object
In this example, the media object “collapses” to a single column below container width 640px, using sm:flex
. And below that width, the title and button are centered using t-center
, which is overridden by sm:t-left
.
Grid media object
This example will behave as a grid for all container widths, even down to phones in portrait orientation.
A “two-up” feature block
In this exmple, the image is before the text content in the HTML. But for container width above 768px, the grid system places the image to the right (in the 2nd column). The text content is positioned vertical-center by flex flex-column flex-center