Stacking Icons
You can stack our icons easily with the support styling bundled with Font Awesome.
We’ll cover the basics of aligning stacked icons alongside single icons, changing default font size, changing the default font size with stacking, and simple CSS customizations.
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>
Aligning Stacked and Regular Icons
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>
Changing the Default Font Size with Stacking
When you stack icons but change the font-size, you’ll need to make some adjustments to your CSS to keep the icons aligned.
<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>
Stacking Classes
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 |
Customization
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>