body {
  margin: 0;
}

html {
  overflow-x: hidden;
  overflow-y: scroll;
}

#loading-bg {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  inline-size: 100%;
  block-size: 100%;
  background:
    radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--initial-loader-color, #7367f0) 12%, transparent), transparent 48%),
    radial-gradient(circle at 78% 82%, color-mix(in srgb, var(--initial-loader-color, #7367f0) 9%, transparent), transparent 44%),
    var(--initial-loader-bg, #fff);
}

.loading-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.loading-logo {
  inline-size: clamp(136px, 22vw, 210px);
  block-size: auto;
  filter: drop-shadow(0 8px 20px color-mix(in srgb, var(--initial-loader-color, #7367f0) 25%, transparent));
  animation: logo-bob 2.2s ease-in-out infinite;
}

.cut-track {
  position: relative;
  margin-top: -2px;
  inline-size: clamp(140px, 30vw, 260px);
  block-size: 40px;
}

.cut-line {
  position: absolute;
  inset-block-start: 50%;
  inset-inline: 0;
  transform: translateY(-50%);
  block-size: 4px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--initial-loader-color, #7367f0) 24%, #fff);
  overflow: hidden;
}

.cut-line::after {
  content: '';
  position: absolute;
  inset: 0;
  transform-origin: left center;
  animation: cut-progress 2.4s ease-in-out infinite;
  background:
    repeating-linear-gradient(
      90deg,
      var(--initial-loader-color, #7367f0) 0 8px,
      color-mix(in srgb, var(--initial-loader-color, #7367f0) 40%, #fff) 8px 14px
    );
}

.scissor {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 0;
  inline-size: 58px;
  block-size: 30px;
  transform: translate(-12%, -50%) rotate(-8deg);
  transform-origin: 12px 50%;
  animation: scissor-travel 2.4s ease-in-out infinite;
}

.blade {
  position: absolute;
  inset-inline-start: 16px;
  inline-size: 22px;
  block-size: 3px;
  border-radius: 999px;
  background: var(--initial-loader-color, #7367f0);
  transform-origin: 2px 50%;
}

.blade::after {
  content: '';
  position: absolute;
  inset-inline-end: -6px;
  inset-block-start: 50%;
  transform: translateY(-50%);
  inline-size: 7px;
  block-size: 3px;
  border-radius: 999px;
  background: inherit;
}

.blade-top {
  inset-block-start: 11px;
  animation: blade-top 0.32s ease-in-out infinite;
}

.blade-bottom {
  inset-block-start: 17px;
  animation: blade-bottom 0.32s ease-in-out infinite;
}

.pivot {
  position: absolute;
  inset-inline-start: 14px;
  inset-block-start: 50%;
  transform: translateY(-50%);
  inline-size: 7px;
  block-size: 7px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--initial-loader-color, #7367f0) 85%, #fff);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--initial-loader-color, #7367f0) 24%, transparent);
}

.ring {
  position: absolute;
  inline-size: 11px;
  block-size: 11px;
  border: 2px solid var(--initial-loader-color, #7367f0);
  border-radius: 50%;
}

.ring-left {
  inset-inline-start: 1px;
  inset-block-start: 6px;
}

.ring-right {
  inset-inline-start: 1px;
  inset-block-start: 16px;
}

.loading-copy {
  font-size: 0.94rem;
  letter-spacing: 0.06em;
  color: color-mix(in srgb, var(--initial-loader-color, #7367f0) 74%, #1f2233);
  animation: copy-pulse 1.6s ease-in-out infinite;
}

@keyframes logo-bob {
  0%, 100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-5px);
  }
}

@keyframes cut-progress {
  0% {
    transform: scaleX(0.04);
    opacity: 0.55;
  }

  50% {
    transform: scaleX(0.72);
    opacity: 1;
  }

  100% {
    transform: scaleX(1);
    opacity: 0.6;
  }
}

@keyframes scissor-travel {
  0% {
    transform: translate(-12%, -50%) rotate(-8deg);
  }

  48% {
    transform: translate(45%, -50%) rotate(-2deg);
  }

  100% {
    transform: translate(338%, -50%) rotate(-8deg);
  }
}

@keyframes blade-top {
  0%, 100% {
    transform: rotate(-21deg);
  }

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

@keyframes blade-bottom {
  0%, 100% {
    transform: rotate(21deg);
  }

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

@keyframes copy-pulse {
  0%, 100% {
    opacity: 0.55;
  }

  50% {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .loading-logo,
  .cut-line::after,
  .scissor,
  .blade-top,
  .blade-bottom,
  .loading-copy {
    animation: none !important;
  }
}
