/* Usage
    <div class="my active dimmer">
        <div class="my text loader">Loading</div>
      </div>
*/
.my.dimmer {
    border-radius: inherit !important;
    display: none;
    position: absolute;
    top: 0 !important;
    left: 0 !important;
    width: 100%;
    height: 100%;
    text-align: center;
    vertical-align: middle;
    background-color: rgba(233, 238, 247, 0.72);
    opacity: 0;
    line-height: 1;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-duration: .5s;
    animation-duration: .5s;
    -webkit-transition: background-color .5s linear;
    transition: background-color .5s linear;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    will-change: opacity;
    z-index: 1000;
}

.my.active.dimmer {
    display: block;
    opacity: 1;
}

.my.active.dimmer .loader{
    display: block;
}
.my.dimmer .my.loader {
    color: black;
}

.my.loader {
    display: none;
    position: absolute;
    /* width: 2.28571429rem; */
    /* height: 2.28571429rem; */
    font-size: 1em;
    top: 50%;
    left: 50%;
    margin: 0;
    text-align: center;
    z-index: 1000;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}

.my.text.loader {
    width: auto !important;
    height: auto !important;
    text-align: center;
    font-style: normal;
    /* min-width: 2.28571429rem; */
    /* padding-top: 3.07142857rem; */
}


.my.loader:before {
    font-family: FontAwesome;
    font-size: 2em;
    display: block;
    /* position: absolute; */
    content: '\f110';
    /* top: 0; */
    /* left: 0; */
    width: 100%;
    height: 100%;
    -webkit-animation: fa-spin 1s infinite steps(8);
    animation: fa-spin 1s infinite steps(8);
}

.my.loader:after {
    -webkit-animation: fa-spin 1s infinite steps(8);
    animation: fa-spin 1s infinite steps(8);
}