.app-loading {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: rgba(15, 23, 42, 0.22);
  backdrop-filter: blur(2px);
}

.app-loading[hidden] {
  display: none !important;
}

body.app-loading-active {
  cursor: progress;
}

body.app-loading-active .app-loading {
  display: flex;
}

.app-loading__panel {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  min-height: 3.25rem;
  max-width: min(20rem, calc(100vw - 3rem));
  padding: 0.75rem 1rem;
  border: 1px solid rgba(191, 219, 254, 0.75);
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.96);
  color: #1d4ed8;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.2;
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.18);
}

.app-loading__spinner {
  width: 1.1rem;
  height: 1.1rem;
  border: 2px solid rgba(29, 78, 216, 0.24);
  border-top-color: #1d4ed8;
  border-radius: 9999px;
  animation: app-loading-spin 0.75s linear infinite;
  flex: 0 0 auto;
}

.dark .app-loading {
  background: rgba(2, 6, 23, 0.38);
}

.dark .app-loading__panel {
  border-color: rgba(96, 165, 250, 0.28);
  background: rgba(15, 23, 42, 0.96);
  color: #bfdbfe;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.32);
}

.dark .app-loading__spinner {
  border-color: rgba(191, 219, 254, 0.22);
  border-top-color: #bfdbfe;
}

@keyframes app-loading-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .app-loading__spinner {
    animation: none;
  }
}
