#root {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Loading spinner styles */
.loading-spinner {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50px;
  height: 50px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid #ea580c;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  z-index: 9999;
  opacity: 1;
  transition: opacity 0.3s ease-out;
}

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

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

/* Hide spinner when React loads */
.react-loaded .loading-spinner {
  display: none;
}

/* Focus styles for better accessibility */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.focus-visible\:not-sr-only:focus-visible {
  position: absolute !important;
  width: auto !important;
  height: auto !important;
  padding: 0.5rem !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
  border: 2px solid #1d4ed8 !important;
  border-radius: 0.375rem !important;
  background-color: white !important;
  color: #1d4ed8 !important;
  font-weight: 600 !important;
  top: 0.5rem !important;
  left: 0.5rem !important;
  z-index: 50 !important;
  text-decoration: none !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
}

/* High contrast support */
@media (prefers-contrast: high) {
  .focus-visible\:not-sr-only:focus-visible {
    border-width: 3px !important;
    background-color: yellow !important;
    color: black !important;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .loading-spinner {
    animation: none;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
  body {
    background-color: #1f2937;
    color: #f9fafb;
  }

  .focus-visible\:not-sr-only:focus-visible {
    background-color: #1f2937 !important;
    color: #60a5fa !important;
    border-color: #60a5fa !important;
  }
}

/* Print styles */
@media print {
  .loading-spinner,
  .focus-visible\:not-sr-only {
    display: none !important;
  }
}
/* Styles for no-JS fallback content */
.noscript-container {
  text-align: center;
  padding: 2rem;
  font-family: system-ui, sans-serif;
  max-width: 600px;
  margin: 0 auto;
}
.noscript-title {
  color: #ea580c;
  margin-bottom: 1rem;
}
.noscript-paragraph {
  margin-bottom: 1rem;
  line-height: 1.6;
}
.noscript-list {
  text-align: left;
  line-height: 1.8;
  margin-bottom: 1rem;
}
.noscript-note {
  font-size: 0.9rem;
  color: #666;
}
