html, body {
  width: 100%;
  height: 100vh;
}

body {
  display: grid;
  place-content: center;

  --color: oklch(80% 0.2 40);
}

.wrapper {
  width: 448px;
  height: 448px;
  border: 1px solid var(--color);
  border-radius: 8px;
  display: grid;
  gap: 16px;
  grid-template: repeat(4, 1fr) / repeat(4, 1fr);
  background: var(--color);
  padding: 16px;
}

@keyframes loader-1 {
  from {
    trasform: rotate(0deg);
  }
  
  to {
    transform: rotate(360deg);
  }
}

@keyframes loader-2 {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(25px);
  }
}

@keyframes loader-4 {
  0% {
    transform: translate(0, -15px);
  }
  33.3% {
    transform: translate(15px, 15px);
  }
  66.6% {
    transform: translate(-15px, 15px);
  }
  100% {
    transform: translate(0, -15px);
  }
}

@keyframes loader-5 {
  0% {
    transform: scale(1);
  }
  30% {
    transform: scale(1.5);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes loader-6 {
  0%, 5%, 95%, 100% {
    width: 4px;
  }
  25%, 75% {
    width: 32px;
    transform: translateX(0);
  }
  47%, 53% {
    width: 4px;
    transform: translateX(28px);
  }
}

@keyframes loader-7 {
  0% {
    opacity: 0.3;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0.3;
  }
}

@keyframes loader-9 {
  0% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(90deg);
  }
  50% {
    transform: rotate(180deg);
  }
  75% {
    transform: rotate(270deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes loader-10 {
  0% {
    transform: translate(0, 12px) rotate(0deg);
  }
  25% {
    transform: translate(-12px, 0) rotate(90deg);
  }
  50% {
    transform: translate(0, -12px) rotate(180deg);
  }
  75% {
    transform: translate(12px, 0) rotate(270deg);
  }
  100% {
    transform: translate(0, 12px) rotate(360deg);
  }
}

@keyframes loader-11 {
  0% {
    height: 4px;
    transform: translateY(0);
  }
  50% {
    transform: translateY(-6px);
    height: 16px;
  }
  100% {
    transform: translateY(0);
    height: 4px;
  }
}

@keyframes loader-12 {
  0% {
    transform: translate(-12px, 12px);
  }
  25% {
    transform: translate(-12px, -12px);
  }
  50% {
    transform: translate(12px, -12px);
  }
  75% {
    transform: translate(12px, 12px);
  }
  100% {
    transform: translate(-12px, 12px);
  }
}

@keyframes loader-13 {
  0% {
    height: 4px;
    transform: rotate(0) translateY(0);
  }
  25% {
    height: 24px;
    transform: rotate(0) translateY(-10px);
  }
  50% {
    height: 4px;
    transform: rotate(0) translateY(0);
  }
  51% {
    height: 4px;
    transform: rotate(90deg) translateY(0);
  }
  75% {
    height: 24px;
    transform: rotate(90deg) translateX(-10px);
  }
  100% {
    height: 4px;
    transform: rotate(90deg) translateX(0);
  }
}

@keyframes loader-14 {
  0% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(0, -16px);
  }
  40% {
    transform: translate(16px, -16px);
  }
  60% {
    transform: translate(-16px, -16px);
  }
  80% {
    transform: translate(0, -16px);
  }
  100% {
    transform: translate(0, 0);
  }
}

@keyframes loader-14-2 {
  0% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(0, 16px);
  }
  40% {
    transform: translate(-16px, 16px);
  }
  60% {
    transform: translate(16px, 16px);
  }
  80% {
    transform: translate(0, 16px);
  }
  100% {
    transform: translate(0, 0);
  }
}

@keyframes loader-15 {
  0% {
    transform: translate(-16px, -16px);
  }
  25% {
    transform: translate(16px, -16px);
  }
  50% {
    transform: translate(-16px, 16px);
  }
  75% {
    transform: translate(16px, 16px);
  }
  100% {
    transform: translate(-16px, -16px);
  }
}

@keyframes loader-16 {
  0% {
    transform: scale(1);
    border-radius: 50%;
  }
  50% {
    transform: scale(15);
    border-radius: 4%;
  }
  100% {
    transform: scale(1);
    border-radius: 50%;
  }
}

.loader {
  border: 1px solid var(--color);
  background: white;
  padding: 49px;
  position: relative;
  border-radius: 8px;
  &:after,
  &:before {
    position: absolute;
    border: 1px solid var(--color);
    background: var(--color);
    width: 24px;
    height: 24px;
    border-radius: 8px;
    left: 36px;
    top: 36px;
  }
}

#loader-1 {
  &:after {
    content: '';
    animation: loader-1 1s ease-in-out infinite;
  }
}

#loader-2 {
  &:after {
    content: '';
    top: 46px;
    left: 32px;
    width: 4px;
    height: 4px;
    animation: loader-2 1s ease-in-out infinite alternate;
  }
}

