html {
  background-color: #000000;
}

.fullscreen-loader {
  overflow: hidden;
  background-color: #000;
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  min-height: 100vh;
  max-height: 100vh;
  max-width: 100vw;
  min-width: 100vw;
}

/* https://codepen.io/stix/pen/qNZajO/ */
figure {
  margin: 0;
  transform: translate(-50%, -50%) rotate(0deg) scale(1.4, 1.4);
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 150px;
  box-sizing: border-box;
  animation: rotation 20s infinite linear;
}

figure div:after {
  content: '';
  width: 20px;
  height: 20px;
  border: 1px solid #fff;
  box-sizing: border-box;
  position: absolute;
  left: 20px;
  top: 20px;
  animation: shuffle 2s infinite;
}

figure div:nth-child(1) {
  transform: rotate(0deg);
}
figure div:nth-child(1):after {
  animation-delay: -0.5s;
}
figure div:nth-child(2) {
  transform: rotate(45deg);
}
figure div:nth-child(2):after {
  animation-delay: -1s;
}
figure div:nth-child(3) {
  transform: rotate(90deg);
}
figure div:nth-child(3):after {
  animation-delay: -1.5s;
}
figure div:nth-child(4) {
  transform: rotate(135deg);
}
figure div:nth-child(4):after {
  animation-delay: -2s;
}
figure div:nth-child(5) {
  transform: rotate(180deg);
}
figure div:nth-child(5):after {
  animation-delay: -2.5s;
}
figure div:nth-child(6) {
  transform: rotate(225deg);
}
figure div:nth-child(6):after {
  animation-delay: -3s;
}
figure div:nth-child(7) {
  transform: rotate(270deg);
}
figure div:nth-child(7):after {
  animation-delay: -3.5s;
}
figure div:nth-child(8) {
  transform: rotate(315deg);
}
figure div:nth-child(8):after {
  animation-delay: -4;
}

@keyframes rotation {
  100% {
    transform: translate(-50%, -50%) rotate(-360deg) scale(1.4, 1.4);
  }
}
@keyframes shuffle {
  50% {
    transform: scale(0.4, 0.4) rotate(-90deg);
    border-radius: 50%;
  }
}
