Layout

Our layout guidelines help you to create consistent experiences across different platforms, environments and screen sizes.


Layout principles

Responsive

Our layout principles adapt to different screen sizes, so that users get a great experience regardless of what device they’re using.

Flexible

All of our defaults can be modified to meet the needs of different users.

Mobile first

In both design and code, we cater for the smallest breakpoint first, then customise as the screen size increases.

Overview of grids

The structure of a page is created through the grid. It controls the positioning of components, the spacing between them and how wide they can expand.

The grid normally makes use of a 12-column layout to cater for either 2, 3 or 4 components being displayed side-by-side. However, there’s flexibility for other approaches if the design requires it.

grid overview image

Most measurements align to an 8 based grid applied, it's our base unit for mobile, tablet, and desktop. Smaller components, such as icons and type, can align to a 4 based grid.

These base units will help us keep the design consistent and improve communication between designers and developers. We chose an 8 unit because most screen sizes are divisible by 4, and 4 itself is also an easily divisible number.


Composition of grids

The grid is made up of three different elements These are margins, columns, and gutters.

Grid margins

Margins are the spaces on the left and right edges of the device screen (shown below in red). Margin widths are fixed within each breakpoint range.

grid margins image

Grid columns

Columns show the space available for content or container to begin and end they are a vertical series within the grid (shown below in red). Content or containers can span multiple columns and column widths change with the size of the grid.

grid columns image

Column layout span

Mix and match column widths of your content or containers by spanning multiple columns for a wide variety of layout options.

column span image

The above is an example of how a designer may vary columns of content or containers across a 12-column grid layout within a page.

  1. Two pieces of content or containers, spaced equally across a layout.
  2. Three pieces of content or containers, spaced equally across a layout.
  3. Four pieces of content or containers, spaced equally across a layout.
  4. Six pieces of content or containers, spaced equally across a layout.
  5. Two pieces of content or containers of unequal width: one that spans three-fourths of the page, and the other spanning one fourth of the page.

Grid gutters

Gutters are the spaces between columns (shown below in red). Gutter widths are fixed within each breakpoint range.

grid gutters image

Fluid and fixed grids

Fluid grids are built using percentages for widths. As a result, columns are relative to one another allowing it to scale up and down fluidly.

Fixed grids have a set width and resizing the browser or viewing it on different devices won't affect the way the website looks.

While both fluid and fixed grid options can work for responsive websites, in most cases it's recommended to use fluid grids.

Fluid grids

Fluid layouts are calculated to their relative size, and stretch as the screen (viewport) is resized. For example, if you set layout width to 100%, each column will only be calculated to its relative size, and will stretch as the browser is resized.

Fluid grid at 320px

fluid grid 320px image

Fluid grid at 768px

fluid grid 768px image

Fluid grid at 1024px

fluid grid 1024px image

Fixed grids

Fixed grids use columns of a fixed size, with fluid margins to keep content unchanging within each breakpoint range. A fixed grid's layout can only change at an assigned breakpoint.

Fixed grids at 1280px display

fixed grid 1280px image

Fixed grids at 1440px display

fixed grid 1440px image

Fixed grids at 2560px display

fixed grid 2560px image

Content or container spanning

Make sure the content or container spans all of the columns in the layout (whether it is 2, 6, or 12 columns), rather than using columns as margins or padding. Following this methodology will keep layouts uniform and prevent unreliable responsive behaviour.

content or container image
  1. Best practice for content or containers.
  2. Best practice for content or containers.
  3. Not recommended as this is relying on grid columns for margins, instead of the actual margins.

Spacing

Spacing is the negative area between elements in your layout as well as within components.

Our spacing system follows our grids system. Consistent spacing creates a visual balance that makes the user interface easier to scan. Apply consistent spacing to improve the quality of the user interfaces you produce.

To create an efficient layout, we consider 2 kinds of spacings: horizontal and vertical. Horizontal based mainly on the grid systems and spacings through elements. Vertical based on some rules and minimum spacings between components.

