@media only screen and (min-width: 768px) {   
  .loading-spinner {
    animation-play-state: running;
    opacity: 1;
    position: relative;
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    height: 80px;
    padding: 40px 40px 0;
  }
  @keyframes spinner {
    0% {
      transform: translate3d(-50%, -50%, 0) rotate(0deg);
    }
    100% {
      transform: translate3d(-50%, -50%, 0) rotate(360deg);
    }
  }
  .loading-spinner.-paused {
    animation-play-state: paused;
    opacity: 0.2;
    transition: opacity linear 0.1s;
    display: none;
  }
  .loading-spinner::before {
    animation: 1.5s linear infinite spinner;
    animation-play-state: inherit;
    border: solid 3px #fff;
    border-bottom-color: #ef6565;
    border-radius: 50%;
    content: "";
    height: 40px;
    left: 50%;
    opacity: inherit;
    position: absolute;
    top: 50%;
    transform: translate3d(-50%, -50%, 0);
    width: 40px;
    will-change: transform;
  }
  .loading-spinner.-paused + .btn {
    background-color: #2ecc71;
    color: #323232;
  }
}