/* -- LOADER -- */
:root {
  --color: #fff;
}

/*  BouncyArc */
.bouncy-arc-container {
  --uib-size: 35px;
  --uib-color: var(--color);
  --uib-speed: 1.65s;
  --uib-cube-size: calc(var(--uib-size) / 5.5);
  --uib-arc-1: -80deg;
  --uib-arc-2: 80deg;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: var(--uib-size);
  height: calc(var(--uib-size) * 0.51);
}

.bouncy-arc {
  width: var(--uib-cube-size);
  height: calc(var(--uib-size) * 0.5);
  transform-origin: center bottom;
  transform: rotate(var(var(--uib-arc-1)));
  animation: metronome var(--uib-speed) linear infinite;

  &::after {
    content: '';
    display: block;
    width: var(--uib-cube-size);
    height: var(--uib-cube-size);
    background-color: var(--uib-color);
    border-radius: 25%;
    animation: morph var(--uib-speed) linear infinite;
    transition: background-color 0.3s ease;
  }
}

@keyframes metronome {
  0% {
    transform: rotate(var(--uib-arc-1));
  }

  5% {
    transform: rotate(var(--uib-arc-1));
    animation-timing-function: ease-out;
  }

  50% {
    transform: rotate(var(--uib-arc-2));
  }

  55% {
    transform: rotate(var(--uib-arc-2));
    animation-timing-function: ease-out;
  }

  100% {
    transform: rotate(var(--uib-arc-1));
  }
}

@keyframes morph {
  0%,
  5% {
    transform: scaleX(0.75) scaleY(1.25);
    transform-origin: center left;
  }

  12.5% {
    transform: scaleX(1.5);
    transform-origin: center left;
  }

  27.5% {
    transform: scaleX(1);
    transform-origin: center left;
  }

  27.5001%,
  42.5% {
    transform: scaleX(1);
    transform-origin: center right;
  }

  50%,
  52.5% {
    transform: scaleX(0.75) scaleY(1.25);
    transform-origin: center right;
    animation-timing-function: ease-in;
  }

  65% {
    transform: scaleX(1.5);
    transform-origin: center right;
  }

  77.5% {
    transform: scaleX(1);
    transform-origin: center right;
  }

  77.5001%,
  95% {
    transform: scaleX(1);
    transform-origin: center left;
  }

  100% {
    transform: scaleX(0.75) scaleY(1.25);
    transform-origin: center left;
  }
}
/*  .BouncyArc */

/* Bouncy */
.bouncy-container {
  --uib-size: 45px;
  --uib-color: var(--color);
  --uib-speed: 1.75s;
  display: flex;
  align-items: flex-end;
  /* padding-bottom: 20%; */
  justify-content: space-between;
  width: var(--uib-size);
  height: calc(var(--uib-size) * 0.6);
}

.bouncy {
  flex-shrink: 0;
  width: calc(var(--uib-size) * 0.2);
  height: calc(var(--uib-size) * 0.2);
  animation: jump var(--uib-speed) ease-in-out infinite;
}

.bouncy__inner {
  display: block;
  height: 100%;
  width: 100%;
  border-radius: 25%;
  background-color: var(--uib-color);
  transform-origin: center bottom;
  animation: morph var(--uib-speed) ease-in-out infinite;
  transition: background-color 0.3s ease;
}

.bouncy:nth-child(2) {
  animation-delay: calc(var(--uib-speed) * -0.36);

  .bouncy__inner {
    animation-delay: calc(var(--uib-speed) * -0.36);
  }
}
.bouncy:nth-child(3) {
  animation-delay: calc(var(--uib-speed) * -0.2);

  .bouncy__inner {
    animation-delay: calc(var(--uib-speed) * -0.2);
  }
}

@keyframes jump {
  0% {
    transform: translateY(0px);
  }

  30% {
    transform: translateY(0px);
    animation-timing-function: ease-out;
  }

  50% {
    transform: translateY(-200%);
    animation-timing-function: ease-in;
  }

  75% {
    transform: translateY(0px);
    animation-timing-function: ease-in;
  }
}

