Skip to main content Home
About About the Design SystemRoadmap
Get started OverviewDesignersDevelopers
Foundations OverviewColorGridIconographyInteractionsSpacingTypography
Tokens Overview Global colorBox shadowTypographyBorderOpacitySpaceLengthIconBreakpointsMedia queries
Elements All elements Accordion Alert Announcement Audio player Avatar Back to top Badge Blockquote Breadcrumb Button Card Chip Code block Call to action Dialog Disclosure Footer Health index Icon Jump links Navigation (primary) Navigation (secondary) Pagination PopoverPlanned Progress stepper Scheme toggle Site status Skeleton Skip link Spinner Statistic Subnavigation Surface Switch Table Tabs Tag Tile Timestamp Tooltip Video embed
Theming OverviewColor PalettesCustomizingDevelopers
Patterns All PatternsAccordionCardFilterFormLink with iconLogo wallSearch barSticky bannerSticky cardTabsTagTile
Personalization All Personalization PatternsAnnouncement
Accessibility FundamentalsAccessibility toolsAssistive technologiesCI/CDContentContributorsDesignDevelopmentManual testingResourcesScreen readers
Design/code status Release notes Get support

Tabs

OverviewStyleGuidelinesCodeAccessibilityDemos
UsageVariantsTab panelWriting contentLayoutBehaviorResponsive designBest practicesUsageVariantsTab panelWriting contentLayoutBehaviorResponsive designBest practices

Usage

Use tabs to help users navigate information while staying on the same page. Text labels and content in the panel should be related so users know what to expect when they select each tab. Never force users to switch back and forth between tabs to complete a task.

When to use tabs

Use tabs to organize lots of information into logical sections. Consider using an accordion if that information needs to be viewed simultaneously because using tabs is not suitable as it forces users to rely on short-term memory when switching back and forth. Using an accordion can also accommodate more sections with longer text labels whereas tabs should only display three or four sections with short text labels. Therefore, if viewing lots of sections of content simultaneously is critical to the user experience or if important information requires more focus and less clicking, use an accordion instead.

Tabs vs. accordion

Tabs allow users to click through content one section at a time whereas an accordion allows users to view multiple sections of content simultaneously.

Image of tabs on top and an accordion below with two panels expanded

Number of tabs

To reduce cognitive load and a cluttered user interface, avoid using more than three or four tabs.

Image of open tabs with three tabs on top and box tabs with three tabs below

Variants

When choosing one variation over the other, consider where it is being used. If using tabs multiple times on one page, use one variation only. Open tabs - use if you want to keep your design clean and maintain a minimal look and feel Box tabs - use if your design includes a lot of boxes or you want to maintain the classic tabs look and feel

Image of open tabs on top and box tabs below

Orientation

When choosing one orientation over the other, consider the content in the panel, other elements in the layout, and how you want users to read the content:

  • Horizontal tabs are placed in the middle of a container and offer users a top-to-bottom reading experience
  • Vertical tabs are placed on the left side of a container and offer users a left-to-right reading experience
Image of horizontal tabs on top and vertical tabs below

Alignment

If using horizontal tabs, the default orientation is left aligned, but center aligned is also an option.

Image of open tabs with left and center alignment and box tabs with left and center alignment

Inset and tab panel spacing

An inset is used to ensure consistent alignment and padding between text labels, overflow buttons, and content in the panel.

Helpful Tip

With horizontal tabs, there are two inset options. With vertical tabs, there is only one.

Image of open tabs showing detailed inset specs Image of box tabs showing detailed inset specs Image of vertical tabs showing detailed inset specs

Certain content layouts may require removing the inset. While this is not a default style, it is possible with custom CSS.

Logos

In certain edge cases, logos can be used instead of text labels.

Image of open tabs with small logos in place of text labels

Tab panel

The panel is below or to the right of tabs. Use this area to place other elements or content like text, links, calls to action, and more. Text blocks should not exceed 750px to maintain optimal readability.

Warning

The Tabs element has no control over the panel in terms of content, layout, spacing, etc.

Image of open tabs with a text block and a card Image of open tabs with a title and a wide card Image of open tabs with a text block and a blockquote

Writing content

Text labels

Text labels should be concise, scannable, and descriptive of content in the panel. They should not exceed more than two or three short words. If they do, work with a content strategist to shorten them.

Image of open tabs with examples of adequate and long text labels

Character count

In general, tabs should have three or four text labels maximum. Text labels should be short but descriptive.

Text labels should be short but descriptive.

Column count Character count
3 to 4 20 to 30

Layout

Horizontal tabs width

The divider line can be set to any width or be the same width as the list of tabs.

Image of open tabs with a stretched divider line on top and box tabs with a divider line constrained to the width of text labels below

Vertical tabs height

The divider line will become taller if the height of content in the panel exceeds the height of vertical tabs.

Image of vertical tabs with a short amount of content in the panel on top and vertical tabs with a long amount of content in the panel below

Card

Tabs can be used in a card if the layout is wide enough and there are fewer tabs.

Image of open tabs in a card with only two tabs

Behavior

Overflow

If the number of tabs exceeds the container width or breakpoint, overflow buttons with chevron icons are added to each side so users can horizontally scroll to reveal hidden tabs.

Warning

Long text labels will make overflow buttons appear sooner, try and write text labels as short as possible.

Image of open tabs at various widths showing overflow buttons on top and box tabs at various widths showing overflow buttons below

When the first tab is active, the left overflow button is disabled. When the last tab is active, the right overflow button is disabled. When a tab that is cut off is selected, the list of tabs shifts so the selected tab is in full view.

Image of selecting a cut off tab and the list of tabs shifting to reveal the selected tab in full view

Responsive design

Large breakpoints

Image of horizontal and vertical tabs on desktop and tablet breakpoints

Small breakpoints

Vertical tabs switch to horizontal tabs with overflow buttons on small breakpoints.

Image of tabs with overflow buttons on small breakpoints

Best practices

Minimum number of tabs

Groups of two tabs shown in the open and box variants

There should always be at least two tabs.

One tab shown in the open and box variants

Do not use only one tab.

Using many tabs

Group of five box tabs at a large breakpoint

Use a reasonable number of tabs.

Group of six box tabs that overflow at a large breakpoint

Do not use too many tabs. In the horizontal orientation, be aware that including a lot of tabs may mean that the overflow layout will be triggered.

Spacing and width

Group of three tabs using the open variant's default styles

Retain the default spacing for tabs.

Group of three open variant tabs using very large padding

Do not add extra spacing or stretch the width of tabs.

Overflow buttons

Group of three open variant tabs flanked by overflow buttons

Use overflow buttons if not all of the tabs can fit.

Group of two open variant tabs flanked by overflow buttons

Do not make overflow buttons visible if all tabs can comfortably fit.

© 2025 Red Hat Deploys by Netlify