prefers-contrast
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since May 2022.
Theprefers-contrastCSSmedia feature is used to detect whether the user has requested the web content to be presented with a lower or higher contrast.
In this article
Syntax
no-preferenceIndicates that the user has made no preference known to the system. This keyword value evaluates as false in the Boolean context.
moreIndicates that user has notified the system that they prefer an interface that has a higher level of contrast.
lessIndicates that user has notified the system that they prefer an interface that has a lower level of contrast.
customIndicates that user has notified the system for using a specific set of colors, and the contrast implied by these colors matches neither
morenorless. This value will match the color palette specified by users offorced-colors: active.
User preferences
Various operating systems do support such preferences and user agents are likely to rely on the settings provided by the operating system.
Examples
This example includes a box with a dashedoutline set on it by default. When theprefers-contrast: more media query matches, the applied outline is given a higher contrastsolid style instead.
HTML
<div>low contrast box</div>CSS
.contrast { margin: 5px; width: 100px; height: 100px; outline: 2px dashed black;}@media (prefers-contrast: more) { .contrast { outline: 2px solid black; }}Result
Specifications
| Specification |
|---|
| Media Queries Level 5> # prefers-contrast> |
Browser compatibility
See also
- CSSforced-colors media query