@keyframes morph {
  0% {
    transform: scaleY(1);
  }

  10% {
    transform: scaleY(1);
  }

  20%,
  25% {
    transform: scaleY(0.6) scaleX(1.3);
    animation-timing-function: ease-in-out;
  }

  30% {
    transform: scaleY(1.15) scaleX(0.9);
    animation-timing-function: ease-in-out;
  }

  40% {
    transform: scaleY(1);
  }

  70%,
  85%,
  100% {
    transform: scaleY(1);
  }

  75% {
    transform: scaleY(0.8) scaleX(1.2);
  }
}
/* .Bouncy */

/* RING */
.ring-container {
  --uib-size: 17px;
  --uib-color: var(--color);
  --uib-speed: 2s;
  --uib-bg-opacity: 0;
  height: var(--uib-size);
  width: var(--uib-size);
  transform-origin: center;
  animation: rotate var(--uib-speed) linear infinite;
  will-change: transform;
  overflow: visible;
}

.ring-car {
  fill: none;
  stroke: var(--uib-color);
  stroke-dasharray: 1, 200;
  stroke-dashoffset: 0;
  stroke-linecap: round;
  animation: stretch calc(var(--uib-speed) * 0.75) ease-in-out infinite;
  will-change: stroke-dasharray, stroke-dashoffset;
  transition: stroke 0.5s ease;
}

.ring-track {
  fill: none;
  stroke: var(--uib-color);
  opacity: var(--uib-bg-opacity);
  transition: stroke 0.5s ease;
}

