GC Design System Components
Home Start to use Page templates overview Basic page Components overview Breadcrumbs Button Card Checkboxes Container Date input Date modified Details Error message Error summary Fieldset File uploader Footer Grid Header Heading Icon Input Language toggle Link Notice Pagination Radios Screenreader-only Search Select Side navigation Signature Stepper Text Textarea Theme and topic menu Top navigation CSS shortcuts overview Reset styles Responsive layout State Box sizing Container sizing Display Overflow Position Visibility Font Font family Font size Font style Font weight Line height Link colour Link size Link text decoration List style Text align Text colour Text overflow Text transform Word break Margin Padding Align content Align items Align self Flex Flex direction Flex grow Flex shrink Flex wrap Gap Grid columns Grid rows Justify content Justify items Justify self Order Place content Place items Place self Background colour Border colour Border radius Border style Border width Icon names Icon size Image Cursor Pointer events Transition Styles overview Design tokens Colour tokens Spacing tokens Typography tokens Contact us Get involved Find a demo

Heading
<gcds-heading>

Also called: title, section heading, subheading.

A heading is a title that establishes levels of hierarchy to organize page content into a structure.

Heading component preview

Build a Heading

Headings structure content by establishing levels of hierarchy that organize page content.

Coding and accessibility for headings

Order heading levels hierarchically

Heading levels follow a sequential, hierarchical order: higher levels have larger display text than lower ones.

  • Set correct and consistent heading levels to align the coded and visual headings on a page. Consistent headings support an equitable experience for people who use assistive technologies.
  • Order headings sequentially from lowest to highest (H1–H6).
  • Avoid skipping heading levels. Instead, restructure content so headings are used sequentially, from largest (H1) to smallest (H6).
  • Only use an H1 heading once on a page. Other heading types can be used multiple times.
  • Use H2 headings to describe individual sections. Each section should have one H2 heading.
  • Opt to use H3–H6 headings within sections. Sections can contain multiple H3–H6 headings, as long as they are placed in hierarchical order.

Maintain accessible character limits

  • Maintain the default character-limit for each heading line by keeping the attribute set to true for a comfortable and accessible reading length. These defaults create a balanced, consistent line length across heading font sizes.
  • Keep character limits to the following lengths to maintain a visual balance across headings on a page:
    • 31 characters for H1.
    • 35 characters for H2.
    • 40 characters for H3.
    • 45 characters for H4.
    • 50 characters for H5.
    • 57 characters for H6.

Use consistent spacing

  • Maintain default spacing for a comfortable and accessible reading experience. These defaults create visual breaks and separation between different sections.
  • Keep spacing values to the following to maintain a visual balance across headings on a page:
    • Default margin-bottom: 300 for all
    • Default margin-top: 0 for H1 and 600 for H2–3

Get your code

Generate an instance of the component you need by selecting its code properties.

  1. Explore by choosing different code values to generate the instance you want.

  2. Get the code and pull it into your environment.

  3. Add any copy you need to the component (like text for a label).

Note: The code builder uses English for all code elements, which follows standard practice.

Help us improve

Have questions or a request? Give feedback on our contact form.

Something's wrong? Raise it through GitHub with an account. You'll have access to the team's direct responses, progress made on your issue, and issues raised by others.

Give feedback Report an issue on GitHub
2025-10-14