Skip to main content
U.S. flag

An official website of the United States government

Dot gov

The .gov means it’s official.
Federal government websites often end in .gov or .mil. Before sharing sensitive information, make sure you’re on a federal government site.

Https

The site is secure.
The https:// ensures that you are connecting to the official website and that any information you provide is encrypted and transmitted securely.

Components

Card

use: deployed Web
A card groups short, related pieces of personalized information into a series of discrete containers, similar to physical index or playing cards. The goal of a card is to present a snapshot of information in one digestible chunk with the option to navigate to more detailed content. The user should be able to easily scan a sequence of cards and take action on the most relevant items.

Examples

Default

View va-card default in Storybook

With Background

View va-card with background in Storybook

With Drop Shadow

View va-card with drop shadow in Storybook

With Icon

View va-card with icon in Storybook

Usage

When to use Card

  • Collections. Cards usually appear in a collection, rather than in isolation, contain identical or similar information, and are uniform in their look and feel so that users can easily scan the collection of related items and actions.
  • Framing a call to action. Cards help highlight and frame a specific call to action or decision a user needs to take.

When to consider something else

  • When you need a structured status card. Use Card - Status when you need a consistent, structured component with defined props for status, heading, body, and action link. Card Status enforces patterns for action-required scenarios and handles accessibility automatically.
  • Eligibility information. When you want to show benefits or tools the user is currently enrolled in or has access to, use the Service list item component.
  • Other content highlight. The Summary box component, which is the only card-like element represented in Drupal, is meant to act as a content highlight for the most important information on the page. It was originally intended to highlight eligibility information. Featured content is not a Card and you shouldn’t use them interchangeably. Use the Summary box once on the page, and don’t stack it in a list as you would the Card component or Service list item component.
  • Dynamic content. Do not use a Card when inserting content into the page in response to a user action. In those cases use a variation of an Alert component.
  • Forms - A Card is not a Fieldset. Use a fieldset to cluster related form fields into a sub-section of a form. The visual design of a fieldset should not mimic a Card.
  • Large data - A Card is not a Table row. A collection of cards does not scale up to large data sets. If users need to compare large amounts of data consider a table.
  • Navigation - A Card is not a Button or a Link. While a Card may contain a call-to-action link, it is not a navigation element. Do not use a Card to act as a large tap target.

When to use caution

  • Search results. You can use cards as a treatment for search results depending on the density of the data. However, the card may in fact add unnecessary visual noise when displaying a list of results. In those cases, if the data density is low consider removing the card container and having rows of results. If the data density is high consider adding pagination and the ability to search and/or filter the results.

How this component works

Card is a flexible container component. Teams build and pass in their own content, giving them full control over the structure and elements within the card. Below are some examples on how teams can do this.

Default

Basic card

  1. Background color. White or $color-gray-lightest - set via component props.
  2. Header. Teams provide their own header content that summarizes the card.
  3. Secondary content. Teams provide body text, which can include any combination of text, dates, or other content.
  4. Call to action. Teams add their own links - typically an action link or link.

Note: You can use Tag - Status in either Card or Card - Status. Card Status is required if you need an error state on the card, as it’s the only card component that supports error states. Use Card Status when you need a consistent, structured pattern with a single action link. Use the default Card component when you need multiple calls to action or flexible content structure.

You can see these options in use in the variations below.

Variations

Choosing between variations

Currently (06/2025), there are 4 variations to choose from:

1. Default

This variation is the default. New variations of Card start with this variation as the base.

2. With Background

This variation was the previous default and is the Card variation most widely found across VA.gov. However, it is no longer preferred. Visually, it features a gray background ($color-gray-lightest) with no border or drop shadow.

3. With Drop Shadow

Use this variation for emphasis, for example at the top of a page or section, or as the primary card in a series of cards. When using in a series, use with the default white variation. Do not combine this variation with the default gray variation.

4. With Icon

Use this variation to provide additional descriptive information about the contents of the Card. For example, in the context of appointments this variation features an icon that helps differentiate between cards related to in-person and remote appointments.

Instances of this component in production

There are many instances of the Card component in production. This is not an exhaustive list but does serve to augment the examples above and highlight well defined instances of a Card.

Appointment, large with icon

A large appointment card with an icon.
A large appointment card with an icon to identify the card type or category, in this case for an in-person appointment.

Financial Status Report

A Financial Status Report card.
A Financial Status Report (VA form 5655) card showing a household expense added with a Link - Active for editing the monthly amount and a Button - Icon for deleting the entry.

Media

A media card for the GI Bill Comparison Tool.
A media card features an image or icon and contains a call to action with a description.
A navigation card used in the MyHealtheVet landing page.
A navigation card used in the MyHealtheVet landing page which contains a category of links.

