.app-css3-loading {
  width: 100%;
  height: 100vh;
  background: #f9f9f9;
  font-size: 12px;
  box-sizing: content-box;
}

.app-css3-loading .base {
  height: 9em;
  left: 50%;
  margin: -7.5em;
  padding: 3em;
  position: absolute;
  top: 50%;
  width: 9em;
  transform: rotateX(45deg) rotateZ(45deg);
  transform-style: preserve-3d;
  box-sizing: content-box;
}

.app-css3-loading .cube,
.app-css3-loading .cube:after,
.app-css3-loading .cube:before {
  content: '';
  float: left;
  height: 3em;
  position: absolute;
  width: 3em;
  color: #fff;
}

/* Top */
.app-css3-loading .cube {
  background-color: #2490e8;
  position: relative;
  transform: translateZ(3em);
  transform-style: preserve-3d;
  transition: .25s;
  box-shadow: 9em 9em 1.5em rgba(0, 0, 0, 0.1),
    0 0 1px #0161b1;
  animation: anim 1s infinite;
}

.app-css3-loading .cube:after {
  background-color: #205886;
  transform: rotateX(-90deg) translateY(3em);
  transform-origin: 100% 100%;
}

.app-css3-loading .cube:before {
  background-color: #0161b1;
  transform: rotateY(90deg) translateX(3em);
  transform-origin: 100% 0;
}

.app-css3-loading .cube:nth-child(1) {
  animation-delay: 0.05s;
}

.app-css3-loading .cube:nth-child(2) {
  animation-delay: 0.1s;
}

.app-css3-loading .cube:nth-child(3) {
  animation-delay: 0.15s;
}

.app-css3-loading .cube:nth-child(4) {
  animation-delay: 0.2s;
}

.app-css3-loading .cube:nth-child(5) {
  animation-delay: 0.25s;
}

.app-css3-loading .cube:nth-child(6) {
  animation-delay: 0.3s;
}

.app-css3-loading .cube:nth-child(7) {
  animation-delay: 0.35s;
}

.app-css3-loading .cube:nth-child(8) {
  animation-delay: 0.4s;
}

.app-css3-loading .cube:nth-child(9) {
  animation-delay: 0.45s;
}

@keyframes anim {
  50% {
    transform: translateZ(0.5em);
  }
}