@keyframes loaderSpin {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(180deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.c-loading {
  $self: #{&};
  $spinner: #{$self}__spinner;
  $text: #{$self}__text;

  $border: none;
  $border-radius: 10px;

  $spinner-size: 45px;
  $spinner-border: 6px solid;
  $spinner-color: $color-primary;
  $spinner-track-color: $g-border-color;

  $text-color: #555;
  $text-size: 1.2rem;

  @at-root {
    #{$self} {
      display: inline-flex;
      flex-flow: row nowrap;
      justify-content: center;
      align-items: center;
      padding: 10px;
      background-color: #fff;
      border: $border;
      border-radius: $border-radius;
      text-align: center;
      font-size: $text-size;
      color: $text-color;
      overflow: hidden;
    }

    #{$spinner} {
      position: relative;
      display: block;
      font-size: $spinner-size;
      width: 1em;
      height: 1em;
      margin: 0 auto;

      &:before,
      &:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        display: block;
        width: 100%;
        height: 100%;
        border-radius: 50%;
      }

      &:before {
        z-index: 2;
        border: $spinner-border;
        border-color: transparent transparent transparent $spinner-color;
        animation: loaderSpin 0.6s linear infinite;
      }

      &:after {
        z-index: 1;
        border: $spinner-border;
        border-color: $spinner-track-color;
      }
    }

    #{$text} {
      display: block;
      margin-left: 1em;
      font-weight: bold;
      font-size: 1em;
    }

    #{$self} {

      @include make-modifier('elevated') {
        @include box-elevation();
      }

      @include make-modifier('dense') {
        padding: 5px;
        font-size: 1rem;

        #{$spinner} {
          font-size: 30px;
        }
      }

    }

  }

}
