Color

Web Awesome's color system is made up of CSS custom properties to help with consistent color use throughout your project.

Color is organized by three main categories:

Color Scales

Color scales are determined by your color palette and are made up of the lowest level color tokens in your theme. Each token is identified by a name, like red or gray, and numerical tint based on the color's lightness. On this scale, 100 is equal to pure white and 0 is equal to pure black.

You can use these tints to ensure accessible color contrast per WCAG 2.1 success criteria:

You have several hand-crafted color palettes to choose from. Each palette defines 10 hues each with a scale of 11 tints using the format --wa-color-{hue}-{tint}.

Red
Orange
Yellow
Green
Cyan
Blue
Indigo
Purple
Pink
Gray

Semantic Scales

Any hue can be mapped to brand, neutral, success, warning, and danger scales. Like the tokens in a color scale, each token is identified by its semantic group and a numerical tint using the format --wa-color-{group}-{tint}.

Brand
Neutral
Success
Warning
Danger

Foundational Colors

Foundational colors lay the groundwork for the content and structure of your project. These colors are named according to their role in your theme.

Surfaces

Surfaces are background layers that other content rests on. Surface colors help convey hierarchy through a sense of elevation, where --wa-color-surface-raised is the closest to the user (e.g., dialogs and popup menus) and --wa-color-surface-lowered is the farthest away (e.g., wells).

Custom Property Preview
--wa-color-surface-raised
--wa-color-surface-default
--wa-color-surface-lowered
--wa-color-surface-border

Text

Text colors are used for standard text elements. We recommend a minimum 4.5:1 contrast ratio between text colors and surface colors.

Custom Property Preview
--wa-color-text-normal
AaBb
--wa-color-text-quiet
AaBb
--wa-color-text-link
AaBb

Overlays

Overlays provide a backdrop to isolate content, often allowing background context to show through.

Custom Property Preview
--wa-color-overlay-modal
--wa-color-overlay-inline

Shadow

Web Awesome uses a single color for all shadows. This is used alongside other shadow tokens to construct your theme's shadows.

Custom Property Preview
--wa-color-shadow

Interactions

Focus

Web Awesome uses a single focus color for predictable keyboard navigation. This is used alongside other focus tokens to construct --wa-focus-ring. We recommend a minimum 3:1 contrast ratio against surface colors and background colors wherever possible.

Custom Property Preview
--wa-color-focus

Hover and Active

Web Awesome leverages color-mix() to achieve consistent hover and active states across components without the need for untold numbers of handpicked colors. Through color-mix(), these custom properties contextually generate hover and active colors based on the color of the component.

Custom Property Preview
--wa-color-mix-hover
mixed
--wa-color-mix-active
mixed

Semantic Colors

Semantic colors reinforce a specific message, intended usage, or expected results through familiar, meaningful hues. Each color is identified by its semantic group, role, and attention using the format --wa-color-{group}-{role}-{attention}. There are five groups of semantic colors:

Each group defines colors for specific roles so that colors can be easily assembled with predictable results and readable contrast. There are three roles:

Finally, each color is named according to how much attention it draws. Here, we use noise as an analogy: a loud noise draws more attention than a quiet one. There are three levels of attention:

Custom Property brandsuccessneutralwarningdanger
--wa-color-*-fill-quiet
--wa-color-*-fill-normal
--wa-color-*-fill-loud
--wa-color-*-border-quiet
--wa-color-*-border-normal
--wa-color-*-border-loud
--wa-color-*-on-quiet
AaBb
AaBb
AaBb
AaBb
AaBb
--wa-color-*-on-normal
AaBb
AaBb
AaBb
AaBb
AaBb
--wa-color-*-on-loud
AaBb
AaBb
AaBb
AaBb
AaBb
    No results