Number highlight

A Number highlight card showing a disability rating.
A Number Highlight card brings attention to a specific number or statistic.

With status indicator

A card using a status with indicator. Accommodates longer status labels.
When statuses are longer than a single word, you can use an icon with a status message to explain the status

Behavior

Calls to action

Placement

Dimensions

Cards use the following widths:

Layout

Cards can sit inside or outside of a grid layout. Cards start with 1.5 spacing units (1.2rem/12px) below each card to separate them. Then the spacing increases to 2 spacing units (1.6rem/16px) of margin on all sides at the $medium-screen and above breakpoint.

Code usage

Web

Attributes and Properties

Property Attribute Type Default Description background background boolean false

If true, the card will have a gray background.

iconName icon-name string

If set, displays an icon at the top of the card in a blue circle. The value should be the icon name to use. Icons can be found at https://design.va.gov/components/icon

showShadow show-shadow boolean false

If true, a drop-shadow will be displayed with a white background.

Not a Card

There are a few design elements that look like a Card but do not behave like a Card and are actually instances, or variations, of other components or are simply containers that share the same background color as a Card. These Card adjacent designs should not be thought of as a Card component and do not adhere to the guidelines defined here.

A mobile link that looks like a Card.
Mobile link. Not a Card.

The Mobile App uses a Card-like container around an active link to make the link a large tap target on mobile. Think of this treatment as a mobile-specific link variation rather than an instance of a Card.

Containers for asking users for multiple responses (aka List and Loop) in forms

A container for an action in a form used in the Ask users for multiple responses (aka List and Loop) pattern.
Container for a button and title. Not a Card.

The pattern for asking users for multiple responses (aka List and Loop) uses a Card-like container to enter the loop to edit or remove an item in the list. This treatment is specific to that pattern—don’t think of it as an instance of a Card.

Containers for radio button tiles and checkboxes

A container for a checkbox and description in a form.
Container for a checkbox. Not a Card.

A radio button tile has a title and description within the label and a Card-like container around the radio button and label. You can see this treatment in the Radio button - Tile variation. It is also in use around checkboxes in parts of VA.gov. This treatment is specific to radio buttons and checkboxes—don’t think of it as an instance of a Card.

A list of services or tools

View va-service-list-item maximal example in Storybook

When you want to show benefits or tools the user is currently enrolled in or has access to, use the Service list item component instead of the Card component.

Content considerations

  • Concise headers and text. Keep card content (especially header text) short, crisp, and to-the-point: Users should be able to glean the most important information at-a-glance, and have the option to view additional details by clicking a link or action link.
  • Translation proof. Avoid using dynamic content within the middle of a sentence to future-proof the card for translation.

Accessibility considerations

  • Use the appropriate heading level for your page. Set the heading level based on the content of your page to make sure card headings are in the correct, logical outline order. Use CSS to style the header visually if you need a different visual representation.
  • Use unordered lists and list items. Use a ul for a card group and an li for each card. This formatting allows screen readers to enumerate the items in the card group and allows shortcuts between list items.
  • Keyboard navigation. The tab key should bring focus to the call to action within the card. The enter key or spacebar should open a Link or Link - Action.

Component checklist

Maturity

Guidance

Web

Examples, usage, code usage, content considerations, and accessibility considerations are all complete.

Research

Web

VFS team conducted research on this component which is linked from this page.

Stability

Web

Component has been in production for more than 3 months with no significant issues found.

Adoption

Web

Multiple teams have adopted this component.

Accessibility

While this component has been previously tested against older criteria, it has not yet been audited with the updated testing criteria.

Code assets

Variations

Web

Storybook includes all variations (style, size, orientation, optional iconography, selection, error state, etc.)

Responsive

Web

Component depicted in all responsive breakpoints.

Interactive states

Web

Includes all interactive states that are applicable (hover, active, focus, keyboard focus, disabled).

Tokens

Web

All design attributes (color, typography, layout, etc.) are available as tokens.

Internationalization

Web

Describes i18n attributes.

Visual assets

Variations

Web

Figma library includes all variations (style, size, orientation, optional iconography, selection, error state, etc.)

Responsive

Web

Component designed to work in all responsive breakpoints.

Interactive states

Web

Includes all interactive states that are applicable (hover, active, focus, keyboard focus, disabled).

Tokens

Web

All design attributes (color, typography, layout, etc.) are available as tokens.

Legend:

  • Complete
  • Incomplete
  • N/A Not applicable

Provide feedback

Share your feedback, report issues, or suggest improvements for the Card component. Your input helps us make the design system better for everyone.

Edit this page in GitHub (Permissions required)
Last updated: Feb 24, 2026