Skip to main content
Figuration v3 Preview Available!

Dozens of utility classes with a single purpose designed to reduce the frequency of highly repetitive declarations in your CSS while allowing for quick and easy development.

Screen Readers & Visibility

Hide content without sacrificing accessibility.


Screen Readers and Keyboard Users

Hide an element to all devices except screen readers with .sr-only. Combine .sr-only with .sr-only-focusable to show the element again when it’s focused (e.g. by a keyboard-only user). Can also be used as mixins.

There are also responsive variants available in the form .sr-only-{breakpoint}-{up/down}. For example, to visually hide content, except for screen readers, for a sm or smaller screens you would use .sr-only-sm-down.

These classes are exceptionally useful helping to follow accessibility best practices.

<a class="sr-only sr-only-focusable" href="#content">Skip to main content</a>

<span class="sr-only-sm-down">...</span>
// Usage as a mixin
.skip-navigation {
  @include sr-only;
  @include sr-only-focusable;

Hidden Content

Force an element to be hidden (including for screen readers) with the use of .hide-{breakpoint}-{up/down} classes. These classes use !important to avoid specificity conflicts. For example, to hide content for lg or larger screens you would use .hide-lg-up.

A section on the responsive utilities layout page gives more detail about how these classes and breakpoints are related.

<span class="hide-lg-up">...</span>
<span class="hide-sm-down">...</span>

Invisible Content

The .invisible and .visible classes can be used to toggle only the visibility of an element, meaning its display is not modified and the element can still affect the flow of the document.

<div class="invisible">...</div>
<div class="visible">...</div>
// Class
.invisible {
  visibility: hidden !important;
.visible {
  visibility: visible !important;

// Usage as a mixins
.element {
  @include invisible;
.element {
  @include visible;