.loading-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: white;
  opacity: 0.7;
  z-index: 1000;
}

.loading {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  transform: translate(-50%, -50%);
}

.loading .dot {
  position: absolute;
  border-radius: 50%;
  left: 1px;
  top: 1px;
  width: 18px;
  height: 18px;
  background: var(--primary-color);
  animation: spin 2.5s 0s infinite both;
}

.loading .dot2 {
  position: absolute;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  background: var(--primary-color);
  animation: spin2 2.5s 0s infinite both;
}

@keyframes spin {

  0%,
  100% {
    box-shadow:
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color);
  }

  50% {
    transform: rotate(180deg);
  }

  25%,
  75% {
    box-shadow:
      28px 0 0 var(--primary-color),
      -28px 0 0 var(--primary-color),
      0 28px 0 var(--primary-color),
      0 -28px 0 var(--primary-color),
      20px -20px 0 var(--primary-color),
      20px 20px 0 var(--primary-color),
      -20px -20px 0 var(--primary-color),
      -20px 20px 0 var(--primary-color);
  }

  100% {
    transform: rotate(360deg);
    box-shadow:
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color);
  }
}

@keyframes spin2 {

  0%,
  100% {
    box-shadow:
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color);
  }

  50% {
    transform: rotate(-180deg);
  }

  25%,
  75% {
    box-shadow:
      52px 0 0 var(--primary-color),
      -52px 0 0 var(--primary-color),
      0 52px 0 var(--primary-color),
      0 -52px 0 var(--primary-color),
      38px -38px 0 var(--primary-color),
      38px 38px 0 var(--primary-color),
      -38px -38px 0 var(--primary-color),
      -38px 38px 0 var(--primary-color);
    background: transparent;
  }

  100% {
    transform: rotate(-360deg);
    box-shadow:
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color),
      0 0 0 var(--primary-color);
  }
}