CSS custom properties for cascading variables
The CSS custom properties for cascading variables module adds support for cascading variables in CSS properties and lets you create custom properties to define these variables along with the mechanisms to use custom properties as the values for other CSS properties.
When working with CSS, you often end up reusing common project-specific values such as widths that work well with your layout, or a set of colors for your color scheme.
One way of managing repetition in stylesheets is to define a value once and use it many times in other places.
Custom properties let you create and define custom variables that can be reused, simplifying complex or repetitive rules and making them easier to read and maintain.
For example, --dark-grey-text and --dark-background are easier to understand than hexadecimal colors such as #323831, and the context of how you use them is more obvious, too.
Custom properties in action
To see how custom properties can be used, move the input slider left to right.
In these color swatches, the background-color is set using the hsl() <color> function as hsl(var(--hue) 50% 50%).
Each color swatch increments the <hue> value by 10 degrees like calc(var(--hue) + 10), calc(var(--hue) + 20) etc.
As the slider's value changes from 0 up to 360, the value of the --hue custom property is updated using calc(), and the background color of each box inside the grid is updated, also.
Reference
>Properties
Functions
Guides
- Using CSS custom properties (variables)
- 
Explains how to use custom properties in CSS and JavaScript, with hints on handling undefined and invalid values, fallbacks, and inheritance. 
- Invalid custom properties
- 
Explains how browsers handle property values when a custom property's value is an invalid data type for that property. 
Related concepts
- CSS Properties and Values API module
- @propertyat-rule
- CSS.registerProperty()method
 
Specifications
| Specification | 
|---|
| CSS Custom Properties for Cascading Variables Module Level 1> | 
See also
- CSS cascading and inheritance module
- CSS env()function
- CSS calc()function
- getPropertyValue()method