Most browsers support using color keywords to specify a color. For example, to set the color
of an element to blue, use the blue
keyword:
.some-class {
color: blue;
}
CSS keywords are not case sensitive—blue
, Blue
and BLUE
will all result in #0000FF
.
In addition to the named colors, there is also the keyword transparent
, which represents a fully-transparent black: rgba(0,0,0,0)
CSS colors may also be represented as a hex triplet, where the members represent the red, green and blue components of a color. Each of these values represents a number in the range of 00
to FF
, or 0
to 255
in decimal notation. Uppercase and/or lowercase Hexidecimal values may be used (i.e. #3fc
= #3FC
= #33ffCC
). The browser interprets #369
as #336699
. If that is not what you intended but rather wanted #306090
, you need to specify that explicitly.
The total number of colors that can be represented with hex notation is 256 ^ 3 or 16,777,216.
color: #rrggbb;
color: #rgb
Value | Description |
---|---|
rr | 00 - FF for the amount of red |
gg | 00 - FF for the amount of green |
bb | 00 - FF for the amount of blue |
.some-class {
/* This is equivalent to using the color keyword 'blue' */
color: #0000FF;
}
.also-blue {
/* If you want to specify each range value with a single number, you can!
This is equivalent to '#0000FF' (and 'blue') */
color: #00F;
}
Hexadecimal notation is used to specify color values in the RGB color format, per the W3C's 'Numerical color values'.
There are a lot of tools available on the Internet for looking up hexadecimal (or simply hex) color values.
Search for "hex color palette" or "hex color picker" with your favorite web browser to find a bunch of options!
Hex values always start with a pound sign (#), are up to six "digits" long, and are case-insensitive: that is, they don't care about capitalization. #FFC125
and #ffc125
are the same color.
RGB is an additive color model which represents colors as mixtures of red, green, and blue light. In essence, the RGB representation is the decimal equivalent of the Hexadecimal Notation. In Hexadecimal each number ranges from 00-FF which is equivalent to 0-255 in decimal and 0%-100% in percentages.
.some-class {
/* Scalar RGB, equivalent to 'blue'*/
color: rgb(0, 0, 255);
}
.also-blue {
/* Percentile RGB values*/
color: rgb(0%, 0%, 100%);
}
rgb(<red>, <green>, <blue>)
Value | Description |
---|---|
<red> | an integer from 0 - 255 or percentage from 0 - 100% |
<green> | an integer from 0 - 255 or percentage from 0 - 100% |
<blue> | an integer from 0 - 255 or percentage from 0 - 100% |
HSL stands for hue ("which color"), saturation ("how much color") and lightness ("how much white").
Hue is represented as an angle from 0° to 360° (without units), while saturation and lightness are represented as percentages.
p {
color: hsl(240, 100%, 50%); /* Blue */
}
color: hsl(<hue>, <saturation>%, <lightness>%);
Value | Description |
---|---|
<hue> | specified in degrees around the color wheel (without units), where 0° is red, 60° is yellow, 120° is green, 180° is cyan, 240° is blue, 300° is magenta, and 360° is red |
<saturation> | specified in percentage where 0% is fully desaturated (grayscale) and 100% is fully saturated (vividly colored) |
<lightness> | specified in percentage where 0% is fully black and 100% is fully white |
A saturation of 0% always produces a grayscale color; changing the hue has no effect.
A lightness of 0% always produces black, and 100% always produces white; changing the hue or saturation has no effect.
currentColor
returns the computed color value of the current element.
Here currentColor evaluates to red since the color
property is set to red
:
div {
color: red;
border: 5px solid currentColor;
box-shadow: 0 0 5px currentColor;
}
In this case, specifying currentColor for the border is most likely redundant because omitting it should produce identical results. Only use currentColor inside the border property within the same element if it would be overwritten otherwise due to a more specific selector.
Since it's the computed color, the border will be green in the following example due to the second rule overriding the first:
div {
color: blue;
border: 3px solid currentColor;
color: green;
}
The parent's color is inherited, here currentColor evaluates to 'blue', making the child element's border-color blue.
.parent-class {
color: blue;
}
.parent-class .child-class {
border-color: currentColor;
}
currentColor can also be used by other rules which normally would not inherit from the color property, such as background-color. The example below shows the children using the color set in the parent as its background:
.parent-class {
color: blue;
}
.parent-class .child-class {
background-color: currentColor;
}
Possible Result:
Similar to rgb() notation, but with an additional alpha (opacity) value.
.red {
/* Opaque red */
color: rgba(255, 0, 0, 1);
}
.red-50p {
/* Half-translucent red. */
color: rgba(255, 0, 0, .5);
}
rgba(<red>, <green>, <blue>, <alpha>);
Value | Description |
---|---|
<red> | an integer from 0 - 255 or percentage from 0 - 100% |
<green> | an integer from 0 - 255 or percentage from 0 - 100% |
<blue> | an integer from 0 - 255 or percentage from 0 - 100% |
<alpha> | a number from 0 - 1, where 0.0 is fully transparent and 1.0 is fully opaque |
Similar to hsl() notation, but with an added alpha (opacity) value.
hsla(240, 100%, 50%, 0) /* transparent */
hsla(240, 100%, 50%, 0.5) /* half-translucent blue */
hsla(240, 100%, 50%, 1) /* fully opaque blue */
hsla(<hue>, <saturation>%, <lightness>%, <alpha>);
Value | Description |
---|---|
<hue> | specified in degrees around the color wheel (without units), where 0° is red, 60° is yellow, 120° is green, 180° is cyan, 240° is blue, 300° is magenta, and 360° is red |
<saturation> | percentage where 0% is fully desaturated (grayscale) and 100% is fully saturated (vividly colored) |
<lightness> | percentage where 0% is fully black and 100% is fully white |
<alpha> | a number from 0 - 1 where 0 is fully transparent and 1 is fully opaque |