/* Make clicks pass-through */
#nprogress {
  pointer-events: none;
}

.nprogress-busy body {
  cursor: wait;
}

#nprogress .bar {
  background: #5bc0de;

  position: fixed;
  z-index: 99031;
  top: 0;
  left: 0;

  width: 100%;
  height: 8px;
}

/* Fancy blur effect */
#nprogress .peg {
  display: block;
  position: absolute;
  right: 0px;
  width: 100px;
  height: 100%;
  box-shadow: 0 0 10px #5bc0de, 0 0 15px #5bc0de;
  opacity: 1.0;

  -webkit-transform: rotate(3deg) translate(0px, -4px);
      -ms-transform: rotate(3deg) translate(0px, -4px);
          transform: rotate(3deg) translate(0px, -4px);
}

/* Remove these to get rid of the spinner */
#nprogress .spinner {
  display: block;
  position: fixed;
  z-index: 99031;
  top: 20px;
  left: 20px;
}

#nprogress .spinner-icon {
  width: 32px;
  height: 32px;
  box-sizing: border-box;

  border: solid 6px transparent;
  border-top-color: #5bc0de;
  border-left-color: #8a8f94;
  border-radius: 50%;

  -webkit-animation: nprogress-spinner 400ms linear infinite;
          animation: nprogress-spinner 400ms linear infinite;
}

.nprogress-custom-parent {
  overflow: hidden;
  position: relative;
}

.nprogress-custom-parent #nprogress .spinner,
.nprogress-custom-parent #nprogress .bar {
  position: absolute;
}

@-webkit-keyframes nprogress-spinner {
  0%   { -webkit-transform: rotate(0deg); }
  100% { -webkit-transform: rotate(360deg); }
}
@keyframes nprogress-spinner {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Loading Mask */
/* Absolute Center Spinner */
.loading {
    position: fixed;
    z-index: 999;
    height: 2em;
    width: 2em;
    overflow: visible;
    margin: auto;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

    /* Transparent Overlay */
    .loading:before {
        content: '';
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: #fff;
    }

    /* :not(:required) hides these rules from IE9 and below */
    .loading:not(:required) {
        /* hide "loading..." text */
        font: 0/0 a;
        color: transparent;
        text-shadow: none;
        background-color: transparent;
        border: 0;
    }

        .loading:not(:required):after {
            content: '';
            display: block;
            font-size: 10px;
            width: 1em;
            height: 1em;
            margin-top: -0.5em;
            -webkit-animation: spinner 1500ms infinite linear;
            -moz-animation: spinner 1500ms infinite linear;
            -ms-animation: spinner 1500ms infinite linear;
            -o-animation: spinner 1500ms infinite linear;
            animation: spinner 1500ms infinite linear;
            border-radius: 0.5em;
            -webkit-box-shadow: rgba(0, 0, 0, 0.40) 1.5em 0 0 0, rgba(0, 0, 0, 0.40) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) 0 1.5em 0 0, rgba(0, 0, 0, 0.40) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.40) 0 -1.5em 0 0, rgba(0, 0, 0, 0.40) 1.1em -1.1em 0 0;
            box-shadow: rgba(0, 0, 0, 0.40) 1.5em 0 0 0, rgba(0, 0, 0, 0.40) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) 0 1.5em 0 0, rgba(0, 0, 0, 0.40) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) -1.5em 0 0 0, rgba(0, 0, 0, 0.40) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.40) 0 -1.5em 0 0, rgba(0, 0, 0, 0.40) 1.1em -1.1em 0 0;
        }

/* Absolute Center Spinner */
.component-loading {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 999;
    overflow: visible;
    margin: auto;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: #fff
}

    /* Transparent Overlay */
    .component-loading:before {
        content: '';
        display: block;
        position: inherit;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    /* :not(:required) hides these rules from IE9 and below */
    .component-loading:not(:required) {
        /* hide "loading..." text */
        font: 0/0 a;
        color: transparent;
        text-shadow: none;
        background-color: transparent;
        border: 0;
    }

        .component-loading:not(:required):after {
            content: '';
            display: block;
            font-size: 10px;
            width: 1em;
            height: 1em;
            -webkit-animation: spinner 1500ms infinite linear;
            -moz-animation: spinner 1500ms infinite linear;
            -ms-animation: spinner 1500ms infinite linear;
            -o-animation: spinner 1500ms infinite linear;
            animation: spinner 1500ms infinite linear;
            border-radius: 0.5em;
            -webkit-box-shadow: rgba(0, 0, 0, 0.40) 1.5em 0 0 0, rgba(0, 0, 0, 0.40) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) 0 1.5em 0 0, rgba(0, 0, 0, 0.40) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.40) 0 -1.5em 0 0, rgba(0, 0, 0, 0.40) 1.1em -1.1em 0 0;
            box-shadow: rgba(0, 0, 0, 0.40) 1.5em 0 0 0, rgba(0, 0, 0, 0.40) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) 0 1.5em 0 0, rgba(0, 0, 0, 0.40) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.40) -1.5em 0 0 0, rgba(0, 0, 0, 0.40) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.40) 0 -1.5em 0 0, rgba(0, 0, 0, 0.40) 1.1em -1.1em 0 0;
        }

/* Animation */

@-webkit-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-moz-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-o-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}