bottom
{{CSSRef}}
The bottom
CSS property participates in setting the vertical position of a positioned element. This {{glossary("inset properties", "inset property")}}
has no effect on non-positioned elements.
{{EmbedInteractiveExample("pages/css/bottom.html")}}
The effect of bottom
depends on how the element is positioned (i.e., the value of the {{cssxref("position")}}
property):
- When
position
is set toabsolute
orfixed
, thebottom
property specifies the distance between the outer edge of the element’s bottom margin and the outer edge of the containing block’s bottom padding, or, in the case of anchor positioned elements when the{{cssxref("anchor()")}}
function is used within the value, relative to the position of the specified<anchor-side>
edge. Thebottom
property is compatible with thetop
,bottom
,start
,end
,self-start
,self-end
,center
, and<percentage>
values. - When
position
is set torelative
, thebottom
property specifies the distance the element’s bottom edge is moved above its normal position. - When
position
is set tosticky
, thebottom
property is used to compute the sticky-constraint rectangle. - When
position
is set tostatic
, thebottom
property has no effect.
When both {{cssxref("top")}}
and bottom
are specified, position
is set to absolute
or fixed
, and {{cssxref("height")}}
is unspecified (either auto
or 100%
) both the top
and bottom
distances are respected. In all other situations, if {{cssxref("height")}}
is constrained in any way or position
is set to relative
, the top
property takes precedence and the bottom
property is ignored.
Syntax
/* <length> values */
bottom: 3px;
bottom: 2.4em;
bottom: calc(anchor(--myAnchor 50%) + 5px);
bottom: anchor-size(width);
/* <percentage>s of the height of the containing block */
bottom: 10%;
/* Keyword value */
bottom: auto;
/* Global values */
bottom: inherit;
bottom: initial;
bottom: revert;
bottom: revert-layer;
bottom: unset;
Values
-
{{cssxref("<length>")}}
-
: A negative, null, or positive
{{cssxref("<length>")}}
:- for absolutely positioned elements, it represents the distance to the bottom edge of the containing block.
- for relatively positioned elements, it represents the distance that the element is moved above its normal position.
- for anchor-positioned elements, the
{{cssxref("anchor()")}}
function resolves to a{{cssxref("<length>")}}
value relative to the position of the associated anchor element’s top or bottom edge (see Using inset properties withanchor()
function values), and the{{cssxref("anchor-size()")}}
function resolves to a{{cssxref("<length>")}}
value relative to the associated anchor element’s width or height (see Setting element position based on anchor size).
-
-
{{cssxref("<percentage>")}}
- : A
{{cssxref("<percentage>")}}
of the containing block’s height.
- : A
-
auto
-
: Specifies that:
- for absolutely positioned elements, the position of the element is based on the
{{Cssxref("top")}}
property, whileheight: auto
is treated as a height based on the content; or iftop
is alsoauto
, the element is positioned where it should vertically be positioned if it were a static element. - for relatively positioned elements, the distance of the element from its normal position is based on the
{{Cssxref("top")}}
property; or iftop
is alsoauto
, the element is not moved vertically at all.
- for absolutely positioned elements, the position of the element is based on the
-
-
inherit
- : Specifies that the value is the same as the computed value from its parent element (which might not be its containing block). This computed value is then handled as if it were a
{{cssxref("<length>")}}
,{{cssxref("<percentage>")}}
, or theauto
keyword.
- : Specifies that the value is the same as the computed value from its parent element (which might not be its containing block). This computed value is then handled as if it were a
Formal definition
{{cssinfo}}
Formal syntax
{{csssyntax}}
Examples
Absolute and fixed positioning
This example demonstrates the difference in behavior of the bottom
property, when {{cssxref("position")}}
is absolute
versus fixed
.
HTML
<p>
This<br />is<br />some<br />tall,<br />tall,<br />tall,<br />tall,<br />tall<br />content.
</p>
<div class="fixed"><p>Fixed</p></div>
<div class="absolute"><p>Absolute</p></div>
CSS
p {
font-size: 30px;
line-height: 2em;
}
div {
width: 48%;
text-align: center;
background: rgb(55 55 55 / 20%);
border: 1px solid blue;
}
.absolute {
position: absolute;
bottom: 0;
left: 0;
}
.fixed {
position: fixed;
bottom: 0;
right: 0;
}
Result
{{EmbedLiveSample('Absolute_and_fixed_positioning','500','250')}}
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}
See also
{{cssxref("top")}}
,{{cssxref("left")}}
, and{{cssxref("right")}}
{{cssxref("inset")}}
shorthand{{cssxref("inset-block-start")}}
,{{cssxref("inset-block-end")}}
,{{cssxref("inset-inline-start")}}
, and{{cssxref("inset-inline-end")}}
{{cssxref("inset-block")}}
and{{cssxref("inset-inline")}}
shorthands{{cssxref("position")}}
- CSS positioned layout module