In CSS, combinators define relationships between selectors. Instead of selecting elements individually, combinators allow you to target elements based on how they are positioned within the HTML structure.
Software developers are building the future. Become part of them.
There are four main CSS combinators:
- Descendant Combinator (
space) - Child Combinator (
>) - Adjacent Sibling Combinator (
+) - General Sibling Combinator (
~)
Let’s break each down—definitions, diagrams, and examples.
1. Descendant Combinator ( – space)
Selects any element nested inside another, at any depth.
✔ Meaning
A B = Select B only if it exists anywhere inside A.
✔ Example HTML
<div class="container">
<p>First paragraph</p>
<div>
<p>Nested paragraph</p>
</div>
</div>
✔ CSS
.container p {
color: blue;
}
✔ Output
All <p> elements inside .container—no matter how deeply nested—turn blue.
✔ When to Use
- Styling items inside a section, card, or container
- Applying generic rules to nested structures
2. Child Combinator (>)
Selects direct children only, not deeper descendants.
✔ Meaning
A > B = Select B only if it is a direct child of A.
✔ Example HTML
<ul class="menu">
<li>Home</li>
<li>
About
<ul>
<li>Team</li>
</ul>
</li>
</ul>
✔ CSS
.menu > li {
font-weight: bold;
}
✔ Output
Only the top-level list items (Home and About) become bold, not the nested “Team” item.
✔ When to Use
- Navigation menus
- Card layouts with direct children
- Preventing styles from going too deep
3. Adjacent Sibling Combinator (+)
Selects the immediately next sibling element.
✔ Meaning
A + B = Select B only if it comes right after A.
✔ Example HTML
<h2>Title</h2>
<p>Subtitle paragraph</p>
<p>Another paragraph</p>
✔ CSS
h2 + p {
margin-top: 0;
}
✔ Output
Only the first <p> after <h2> is affected.
✔ When to Use
- Removing margin/padding between specific elements
- Styling the first item after a header or block
- Form validation messages right after an input field
4. General Sibling Combinator (~)
Selects all siblings that come after a specified element—not just the first one.
✔ Meaning
A ~ B = Select every B that appears after A in the same parent.
✔ Example HTML
<div>
<h3>Header</h3>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</div>
✔ CSS
h3 ~ p {
color: green;
}
✔ Output
All <p> elements after <h3> turn green.
✔ When to Use
- Styling all following elements until the next major block
- Applying rules to related items
- Form help-text blocks after an input
Table of CSS Combinators
| Combinator | Symbol | Selects | Example | Meaning |
|---|---|---|---|---|
| Descendant | (space) | Any nested element | div p | All <p> inside <div> |
| Child | > | Direct children | ul > li | Only top-level <li> |
| Adjacent Sibling | + | Next element only | h1 + p | Only the first <p> after <h1> |
| General Sibling | ~ | All following siblings | h1 ~ p | All <p> after <h1> |
Pro Tips for Mastery
✔ 1. Descendant combinators are the most expensive
Use them sparingly in large apps for performance.
✔ 2. Use child combinators when building components
They prevent styles from leaking into unintended nested elements.
✔ 3. Adjacent and general siblings are great for form UX
Example:
input.error + small {
color: red;
}
✔ 4. Combine combinators for powerful selectors
Example:
.card > h2 + p {
opacity: 0.7;
}
Meaning: Select the <p> that comes right after <h2> inside .card.
Final Thoughts
CSS combinators are essential for writing clean, predictable, and efficient styles. They allow you to target elements based on their structural relationship, making your CSS more modular and powerful.

Latest tech news and coding tips.