files/en-us/web/css/reference/properties/margin/index.md
The margin CSS shorthand property sets the margin area on all four sides of an element.
{{InteractiveExample("CSS Demo: margin")}}
margin: 1em;
margin: 5% 0;
margin: 10px 50px 20px;
margin: 10px 50px 20px 0;
margin: 0;
<section id="default-example">
<div id="container">
<div class="row"></div>
<div class="row transition-all" id="example-element"></div>
<div class="row"></div>
</div>
</section>
#container {
width: 300px;
height: 200px;
display: flex;
align-content: flex-start;
flex-direction: column;
justify-content: flex-start;
}
.row {
height: 33.33%;
display: inline-block;
border: solid #ce7777 10px;
background-color: #2b3a55;
flex-shrink: 0;
}
#example-element {
border: solid 10px #ffbf00;
background-color: #2b3a55;
}
This property is a shorthand for the following CSS properties:
/* apply to all four sides */
margin: 1em;
margin: -3px;
/* top and bottom | left and right */
margin: 5% auto;
/* top | left and right | bottom */
margin: 1em auto 2em;
/* top | right | bottom | left */
margin: 2px 1em 0 auto;
/* anchor-size() values */
margin: 5% anchor-size(width);
margin: calc(anchor-size(width) / 4) 1em 0
anchor-size(--my-anchor self-inline, 50px);
/* Keyword values */
margin: auto;
/* Global values */
margin: inherit;
margin: initial;
margin: revert;
margin: revert-layer;
margin: unset;
The margin property may be specified using one, two, three, or four values. Each value is a {{cssxref("<length>")}}, a {{cssxref("<percentage>")}}, or the keyword auto. Negative values draw the element closer to its neighbors than it would be by default.
{{cssxref("length")}}
{{cssxref("percentage")}}
auto
This property can be used to set a margin on all four sides of an element. Margins create extra space around an element, unlike {{cssxref("padding")}}, which creates extra space within an element.
The top and bottom margins have no effect on non-replaced inline elements, such as {{HTMLElement("span")}} or {{HTMLElement("code")}}.
You can horizontally center an element within its parent by setting margin: 0 auto;.
A more common method to center an element horizontally is by setting display: flex; and justify-content: center; on a container, which centers its flex item children.
Elements' top and bottom margins are sometimes collapsed into a single margin that is equal to the larger of the two margins. See Mastering margin collapsing for more information.
{{cssinfo}}
{{csssyntax}}
<div class="center">This element is centered.</div>
<div class="outside">This element is positioned outside of its container.</div>
.center {
margin: auto;
background: lime;
width: 66%;
}
.outside {
margin: 3rem 0 0 -3rem;
background: cyan;
width: 66%;
}
{{ EmbedLiveSample('Basic_example','100%',120) }}
margin: 5%; /* All sides: 5% margin */
margin: 10px; /* All sides: 10px margin */
margin: 1.6em 20px; /* top and bottom: 1.6em margin */
/* left and right: 20px margin */
margin: 10px 3% -1em; /* top: 10px margin */
/* left and right: 3% margin */
/* bottom: -1em margin */
margin: 10px 3px 30px 5px; /* top: 10px margin */
/* right: 3px margin */
/* bottom: 30px margin */
/* left: 5px margin */
margin: 2em auto; /* top and bottom: 2em margin */
/* Box is horizontally centered */
margin: auto; /* top and bottom: 0 margin */
/* Box is horizontally centered */
{{Specifications}}
{{Compat}}