body.loader-body {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  overflow: hidden;
}


/* █ █ █ █ █ █ █ █ █ █ █ █ █ █ █ █ █ */


.loader {
  position: relative;
  width: 150px;
  min-width: 110px;
  overflow: visible;
  margin: 20px;
  border-radius: 50%;
  box-shadow: inset 0 0 8px rgba(255, 255, 255, 0.4), 0 0 25px rgba(255, 255, 255, 0.8);
}
  
.loader::after {
  content: attr(data-text);
  color: #CECECE;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  font-size: calc(70% + 0.10vw);
  text-transform: uppercase;
  letter-spacing: 5px;
}

/* Keep ratio on resize*/
.loader::before {
  content: '';
  float: left;
  padding-top: 100%;
}

@keyframes ldio-c7ne3t13pb4 {
  0% { transform: translate(-50%,-50%) rotate(0deg); }
  100% { transform: translate(-50%,-50%) rotate(360deg); }
}
.ldio-c7ne3t13pb4 div {
  position: absolute;
  width: 40px;
  height: 40px;
  border: 8px solid #0070f2;
  border-top-color: transparent;
  border-radius: 50%;
}
.ldio-c7ne3t13pb4 div {
  animation: ldio-c7ne3t13pb4 1s linear infinite;
  top: 100px;
  left: 100px
}
.loadingio-spinner-rolling-3vqrjqdg5he {
  width: 200px;
  height: 200px;
  display: inline-block;
  overflow: hidden;
  background: none;
}
.ldio-c7ne3t13pb4 {
  width: 100%;
  height: 100%;
  position: relative;
  transform: translateZ(0) scale(1);
  backface-visibility: hidden;
  transform-origin: 0 0; /* see note above */
}
.ldio-c7ne3t13pb4 div { box-sizing: content-box; }
/* generated by https://loading.io/ */
