/* ============================================
   BanketPro — Улучшения доступности (A11Y)
   ============================================ */

/* === СКРЫТИЕ ВИЗУАЛЬНО, НО ДОСТУПНО ДЛЯ SCREEN READERS === */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* === ПРОПУСТИТЬ НАВИГАЦИЮ === */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--color-primary);
  color: white;
  padding: 0.75rem 1.5rem;
  border-radius: 0 0 var(--radius-md) 0;
  z-index: 9999;
  font-weight: 600;
  transition: top 0.2s ease;
}

.skip-link:focus {
  top: 0;
  outline: none;
}

/* === УЛУЧШЕННАЯ ВИДИМОСТЬ ФОКУСА === */
:focus-visible {
  outline: none;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: none;
}

/* === ВЫСОКИЙ КОНТРАСТ === */
@media (prefers-contrast: high) {
  :root {
    --color-primary: #3730a3;
    --color-border: #374151;
  }
  
  .card,
  .btn,
  .form-control {
    border-width: 2px;
  }
}

/* === КОНТРАСТНОСТЬ ТЕКСТА === */
.text-muted {
  color: #64748b !important;
}

.badge {
  font-weight: 600;
}

/* === ИНДИКАТОР ЗАГРУЗКИ ДОСТУПНЫЙ === */
.loading-indicator {
  position: relative;
}

.loading-indicator::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
}

.loading-indicator[aria-busy="true"]::before {
  content: 'Загрузка...';
  position: absolute;
  clip: rect(0, 0, 0, 0);
}

/* === УЛУЧШЕННЫЕ ФОРМЫ === */
.form-label.required::after {
  content: ' *';
  color: var(--color-danger);
  font-weight: bold;
}

.form-text {
  color: var(--color-muted);
  font-size: 0.875rem;
  margin-top: 0.25rem;
}

.is-invalid {
  border-color: var(--color-danger) !important;
}

.invalid-feedback {
  display: block;
  color: var(--color-danger);
  font-size: 0.875rem;
  margin-top: 0.25rem;
}

/* === ТАБЛИЦЫ === */
.table thead th {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--color-surface, #fff);
}

.table tbody tr:focus-within {
  background: var(--color-primary-light);
  outline: none;
}

/* === МОДАЛЬНЫЕ ОКНА === */
body.modal-open {
  overflow: hidden;
}

.modal:focus {
  outline: none;
}

.modal-backdrop {
  background-color: rgba(15, 23, 42, 0.7);
}