vertical spacing example

Mostly all components align to an 8px and 16px square baseline grid for mobile, tablet and desktop.

horizontal spacing example

Typography, iconography, and some elements within components can align to a 4px grid.

Spacing values

Consistent spacing is mandatory and we strongly recommend only using these sizes:

ValueExample of use
4pxThe margin between icon + text
8pxThe margin between label + input
12pxThe padding within components
16pxThe padding within components Most used spacing
24pxThe margin between sections/organisms
32pxThe margin between sections/organisms
40pxThe margin between sections/organisms
48pxThe margin between sections/organisms
56pxThe margin between sections/organisms
64pxThe margin between sections/organisms

*Organisms are groups of molecules that work together to create a more complex component, such as a header or a footer. You create a more structured and scalable system by breaking down a design into its smallest components and then grouping them into molecules and organisms.

Visual example of vertical spacing values

vertical spacing example

Breakpoints

Breakpoints allow for the layout to change on different screen sizes for web responsive interfaces, so that the experience is always optimised for the device the user’s viewing it on.

Example of breakpoint re-sizing

breakpoint resizing example

Breakpoints allow for the layout to change on different screen sizes, so that the experience is always optimised for the device the user’s viewing it on.

For example, a product listing page might show 4 grid columns on a mobile device and 12 grid columns on a tablet and above. The design system has a core set of breakpoints that cover common device groups.

TextBreakpointsNo. of columnsGutters
Mobile0px416px
Tablet600px1216px
Small desktop900px1216px
Medium Desktop1200px1216px
Large Desktop1800px1224px

Click and touch targets

Components within the design system use a standard height of 48px. Larger components go up to 80px.

Clickable or touchable targets should be at least 48px by 48px.

For smaller components like icons, you can use invisible padding to reach the target size.

click and touch targets example

Padding and scale space

The design system uses the 8px base when adding horizontal and vertical space for layout objects, as well as internal padding within components.

In circumstances where elements would look cramped on larger screen sizes, spacing can adapt based on what breakpoint grouping the device falls in.

These values usually go up in multiples of 8px. But the spacing of elements can increase from 16px to 24px, depending on whether the user is on a phone or computer.

16px padding on mobile (below 720)

16px padding on mobile example

24px padding example at larger size

24px padding example

Padding at different breakpoints

Spacing nameBreakpoints smaller than 720pxBreakpoints 720px or more
Default16px24px
SM16px16px
LG24px32px
XL1800px40px

Aspect ratios

Aspect ratios describe the relationship between width and height. To keep things looking consistent, use consistent aspect ratios.

We recommend using 1:1, 2:3, 3:2, 3:4, 4:3, 9:16 and 16:9. These can apply to images, surfaces or components.

aspect ratio example

Design templates

Design templates can be found on the layout page of our Figma Libraries. They cover popular sizes for responsive web, iOS and Android.

Use them as a starting point when creating a new design or presenting work on a specific device.

design templates example

Landmarks

Screen reader users may not be able to see the visual structure of a page. Landmarks are used to provide shortcuts that allow screen reader users to jump to key sections.

When a screen reader user navigates to a landmark, they'll be given a relevant description.

How to see landmarks on any page

We recommend you install the free Accessibility Insights Chrome extension. You can then turn on ‘landmarks’ within ‘ad hoc tools’.

How to use landmarks

You should make sure that the key landmarks, such as the header, navigation, main content and footer are present.

They can be added to a page by using a semantic element or by adding a role attribute. These include (Component / HTML element / role attribute):

  • <Header /> / <header /> / role="banner"
  • <Navigation /> / <nav /> / role="navigation"
  • <Main /> / <main /> / role="main"
  • <Footer /> / <footer /> / role="contentinfo"

If there's more than one navigation landmark, use an aria-label to help the user to tell between them (for example, site navigation versus in-page navigation).

Get more guidance on landmarks from MDN Web Docs.


Was this page helpful?


Get in touch

We can help you answer any questions around layouts or just help with your next project.