--- title: Background description: Convey meaning through `background-color` and add decoration with gradients. toc: true --- import { getData } from '@libs/data' ## Background color Similar to the contextual text color classes, set the background of an element to any contextual class. Background utilities **do not set `color`**, so in some cases you’ll want to use `.text-*` [color utilities]([[docsref:/utilities/colors]]). Background utilities like `.bg-*` that generated from our original `$theme-colors` Sass map don’t yet respond to color modes, however, any `.bg-*-subtle` utility will. This will be resolved in v6. `
.bg-${themeColor.name}
.bg-${themeColor.name}-subtle
`), `
.bg-body-secondary
.bg-body-tertiary
.bg-body
.bg-black
.bg-white
.bg-transparent
` ]} /> ## Background gradient By adding a `.bg-gradient` class, a linear gradient is added as background image to the backgrounds. This gradient starts with a semi-transparent white which fades out to the bottom. Do you need a gradient in your custom CSS? Just add `background-image: var(--bs-gradient);`. {getData('theme-colors').map((themeColor) => { return (
.bg-{themeColor.name}.bg-gradient
) })}
.bg-black.bg-gradient
## Opacity As of v5.1.0, `background-color` utilities are generated with Sass using CSS variables. This allows for real-time color changes without compilation and dynamic alpha transparency changes. ### How it works Consider our default `.bg-success` utility. ```css .bg-success { --bs-bg-opacity: 1; background-color: rgba(var(--bs-success-rgb), var(--bs-bg-opacity)) !important; } ``` We use an RGB version of our `--bs-success` (with the value of `25, 135, 84`) CSS variable and attached a second CSS variable, `--bs-bg-opacity`, for the alpha transparency (with a default value `1` thanks to a local CSS variable). That means anytime you use `.bg-success` now, your computed `color` value is `rgba(25, 135, 84, 1)`. The local CSS variable inside each `.bg-*` class avoids inheritance issues so nested instances of the utilities don’t automatically have a modified alpha transparency. ### Example To change that opacity, override `--bs-bg-opacity` via custom styles or inline styles. This is default success background
This is 50% opacity success background
`} /> Or, choose from any of the `.bg-opacity` utilities: This is default success background
This is 75% opacity success background
This is 50% opacity success background
This is 25% opacity success background
This is 10% opacity success background
`} /> ## CSS In addition to the following Sass functionality, consider reading about our included [CSS custom properties]([[docsref:/customize/css-variables]]) (aka CSS variables) for colors and more. ### Sass variables Most `background-color` utilities are generated by our theme colors, reassigned from our generic color palette variables. Grayscale colors are also available, but only a subset are used to generate any utilities. Variables for setting `background-color` in `.bg-*-subtle` utilities in light and dark mode: ### Sass maps Theme colors are then put into a Sass map so we can loop over them to generate our utilities, component modifiers, and more. Grayscale colors are also available as a Sass map. **This map is not used to generate any utilities.** RGB colors are generated from a separate Sass map: Background color opacities build on that with their own map that’s consumed by the utilities API: Color mode background colors are also available as a Sass map: ### Sass mixins **No mixins are used to generate our background utilities**, but we do have some additional mixins for other situations where you’d like to create your own gradients. ### Sass utilities API Background utilities are declared in our utilities API in `scss/_utilities.scss`. [Learn how to use the utilities API.]([[docsref:/utilities/api#using-the-api]])