/* preload.css - Critical loading styles for dynamic theme-aware spinner */

/* Light mode defaults (Cirrus Light baseline) */
#vite-reload-spinner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: oklch(0.99 0.01 250);
  color: oklch(0.14 0.01 250);
  z-index: 99999;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.spinner {
  box-sizing: border-box;
  width: 48px;
  height: 48px;
  border: 4px solid oklch(0.9 0.01 250);
  border-top: 4px solid oklch(0.62 0.18 250);
  border-radius: 50%;
  animation: spin 1s cubic-bezier(0.4, 0, 0.2, 1) infinite;
  margin-bottom: 20px;
}

#loading-text {
  margin: 0;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.05em;
  opacity: 0.8;
}

/* Dark mode overrides (immediately loaded by head inline script html class toggle) */
html.dark #vite-reload-spinner {
  background: oklch(0.145 0.01 250);
  color: oklch(0.985 0.01 250);
}

html.dark .spinner {
  border-color: oklch(0.25 0.02 250);
  border-top-color: oklch(0.62 0.18 250);
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}