#loader-3 {
  &:before {
    content: '';
    width: 4px;
    height: 4px;
    top: 46px;
    left: 32px;
    animation: loader-2 1s ease-in-out infinite alternate;
    animation-delay: 0.2s;
    opacity: 0.4;
  }

  &:after {
    content: '';
    width: 4px;
    height: 4px;
    top: 46px;
    left: 32px;
    animation: loader-2 1s ease-in-out infinite alternate;
  }
}

#loader-4 {
  &:after {
    left: 48px;
    top: 48px;
    content: '';
    width: 4px;
    height: 4px;
    animation: loader-4 2s ease-in-out infinite;
  }
}

#loader-5 {
  &:after {
    content: '';
    border-radius: 50%;
    animation: loader-5 1s ease-in-out infinite;
  }
}

#loader-6 {
  &:after {
    content: '';
    height: 4px;
    top: 46px;
    left: 32px;
    animation: loader-6 2s linear infinite;
  }
}

#loader-7 {
  &:after {
    content: '';
    border-radius: 50%;
    animation: loader-7 1.5s ease-in-out infinite;
  }
}

#loader-8 {
  &:after {
    content: '';
    height: 4px;
    width: 26px;
    top: 46px;
    animation: loader-1 1s ease-in-out infinite;
  }

  &:before {
    content: '';
    width: 16px;
    height: 16px;
    top: 42px;
    left: 42px;
    border-radius: 50%;
    border: 0;
    background: white;
    z-index: 100;
  }
}

#loader-9 {
  &:after {
    content: '';
    height: 4px;
    width: 26px;
    top: 46px;
    animation: loader-9 2s ease-in-out infinite;
  }
}

#loader-10 {
  &:after {
    content: '';
    height: 4px;
    width: 26px;
    top: 46px;
    animation: loader-10 2s ease-in-out infinite;
  }
}

#loader-11 {
  &:after {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 43px;
    animation: loader-11 1s ease-in-out infinite;
  }

  &:before {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 51px;
    animation: loader-11 1s ease-in-out infinite;
    animation-delay: .3s;
  }
}

#loader-12 {
  &:before {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-12 2s ease-in-out infinite;
  }
  &:after {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-12 2s ease-in-out infinite;
    animation-delay: -1s;
  }
}

#loader-13 {
  &:before {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-13 2s ease-in-out infinite;
  }
}

#loader-14 {
  &:after {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-14 2s ease-in-out infinite;
  }
  
  &:before {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-14-2 2s ease-in-out infinite;
  }
}

#loader-15 {
  &:after {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-15 1.5s ease-in-out infinite;
  }

  &:before {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-15 1.5s ease-in-out infinite;
    animation-delay: -1.4s;
    opacity: 0.5;
  }
}

#loader-16 {
  &:after {
    content: '';
    height: 4px;
    width: 4px;
    top: 46px;
    left: 46px;
    animation: loader-16 2s ease-in-out infinite;
  }
}