@keyframes shine {
  to {
    background-position-x: -200%;
  }
}

.loading {
  background: linear-gradient(110deg, #ececec 8%, #f5f5f5 18%, #ececec 33%);
  border-radius: 5px;
  background-size: 200% 100%;
  animation: 1.5s shine linear infinite;
  color: transparent;
  width: fit-content;
}

.loading * {
  opacity: 0;
  color: transparent;
}

.loading-spinner {
  position: absolute;
  left: 50%;
  width: 100%;
  top: 50%;
  z-index: 1000;
  transform: translate(-50%, -50%);
}

.loader {
  margin: 0 auto;
  font-size: 5px;
  border-width: 1em;
}

@media (min-width: 992px) {
  .loader,
  .loader:after {
    width: 11em;
    height: 11em;
  }
}

.loader,
.loader:after {
  width: 9em;
  height: 9em;
}

.loader,
.loader:after {
  border-radius: 50%;
}

.loader {
  position: relative;
  text-indent: -9999em;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: rotate-spinner 0.5s infinite linear;
  animation: rotate-spinner 0.5s infinite linear;
}

.loader {
  width: 5em;
  height: 5em;
  width: 4.5em;
  height: 4.5em;
  border-top-width: 0.6em;
  border-right-width: 0.6em;
  border-bottom-width: 0.6em;
  border-left-width: 0.6em;
  border-top: 1.1em solid #e8e8e8;
  border-right: 1.1em solid #e8e8e8;
  border-bottom: 1.1em solid #e8e8e8;
  border-left: 1.1em solid #2daaef;
}

@-webkit-keyframes rotate-spinner {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes rotate-spinner {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
