You can stack our icons easily with the support styling bundled with Font Awesome.
To stack multiple icons, use the fa-stack
class on the parent HTML element of the 2 icons you want to stack. Then add the fa-stack-1x
class for the regularly sized icon and add the fa-stack-2x
class for the larger icon. fa-inverse
can be added to the icon with the fa-stack-1x
to help with a knock-out looking effect. You can even throw larger icon classes on the parent to get further control of sizing.
<span class="fa-stack fa-2x">
<i class="fa-solid fa-square fa-stack-2x"></i>
<i class="fab fa-twitter fa-stack-1x fa-inverse"></i>
</span>
<span class="fa-stack fa-2x">
<i class="fa-solid fa-circle fa-stack-2x"></i>
<i class="fa-solid fa-flag fa-stack-1x fa-inverse"></i>
</span>
<span class="fa-stack fa-2x">
<i class="fa-solid fa-camera fa-stack-1x"></i>
<i class="fa-solid fa-ban fa-stack-2x" style="color:Tomato"></i>
</span>
<span class="fa-stack fa-2x">
<i class="fa-solid fa-square fa-stack-2x"></i>
<i class="fa-solid fa-terminal fa-stack-1x fa-inverse"></i>
</span>
<span class="fa-stack fa-4x">
<i class="fa-solid fa-square fa-stack-2x"></i>
<i class="fa-solid fa-terminal fa-stack-1x fa-inverse"></i>
</span>
You can use stacked icons right alongside single icons. Since stacked icons are styled by our framework's included CSS to be twice the size of single icons, you'll need to either size down the stacked icon or size up the single icons.
<i class="fa-regular fa-circle fa-2x"></i>
<span class="fa-stack" style="vertical-align: top;">
<i class="fa-regular fa-circle fa-stack-2x"></i>
<i class="fa-solid fa-flag fa-stack-1x"></i>
</span>
<span class="fa-stack" style="vertical-align: top;">
<i class="fa-solid fa-circle fa-stack-2x"></i>
<i class="fa-solid fa-flag fa-stack-1x fa-inverse"></i>
</span>
<i class="fa-regular fa-circle fa-2x"></i>
When you stack icons but change the font-size, you'll need to make some adjustments to your CSS to keep the icons aligned.
You'll need to write your own custom rules if you change the default font-size
of stacked icons as well as depending on your layout needs (by default stacked icons are set to display: inline-block;
and vertical-align:middle;
).
<style>
.fa-stack.small { font-size: 0.5em; }
i { vertical-align: middle; }
</style>
<i class="fa-regular fa-circle"></i>
<span class="fa-stack small">
<i class="fa-regular fa-circle fa-stack-2x"></i>
<i class="fa-solid fa-flag fa-stack-1x"></i>
</span>
<span class="fa-stack small">
<i class="fa-solid fa-circle fa-stack-2x"></i>
<i class="fa-solid fa-flag fa-stack-1x fa-inverse"></i>
</span>
<i class="fa-regular fa-circle"></i>
Class | Details |
---|---|
fa-stack | Used on a parent HTML element of the two icons to be stacked |
fa-stack-1x | Used on the icon which should be displayed at base size when stacked |
fa-stack-2x | Used on the icon which should be displayed larger when stacked |
fa-inverse | Inverts the color of the icon displayed at base size when stacked |
We've added CSS custom properties to make customizing easier and more efficient. Define your own values for the following properties to override and customize Font Awesome's defaults.
CSS Custom Property | Details | Accepted Values |
---|---|---|
--fa-stack-z-index | Set z-index of a stacked icon | Any valid CSS z-index value |
--fa-inverse | Set color of an inverted stacked icon | Any valid CSS color value |
<span class="fa-stack fa-2x">
<i class="fab fa-twitter fa-stack-1x fa-inverse" style="--fa-stack-z-index: 2;"></i>
<i class="fa-solid fa-square fa-stack-2x" style="--fa-stack-z-index: 1;"></i>
</span>
<span class="fa-stack fa-2x" style="--fa-inverse: #1da1f2;">
<i class="fa-solid fa-square fa-stack-2x"></i>
<i class="fab fa-twitter fa-stack-1x fa-inverse"></i>
</span>
Our SVG + JS method includes powerful ways to mask and layer that allows for rotating an icon on a more granular scale, even by a single degree! If you're using Font Awesome that way, check it out.