@keyframes rotate {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes stretch {
  0% {
    stroke-dasharray: 0, 150;
    stroke-dashoffset: 0;
  }
  50% {
    stroke-dasharray: 75, 150;
    stroke-dashoffset: -25;
  }
  100% {
    stroke-dashoffset: -100;
  }
}
/* .RING */

/* WaveForm */
.waveform-container {
  --uib-size: 35px;
  --uib-color: var(--color);
  --uib-speed: 1s;
  --uib-stroke: 3.5px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: var(--uib-size);
  height: calc(var(--uib-size) * 0.9);
}

.waveform-container .bar {
  width: var(--uib-stroke);
  height: 100%;
  background-color: var(--uib-color);
  transition: background-color 0.3s ease;
}

.waveform-container .bar:nth-child(1) {
  animation: grow var(--uib-speed) ease-in-out calc(var(--uib-speed) * -0.45) infinite;
}

.waveform-container .bar:nth-child(2) {
  animation: grow var(--uib-speed) ease-in-out calc(var(--uib-speed) * -0.3) infinite;
}

.waveform-container .bar:nth-child(3) {
  animation: grow var(--uib-speed) ease-in-out calc(var(--uib-speed) * -0.15) infinite;
}

.waveform-container .bar:nth-child(4) {
  animation: grow var(--uib-speed) ease-in-out infinite;
}

@keyframes grow {
  0%,
  100% {
    transform: scaleY(0.3);
  }

  50% {
    transform: scaleY(1);
  }
}
/* .WaveForm */

/* Quantum */
.quantum-container {
  --uib-size: 45px;
  --uib-color: var(--color);
  --uib-speed: 1.75s;
  position: relative;
  height: var(--uib-size);
  width: var(--uib-size);
  animation: rotate calc(var(--uib-speed) * 4) linear infinite;
}

@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.quantum-container .particle {
  position: absolute;
  top: 0%;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;

  &:nth-child(1) {
    --uib-delay: 0;
    transform: rotate(8deg);
  }
  &:nth-child(2) {
    --uib-delay: -0.4;
    transform: rotate(36deg);
  }

  &:nth-child(3) {
    --uib-delay: -0.9;
    transform: rotate(72deg);
  }
  &:nth-child(4) {
    --uib-delay: -0.5;
    transform: rotate(90deg);
  }
  &:nth-child(5) {
    --uib-delay: -0.3;
    transform: rotate(144deg);
  }
  &:nth-child(6) {
    --uib-delay: -0.2;
    transform: rotate(180deg);
  }
  &:nth-child(7) {
    --uib-delay: -0.6;
    transform: rotate(216deg);
  }
  &:nth-child(8) {
    --uib-delay: -0.7;
    transform: rotate(252deg);
  }
  &:nth-child(9) {
    --uib-delay: -0.1;
    transform: rotate(300deg);
  }
  &:nth-child(10) {
    --uib-delay: -0.8;
    transform: rotate(324deg);
  }
  &:nth-child(11) {
    --uib-delay: -1.2;
    transform: rotate(335deg);
  }
  &:nth-child(12) {
    --uib-delay: -0.5;
    transform: rotate(290deg);
  }
  &:nth-child(13) {
    --uib-delay: -0.2;
    transform: rotate(240deg);
  }
}

.quantum-container .particle::before {
  content: '';
  position: absolute;
  height: 17.5%;
  width: 17.5%;
  border-radius: 50%;
  background-color: var(--uib-color);
  flex-shrink: 0;
  transition: background-color 0.3s ease;
  --uib-d: calc(var(--uib-delay) * var(--uib-speed));
  animation: orbit var(--uib-speed) linear var(--uib-d) infinite;
}

@keyframes orbit {
  0% {
    transform: translate(calc(var(--uib-size) * 0.5)) scale(0.73684);
    opacity: 0.65;
  }
  5% {
    transform: translate(calc(var(--uib-size) * 0.4)) scale(0.684208);
    opacity: 0.58;
  }
  10% {
    transform: translate(calc(var(--uib-size) * 0.3)) scale(0.631576);
    opacity: 0.51;
  }
  15% {
    transform: translate(calc(var(--uib-size) * 0.2)) scale(0.578944);
    opacity: 0.44;
  }
  20% {
    transform: translate(calc(var(--uib-size) * 0.1)) scale(0.526312);
    opacity: 0.37;
  }
  25% {
    transform: translate(0%) scale(0.47368);
    opacity: 0.3;
  }
  30% {
    transform: translate(calc(var(--uib-size) * -0.1)) scale(0.526312);
    opacity: 0.37;
  }
  35% {
    transform: translate(calc(var(--uib-size) * -0.2)) scale(0.578944);
    opacity: 0.44;
  }
  40% {
    transform: translate(calc(var(--uib-size) * -0.3)) scale(0.631576);
    opacity: 0.51;
  }
  45% {
    transform: translate(calc(var(--uib-size) * -0.4)) scale(0.684208);
    opacity: 0.58;
  }
  50% {
    transform: translate(calc(var(--uib-size) * -0.5)) scale(0.73684);
    opacity: 0.65;
  }
  55% {
    transform: translate(calc(var(--uib-size) * -0.4)) scale(0.789472);
    opacity: 0.72;
  }
  60% {
    transform: translate(calc(var(--uib-size) * -0.3)) scale(0.842104);
    opacity: 0.79;
  }
  65% {
    transform: translate(calc(var(--uib-size) * -0.2)) scale(0.894736);
    opacity: 0.86;
  }
  70% {
    transform: translate(calc(var(--uib-size) * -0.1)) scale(0.947368);
    opacity: 0.93;
  }
  75% {
    transform: translate(0%) scale(1);
    opacity: 1;
  }
  80% {
    transform: translate(calc(var(--uib-size) * 0.1)) scale(0.947368);
    opacity: 0.93;
  }
  85% {
    transform: translate(calc(var(--uib-size) * 0.2)) scale(0.894736);
    opacity: 0.86;
  }
  90% {
    transform: translate(calc(var(--uib-size) * 0.3)) scale(0.842104);
    opacity: 0.79;
  }
  95% {
    transform: translate(calc(var(--uib-size) * 0.4)) scale(0.789472);
    opacity: 0.72;
  }
  100% {
    transform: translate(calc(var(--uib-size) * 0.5)) scale(0.73684);
    opacity: 0.65;
  }
}
/* .Quantum */

/* -- .LOADER -- */
