/* WCAG 2.1 AA Accessibility Enhancements */

/* Screen reader only class */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Enhanced focus visible */
:focus-visible {
  outline: 3px solid #C6A85A !important;
  outline-offset: 2px !important;
  border-radius: 4px;
}

/* Remove default focus for mouse users */
:focus:not(:focus-visible) {
  outline: none;
}

/* Ensure minimum touch target size (44x44 px per WCAG) */
button, a, input[type="button"], input[type="submit"], [role="button"] {
  min-height: 44px;
  min-width: 44px;
}

/* Exception for inline links in text */
p a, li a, .inline-link {
  min-height: auto;
  min-width: auto;
}

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* High contrast mode support */
@media (forced-colors: active) {
  button, a {
    forced-color-adjust: none;
  }
}

/* Ensure form errors are visible */
[aria-invalid="true"] {
  border-color: #8A5B5B !important;
  background-color: #E9DCDC !important;
}
