The document tree:
All HTML documents are trees.
Each level of the tree is described in the same manner as a human family tree, with ancestors, descendants, parents, children and siblings. CSS rules are based on the document tree.
Eg:
<body>
<div id="content">
<h1>Heading here</h1>
<p>Lorem ipsum dolor sit amet.</p>
<p>Lorem ipsum dolor <em>sit</em> amet.</p>
<hr>
</div>
<div id="nav">
<ul>
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
</div>
</body>
data:image/s3,"s3://crabby-images/4d0bb/4d0bb1a5699a5bde1b19fb3675b6b08c56a2af11" alt="tree1"
Ancestor:
An ancestor refers to any element that is connected but further up the document tree - no matter how many levels higher.
The <body> element is the ancestor of all other elements on the page.
Descendant:
A descendant refers to any element that is connected but lower down the document tree - no matter how many levels lower.
Eg: all elements that are connected below the <div> element are descendants of that <div> in blue.
data:image/s3,"s3://crabby-images/b6e13/b6e1356b6d161d2d56178d2d96b9d7c606f06d92" alt="tree2"
Parent:
A parent is an element that is directly above and connected to an element in the document tree.
data:image/s3,"s3://crabby-images/baa61/baa615955d437baa8e07dc68143fff6f1f5f2649" alt="tree3"
Child:
A child is an element that is directly below and connected to an element in the document tree.
Sibling:
A sibling is an element that shares the same parent with another element. In the diagram below, the <li>'s are siblings as they all share the same parent - the <ul>.
data:image/s3,"s3://crabby-images/03eb8/03eb87dbb24bdf6ab559b5e6a51f4a69a0bc54d5" alt="tree4"