CSS backgrounds and borders
{{CSSRef}}
The CSS backgrounds and borders module provides properties for adding backgrounds, borders, rounded corners, and box shadows to elements.
You can add different types of border styles, including borders made of images of any image type, from raster images to CSS gradients. Borders can be square or rounded, and a different radius can be set for each corner. Elements can be rounded whether or not they have a visible border.
Box shadows include inset and outset shadow, single or multiple shadows, and solid or allowed to fade to transparent. An outer box-shadow casts a shadow as if the border-box of the element were opaque. An inner box-shadow casts a shadow as if everything outside the padding edge were opaque. The shadow can be solid or include a spread distance with the shadow color transitioning to transparent.
The properties in this module also let you define whether cells inside a {{HTMLElement("table")}}
should have shared or separate borders.
Backgrounds, borders, and box shadows in action
This sample of borders, backgrounds, and box shadows consists of centered background images made of linear and radial gradients. A series of box shadows make the border appear to “pop”. The element on the left has a border image set. The element on the right has a rounded dotted border.
<article>
<div></div>
<div></div>
</article>
article {
display: flex;
gap: 10px;
}
div {
color: #58ade3;
height: 320px;
width: 240px;
padding: 20px;
margin: 10px;
border: dotted 15px; /* defaults to `currentcolor` */
border-radius: 100px 0;
background-image:
radial-gradient(
circle,
transparent 60%,
currentcolor 60% 70%,
transparent 70%
),
linear-gradient(45deg, currentcolor, white),
linear-gradient(transparent, transparent);
/* the third transparent background image was added to provide space for the background color to show through */
background-color: currentcolor;
background-position: center;
background-size:
60px 60px,
120px 120px;
background-clip: content-box, content-box, padding-box;
box-shadow:
inset 5px 5px 5px rgb(0 0 0 / 0.4),
inset -5px -5px 5px rgb(0 0 0 / 0.4),
5px 5px 5px rgb(0 0 0 / 0.4),
-5px -5px 5px rgb(0 0 0 / 0.4);
}
div:first-of-type {
border-radius: 0;
border-image-source: repeating-conic-gradient(
from 3deg at 25% 25%,
currentColor 0 3deg,
transparent 3deg 6deg
);
border-image-slice: 30;
}
{{EmbedLiveSample("backgrounds", "", "450px")}}
The background images are defined with {{cssxref("background-image")}}
. The images are centered with {{cssxref("background-position")}}
. Different values of the {{cssxref("background-clip")}}
property for the multiple background images are used to make the background images stay within the content box. The background color gets clipped to the padding box preventing the background from appearing through the transparent sections for the {{cssxref("border-image")}}
and the {{cssxref("border-style", "dotted")}}
{{cssxref("border")}}
. The rounded corners in the element on the right are created using the {{cssxref("border-radius")}}
property. A single {{cssxref("box-shadow")}}
declaration is used to set all the shadows, both inset and outset.
Click “Play” in the example above to see or edit the code for the animation in the MDN Playground.
Reference
Properties
-
{{cssxref("background-attachment")}}
-
{{cssxref("background-clip")}}
-
{{cssxref("background-color")}}
-
{{cssxref("background-image")}}
-
{{cssxref("background-origin")}}
-
{{cssxref("background-position")}}
-
{{cssxref("background-repeat")}}
-
{{cssxref("background-size")}}
-
{{cssxref("background")}}
shorthand -
{{cssxref("background-position-x")}}
-
{{cssxref("background-position-y")}}
-
{{cssxref("border-bottom-color")}}
-
{{cssxref("border-bottom-style")}}
-
{{cssxref("border-bottom-width")}}
-
{{cssxref("border-bottom")}}
shorthand -
{{cssxref("border-left-color")}}
-
{{cssxref("border-left-style")}}
-
{{cssxref("border-left-width")}}
-
{{cssxref("border-left")}}
shorthand -
{{cssxref("border-right-color")}}
-
{{cssxref("border-right-style")}}
-
{{cssxref("border-right-width")}}
-
{{cssxref("border-right")}}
shorthand -
{{cssxref("border-top-color")}}
-
{{cssxref("border-top-style")}}
-
{{cssxref("border-top-width")}}
-
{{cssxref("border-top")}}
shorthand -
{{cssxref("border-color")}}
shorthand -
{{cssxref("border-style")}}
shorthand -
{{cssxref("border-width")}}
shorthand -
{{cssxref("border")}}
shorthand -
{{cssxref("border-bottom-left-radius")}}
-
{{cssxref("border-bottom-right-radius")}}
-
{{cssxref("border-top-left-radius")}}
-
{{cssxref("border-top-right-radius")}}
-
{{cssxref("border-radius")}}
shorthand -
{{cssxref("border-image-outset")}}
-
{{cssxref("border-image-repeat")}}
-
{{cssxref("border-image-slice")}}
-
{{cssxref("border-image-source")}}
-
{{cssxref("border-image-width")}}
-
{{cssxref("border-image")}}
shorthand -
{{cssxref("box-shadow")}}
[!NOTE] The CSS backgrounds module level 4 introduces the
background-position-block
,background-position-inline
,background-repeat-block
,background-repeat-inline
,background-repeat-x
,background-repeat-y
, andbackground-tbd
properties. These have not yet been implemented.
Data types
{{cssxref("line-style")}}
enumerated type
Guides
- Using multiple backgrounds
- : Setting one or more backgrounds on an element.
- Resizing background images
- : Changing the size and repeating behavior of background images.
- Scaling of SVG backgrounds
- : How SVG aspect ratio, SVG dimension values, and the CSS
background-size
property impact the scaling of SVG background images.
- : How SVG aspect ratio, SVG dimension values, and the CSS
- Using CSS gradients
- : Creating CSS gradients and using them as background images.
- Learn CSS: background and borders
- : Learn how to implement decorative images using CSS background images.
- Learn CSS: the box model
- : Learn how borders and other box model properties impact the CSS box model.
Related concepts
-
{{cssxref("border-block-end-color")}}
property -
{{cssxref("border-block-start-color")}}
property -
{{cssxref("border-inline-end-color")}}
property -
{{cssxref("border-inline-start-color")}}
property -
{{cssxref("border-block-end-style")}}
property -
{{cssxref("border-block-start-style")}}
property -
{{cssxref("border-inline-end-style")}}
property -
{{cssxref("border-inline-start-style")}}
property -
{{cssxref("border-block-end-width")}}
property -
{{cssxref("border-block-start-width")}}
property -
{{cssxref("border-inline-end-width")}}
property -
{{cssxref("border-inline-start-width")}}
property -
{{cssxref("border-start-start-radius")}}
property -
{{cssxref("border-start-end-radius")}}
property -
{{cssxref("border-end-start-radius")}}
property -
{{cssxref("border-end-end-radius")}}
property -
{{cssxref("box-sizing")}}
property -
{{cssxref("box-decoration-break")}}
property -
{{cssxref("text-shadow")}}
property -
{{cssxref("url_value", "<url>")}}
CSS type -
<color>
data type -
<image>
data type -
<position>
data type -
currentcolor
keyword
Specifications
{{Specifications}}
See also
{{cssxref("filter")}}
{{cssxref("backdrop-filter")}}
drop-shadow()
filter function- Applying color to HTML elements using CSS
- Border-image generator
- Border-radius generator