Using color
Color is deliberately used to reinforce meaning or content hierarchy.
Theme colors vs. static colors#
There are two important considerations when deciding between using theme colors or static colors: what the color is going to be applied to and what the color's relationship will be with other colors or objects.
Make this choice in a way that ensures an appropriate level of contrast is given to an object and any text or iconography.
Theme-specific color tokens#
Theme-specific
data:image/s3,"s3://crabby-images/69cd7/69cd78f44481284375f526a815007b20652a3cd5" alt="Theme-specific color tokens return different color values based on theme. Example of a text field, label Username, with an error message and icon."
data:image/s3,"s3://crabby-images/8c25b/8c25bdd74727f430d1cec1c0db8c478f087ac63c" alt="Theme-specific color tokens return different color values based on theme. Example of a text field, label Username, with an error message and icon."
Static color tokens#
Static
data:image/s3,"s3://crabby-images/ec082/ec0824e362533a0c5600d7859dd1711efc6cd20a" alt="Static color tokens return the same color value regardless of theme. An example of a badge, label Draft, on a lighter and a darker theme."
data:image/s3,"s3://crabby-images/07d60/07d60ffe40d0ed7ff493826112488cd46eeb246b" alt="Static color tokens return the same color value regardless of theme. An example of a badge, label Draft, on a lighter and a darker theme."
Background layers#
Spectrum provides three background layer color options for use in application framing: background layer 1, background layer 2, and background base. Background layer colors create dimension, hierarchy, and separation between content. Use these in large regions of layout — not for component backgrounds.
data:image/s3,"s3://crabby-images/29c66/29c667c78aec02d2db7d77840be1cee390345fc7" alt="Background layers presented to demonstrate background base as the darkest value, and background layer 2 as the lightest value for both light and dark themes."
data:image/s3,"s3://crabby-images/110e3/110e358a0d224b054004c350099939758ad8c19c" alt="Background layers presented to demonstrate background base as the darkest value, and background layer 2 as the lightest value for both light and dark themes."
Background base should only be used as empty space surrounding content or regions in
Background layer colors are
App framing#
Background layer colors create the scaffolding of a product’s user interface: the application frame. The level of scaffolding depth needed is dependent upon the product, content, users, and platform. Spectrum supports a variety of options using background layers to provide product flexibility.
Professional editing applications#
One option for these types of applications is to use background layer 1 for the header, footer, toolbars, and paneling. Background layer 2 is used for content (excluding artboards). Background base is used for pasteboards or surrounding backgrounds in photography, video, 3D, or compositing apps.
data:image/s3,"s3://crabby-images/c0409/c040959f4c5999ad4b99906a73991378b8bab747" alt="Key example of professional editing application framing option 1."
Another option is to use background layer 2 for the header, footer, toolbars, and paneling. This puts the frame at the same level of dimension as the primary content. No part of this option uses the background layer 1. This is useful when needing to conform to platform conventions (e.g., the prominent usage of white for application frames in Android light mode).
data:image/s3,"s3://crabby-images/2b626/2b6262e02a312fc5242b32c89d428e628e3489cc" alt="Key example of professional editing application framing option 2."
Lightweight editing and content-based applications#
These types of applications need less dimension to the application frame. The header, footer, toolbars, panels, and primary content all use the background layer 2. Areas that contain content (such as a gallery of cards) use the background layer 1. No part of this option uses background base.
data:image/s3,"s3://crabby-images/7a8a9/7a8a936b801ac0d3ddfbe817f46714ee0fe1e850" alt="Key example of lightweight editing and content-based application framing option."
Color backgrounds#
Sometimes it’s necessary to use color for the background or fill of an object in an interface. Use
Solid color background with black or white#
For these scenarios, color must adhere to WCAG contrast minimums with the color of the text. Most colors have white text placed over the color. To maintain the identifiability of yellow, orange, chartreuse, and cyan while still meeting these requirements, these colors must be used with black text. They must be fully opaque and should be referenced from the
data:image/s3,"s3://crabby-images/f89cd/f89cd0de3e914406f8f79af86c34cb37d69f256b" alt="Key example illustrating Badge component with a generic label, Label, colored backgrounds and white text, except orange, yellow, chartreuse, and cyan which have black text."
data:image/s3,"s3://crabby-images/672b0/672b0e29d20491ccefda267ffda7d42220703663" alt="Key example illustrating Badge component with a generic label, Label, colored backgrounds and white text, except orange, yellow, chartreuse, and cyan which have black text."
Do not use these colors without a text label representation of the color’s meaning in your application (e.g., “drafts,” “reviewed,” “new”). When using multiple colors and text labels cannot readily clarify color meaning — which is a common case in data visualization — use the
Two-tone color pairing#
Two
data:image/s3,"s3://crabby-images/1a4f4/1a4f4216753fbf22e2a00d9ecb50cbb2fcaa19d9" alt="Key example of components using two-tone background colors with two-tone foreground colors for iconography. Four actions with icons, labels Auto straighten, Remove background, Auto crop, Export to PNG."
data:image/s3,"s3://crabby-images/d5357/d53572128e415b868aa9c1deb848007653735799" alt="Key example of components using two-tone background colors with two-tone foreground colors for iconography. Four actions with icons, labels Auto straighten, Remove background, Auto crop, Export to PNG."
To create two-tone color pairs, use the 100
Do not use these colors without a text label representation of the color’s significance in your application. These colors are not color vision deficiency safe, and could be confusing to some users.
Colors for interactive states#
Spectrum components follow a consistent guideline for applying
data:image/s3,"s3://crabby-images/ce721/ce721b2a325f003dde86ad168a7fe33421d339d4" alt="Light theme-specific blue tokens for state progression, beginning with blue-900. Default state is 900 value, hover and keyboard focus states are 1000, and down state is 1100."
data:image/s3,"s3://crabby-images/90146/90146465ac386d4ca3aeb4cd73262794972ccf28" alt="Light theme-specific blue tokens for state progression, beginning with blue-900. Default state is 900 value, hover and keyboard focus states are 1000, and down state is 1100."
Interactive states increase the
data:image/s3,"s3://crabby-images/cdf8a/cdf8a3498daaf5ea7b3ab7baf015fc686423357e" alt="Components using static colors get darker for interactive states, whereas theme-specific colors increase in contrast for interactive states. Two examples, an action button and a switch."
data:image/s3,"s3://crabby-images/e1842/e184262cf989d06d6d5f345ba4ecd1965b066a51" alt="Components using static colors get darker for interactive states, whereas theme-specific colors increase in contrast for interactive states. Two examples, an action button and a switch."
Theme-specific colors get darker in light themes and lighter in dark themes for each state.
The change in
Usage guidelines#
Don't create your own colors#
Every part of the interface should use a color defined by Spectrum to ensure consistency across products. Spectrum’s colors are carefully chosen and tested to ensure they meet accessibility standards.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/a096b/a096b96d4666c80b7440e0c3563d718f20fa9fa9" alt="Image showing through labels components with colors that have incorrectly been changed to non-Spectrum colors."
Don’t use custom colors.
Using transparency#
Spectrum’s colors are opaque and should not be replaced by using transparencies to achieve the same colors. There are only a few instances where it's acceptable to use transparency: for background overlays, drop shadows, and highlight selection styles.
When designing components to be placed over a colored background or image, refer to the
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/ae323/ae32370fb6686b8ea8f9e49f0e961a9cc4b48a1c" alt="Image showing blocks of text correctly using gray-600 on both light and dark color themes."
Use gray tokens.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/080ce/080ce425222aa8ae3ea1ce4436aab8004420f158" alt="Image showing blocks of text incorrectly using 54% transparency black on both light and dark theme, which yields inaccessible text."
Don’t use transparent colors.
Communicating with color#
In order to be accessible for as many users as possible,
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/20b6e/20b6e264e994507ae094b5b019c72fdb322bc5c0" alt="Key example of a text field, correctly communicating an error with both red color, an alert icon, and an in-line text alert."
Use text and icons with color.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/436b9/436b931f41f73be3a1f1ac2ae6623c90780481f8" alt="Key example of a text field, incorrectly communicating an error with only red color."
Don’t use color alone to communicate.
Create hierarchy with background layer colors#
Use
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/003b4/003b47b11dc4b7bb6d9cb7f80a985e8e16882d01" alt="Key example of background layers stacked correctly for light and dark themes."
Use background layers for app framing
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/a5ce5/a5ce5348bc388e851f35a087493470e1104f0e39" alt="Key example of incorrect use of gray color tokens as background colors"
Don’t use global grays for app framing.
Provide sufficient contrast#
Use the appropriate
Choosing lower
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/09183/09183f5d8a11960486522e65973678bdaad8c164" alt="Key example of correct color token usage on background layers with sufficient contrast."
Use background layers and correct color tokens.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/d2aff/d2affb1377e666dda0823a30a11b14af45db4824" alt="Key example of incorrect color token usage on incorrect background colors, resulting in insufficient contrast."
Don’t use global grays for backgrounds or use different color tokens than specified.
Hue and saturation contrast#
Avoid placing colors directly on top of or adjacent to other colors that have a high degree of hue contrast with near-equal saturation or lightness. These scenarios create a visual illusion of depth or vibration (
Use static white or static black components instead of colored components on top of color or image backgrounds.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/8e9d4/8e9d404cec597e79749116a3d93a49a6c30f3aae" alt="Key example of correct use of static-white component on a red background, and colored CTA button on gray background."
Change one of the element's colors to avoid hue contrast issues.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/be7dd/be7ddc67a39e7bf0390f4c615bcd9f820429eb25" alt="Key example of incorrect usage of colored CTA button on a red background."
Don’t combine elements with contrasting hues of similar saturation and lightness.
Programmatic color changes#
Do not use color functions to modify Spectrum colors. The specific tints and shades of Spectrum’s themes were designed to be perceptually uniform. Modifying colors in the product or framework could result in
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f883a/f883ad748f776711e29c21e01b5aa42c7d28130c" alt="Key example of correct use of color token blue-300 in application code."
Use Spectrum colors as they are.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/eaa8f/eaa8f0b12ef6f2d18add5002cb5392ff4a8c2964" alt="Key example of incorrectly changing color token blue-300 using a lightening function in the application code."
Don’t programmatically modify Spectrum colors.
Use data visualization colors for charts#
Colors for data visualization are unique and should be used appropriately. Do not use theme-specific or static colors. View
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f4e53/f4e5379f42c52d7a802e52cbaba096e8ec18838f" alt="Key example of correct usage of Spectrum sequential colors for data visualization."
Use data visualization colors.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/4e610/4e6106b40db082397928e256b28deab08d340366" alt="Key example of correct usage of Spectrum sequential colors for data visualization."
Don’t use theme colors for data visualization.