@font-face {
  font-family: "LoaderDisplay";
  src: url("../assets/fonts/ChakraPetch_Bold.ttf") format("truetype");
  font-display: swap;
}

@font-face {
  font-family: "LoaderBody";
  src: url("../assets/fonts/roboto/roboto_medium_w500.ttf") format("truetype");
  font-display: swap;
}

:root {
  color-scheme: light dark;
  --loader-background:
    radial-gradient(circle at 20% 18%, rgba(123, 78, 255, 0.16), transparent 32%),
    radial-gradient(circle at 82% 20%, rgba(34, 192, 255, 0.12), transparent 28%),
    radial-gradient(circle at 50% 82%, rgba(70, 118, 255, 0.10), transparent 26%),
    linear-gradient(180deg, #f8f8ff 0%, #eef4ff 54%, #f7fbff 100%);
  --loader-background-solid: #f7fbff;
  --loader-shell-color: #1f2552;
  --loader-kicker-background: rgba(255, 255, 255, 0.52);
  --loader-kicker-border: rgba(92, 107, 255, 0.10);
  --loader-kicker-shadow: rgba(88, 113, 255, 0.08);
  --loader-kicker-color: #5a63d8;
  --loader-orbit-border: rgba(103, 118, 255, 0.10);
  --loader-orbit-inner-border: rgba(33, 190, 255, 0.12);
  --loader-icon-shadow: rgba(78, 99, 255, 0.16);
  --loader-title-color: #202650;
  --loader-subtitle-color: #55608b;
  --bootstrap-error-surface: rgba(255, 255, 255, 0.74);
  --bootstrap-error-shadow: rgba(15, 23, 42, 0.12);
  --bootstrap-error-title: #ef4444;
  --bootstrap-error-text: #52607a;
  --bootstrap-error-button-background: linear-gradient(135deg, #27ae60 0%, #0f9d58 100%);
  --bootstrap-error-button-shadow: rgba(15, 118, 110, 0.24);
}

@media (prefers-color-scheme: dark) {
  :root {
    --loader-background:
      radial-gradient(circle at 18% 16%, rgba(88, 115, 255, 0.24), transparent 34%),
      radial-gradient(circle at 84% 18%, rgba(27, 196, 255, 0.18), transparent 28%),
      radial-gradient(circle at 48% 84%, rgba(66, 153, 225, 0.18), transparent 24%),
      linear-gradient(180deg, #07111f 0%, #0b1930 52%, #12233d 100%);
    --loader-background-solid: #0d1b2f;
    --loader-shell-color: #eef4ff;
    --loader-kicker-background: rgba(10, 24, 44, 0.58);
    --loader-kicker-border: rgba(110, 167, 255, 0.22);
    --loader-kicker-shadow: rgba(4, 10, 24, 0.36);
    --loader-kicker-color: #9dc0ff;
    --loader-orbit-border: rgba(120, 164, 255, 0.24);
    --loader-orbit-inner-border: rgba(73, 208, 255, 0.28);
    --loader-icon-shadow: rgba(8, 15, 33, 0.46);
    --loader-title-color: #f5f9ff;
    --loader-subtitle-color: #b3c0d9;
    --bootstrap-error-surface: rgba(9, 19, 36, 0.72);
    --bootstrap-error-shadow: rgba(2, 8, 23, 0.42);
    --bootstrap-error-title: #ff8e8e;
    --bootstrap-error-text: #c8d5eb;
    --bootstrap-error-button-background: linear-gradient(135deg, #34c77b 0%, #13985c 100%);
    --bootstrap-error-button-shadow: rgba(7, 67, 49, 0.36);
  }
}

html,
body {
  margin: 0;
  width: 100%;
  min-height: 100%;
}

.container {
  position: fixed;
  inset: 0;
  width: auto;
  min-height: 100dvh;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 24px;
  box-sizing: border-box;
  background: var(--loader-background);
}

.loader-shell {
  width: min(100%, 380px);
  text-align: center;
  color: var(--loader-shell-color);
}

.loader-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--loader-kicker-background);
  border: 1px solid var(--loader-kicker-border);
  box-shadow: 0 12px 30px var(--loader-kicker-shadow);
  color: var(--loader-kicker-color);
  font-family: "LoaderDisplay", sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.loader-mark {
  position: relative;
  width: 138px;
  height: 138px;
  margin: 14px auto 18px;
}

.loader-mark-orbit,
.loader-mark-icon {
  position: absolute;
}

.loader-mark-orbit {
  left: 50%;
  top: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  border: 1px solid var(--loader-orbit-border);
}

.loader-mark-orbit--outer {
  width: 138px;
  height: 138px;
  animation: loader-spin 16s linear infinite;
}

.loader-mark-orbit--inner {
  width: 108px;
  height: 108px;
  border-color: var(--loader-orbit-inner-border);
  border-style: dashed;
  animation: loader-spin 12s linear infinite reverse;
}

.loader-mark-icon {
  inset: 6px;
  width: 124px;
  height: 124px;
  filter: drop-shadow(0 16px 28px var(--loader-icon-shadow));
  animation: loader-float 2.8s infinite ease-in-out;
}

.loader-copy {
  margin-top: 2px;
}

.loader-title {
  margin: 0;
  color: var(--loader-title-color);
  font-family: "LoaderDisplay", sans-serif;
  font-size: clamp(1.7rem, 3vw, 2.1rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.loader-subtitle {
  margin: 12px 0 0;
  color: var(--loader-subtitle-color);
  font-family: "LoaderBody", sans-serif;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 500;
  letter-spacing: 0.01em;
}

@keyframes loader-spin {
  0%,
  100% {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes loader-float {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  50% {
    transform: translate3d(0, -6px, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .loader-mark-orbit,
  .loader-mark-icon {
    animation: none;
  }
}

@media (max-width: 640px) {
  .container {
    padding: 16px;
  }

  .loader-shell {
    width: min(100%, 320px);
  }

  .loader-kicker {
    min-height: 30px;
    padding: 0 12px;
    font-size: 10px;
  }

  .loader-mark {
    width: 118px;
    height: 118px;
    margin: 12px auto 14px;
  }

  .loader-mark-orbit--outer {
    width: 118px;
    height: 118px;
  }

  .loader-mark-orbit--inner {
    width: 92px;
    height: 92px;
  }

  .loader-mark-icon {
    inset: 5px;
    width: 108px;
    height: 108px;
  }

  .loader-title {
    font-size: 1.5rem;
  }

  .loader-subtitle {
    font-size: 13px;
  }
}