/* ========================================
   ВЕРСИЯ ДЛЯ СЛАБОВИДЯЩИХ И ДОСТУПНОСТЬ
   Терапевтическое отделение ГУЗ НГКБ
   г. Новомосковск, 2026
   
   Соответствует ГОСТ Р 52872-2019
   ======================================== */

/* ========================================
   1. БАЗОВЫЕ НАСТРОЙКИ ДОСТУПНОСТИ
   ======================================== */

/* Скрытие для скринридеров (визуально скрыто, но доступно) */
.sr-only,
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Скрытие скринридеров от визуальных пользователей */
.sr-only-focusable:focus,
.sr-only-focusable:active {
    position: static;
    width: auto;
    height: auto;
    padding: inherit;
    margin: inherit;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/* Пропуск навигации (Skip Link) */
.skip-link {
    position: absolute;
    top: -100px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-primary);
    color: var(--color-white);
    padding: var(--spacing-3) var(--spacing-6);
    border-radius: var(--radius-md);
    z-index: var(--z-tooltip);
    font-weight: 600;
    font-size: var(--font-size-base);
    text-decoration: none;
    transition: top var(--transition-fast);
}

.skip-link:focus {
    top: var(--spacing-4);
    outline: 3px solid var(--color-accent);
    outline-offset: 2px;
}

/* ========================================
   2. ФОКУС ДЛЯ КЛАВИАТУРЫ
   ======================================== */

/* Глобальные стили фокуса */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* Усиленный фокус для версии слабовидящих */
.accessibility-mode a:focus-visible,
.accessibility-mode button:focus-visible,
.accessibility-mode input:focus-visible,
.accessibility-mode select:focus-visible,
.accessibility-mode textarea:focus-visible {
    outline: 4px solid var(--color-accent);
    outline-offset: 3px;
    box-shadow: 0 0 0 6px rgba(76, 175, 80, 0.3);
}

/* Фокус для карточек */
.doctor-card:focus-within,
.service-card:focus-within,
.news-card:focus-within {
    box-shadow: 0 0 0 4px var(--color-primary), var(--shadow-lg);
}

/* Фокус для навигации */
.nav-link:focus-visible {
    outline: 3px solid var(--color-white);
    outline-offset: -2px;
}

/* Фокус для кнопок */
.btn:focus-visible {
    outline: 3px solid var(--color-accent);
    outline-offset: 2px;
}

/* ========================================
   3. ВЕРСИЯ ДЛЯ СЛАБОВИДЯЩИХ (Классы)
   ======================================== */

/* Режим увеличенного текста */
.accessibility-mode {
    font-size: 20px !important;
    line-height: 1.6 !important;
}

.accessibility-mode .container {
    max-width: 1400px !important;
}

.accessibility-mode h1 {
    font-size: 3.5rem !important;
}

.accessibility-mode h2 {
    font-size: 2.5rem !important;
}

.accessibility-mode h3 {
    font-size: 2rem !important;
}

.accessibility-mode h4 {
    font-size: 1.5rem !important;
}

.accessibility-mode p {
    font-size: 1.25rem !important;
    line-height: 1.7 !important;
}

.accessibility-mode .btn {
    font-size: 1.2rem !important;
    padding: 16px 32px !important;
    min-height: 50px !important;
}

.accessibility-mode input,
.accessibility-mode select,
.accessibility-mode textarea {
    font-size: 1.2rem !important;
    padding: 16px !important;
    min-height: 50px !important;
}

/* Режим высокого контраста */
.accessibility-mode-high-contrast {
    --color-primary: #0000FF;
    --color-primary-dark: #0000AA;
    --color-accent: #FFFF00;
    --color-bg: #FFFFFF;
    --color-bg-white: #FFFFFF;
    --color-text: #000000;
    --color-text-light: #000000;
    --color-black: #000000;
    --color-white: #FFFFFF;
    --color-border: #000000;
}

.accessibility-mode-high-contrast body {
    background-color: #FFFFFF !important;
    color: #000000 !important;
}

.accessibility-mode-high-contrast .header,
.accessibility-mode-high-contrast .footer,
.accessibility-mode-high-contrast .service-card,
.accessibility-mode-high-contrast .doctor-card,
.accessibility-mode-high-contrast .news-card,
.accessibility-mode-high-contrast .memo-card,
.accessibility-mode-high-contrast .accordion-item,
.accessibility-mode-high-contrast .modal-container {
    background-color: #FFFFFF !important;
    border: 3px solid #000000 !important;
    box-shadow: none !important;
}

.accessibility-mode-high-contrast a {
    color: #0000FF !important;
    text-decoration: underline !important;
}

.accessibility-mode-high-contrast a:hover,
.accessibility-mode-high-contrast a:focus {
    color: #0000AA !important;
    text-decoration: underline !important;
}

.accessibility-mode-high-contrast .btn-primary {
    background-color: #0000FF !important;
    color: #FFFFFF !important;
    border: 3px solid #0000FF !important;
}

.accessibility-mode-high-contrast .btn-outline {
    background-color: #FFFFFF !important;
    color: #0000FF !important;
    border: 3px solid #0000FF !important;
}

.accessibility-mode-high-contrast img {
    border: 2px solid #000000 !important;
}

.accessibility-mode-high-contrast .section-title::after {
    background-color: #000000 !important;
    height: 6px !important;
}

.accessibility-mode-high-contrast input,
.accessibility-mode-high-contrast select,
.accessibility-mode-high-contrast textarea {
    border: 3px solid #000000 !important;
    background-color: #FFFFFF !important;
    color: #000000 !important;
}

.accessibility-mode-high-contrast input:focus,
.accessibility-mode-high-contrast select:focus,
.accessibility-mode-high-contrast textarea:focus {
    border-color: #0000FF !important;
    box-shadow: 0 0 0 4px rgba(0, 0, 255, 0.3) !important;
}

/* Режим инверсии цветов */
.accessibility-mode-inverted {
    filter: invert(1) hue-rotate(180deg);
}

.accessibility-mode-inverted img,
.accessibility-mode-inverted video,
.accessibility-mode-inverted canvas {
    filter: invert(1) hue-rotate(180deg);
}

/* ========================================
   4. УВЕЛИЧЕННЫЕ ЭЛЕМЕНТЫ УПРАВЛЕНИЯ
   ======================================== */

/* Большие кнопки */
.accessibility-large-controls .btn {
    min-height: 54px !important;
    min-width: 120px !important;
    padding: 16px 32px !important;
    font-size: 1.2rem !important;
}

/* Большие поля ввода */
.accessibility-large-controls input,
.accessibility-large-controls select,
.accessibility-large-controls textarea {
    min-height: 54px !important;
    font-size: 1.2rem !important;
    padding: 16px !important;
}

/* Большие ссылки */
.accessibility-large-controls a {
    min-height: 44px !important;
    display: inline-flex;
    align-items: center;
}

/* Увеличенные чекбоксы и радиокнопки */
.accessibility-large-controls input[type="checkbox"],
.accessibility-large-controls input[type="radio"] {
    width: 24px !important;
    height: 24px !important;
    margin-right: 12px !important;
}

/* ========================================
   5. ОТКЛЮЧЕНИЕ АНИМАЦИЙ
   ======================================== */

/* Для пользователей с вестибулярными нарушениями */
.accessibility-reduce-motion *,
.accessibility-reduce-motion *::before,
.accessibility-reduce-motion *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
}

/* Системное предпочтение reduced motion */
@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;
    }
}

/* ========================================
   6. ДОСТУПНОСТЬ ФОРМ
   ======================================== */

/* Визуальное обозначение обязательных полей */
label[for] .required,
label .required {
    color: var(--color-error);
    margin-left: 4px;
}

/* Сообщения об ошибках */
.form-error {
    color: var(--color-error);
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-1);
    display: block;
}

.accessibility-mode .form-error {
    font-size: 1rem !important;
    font-weight: 600 !important;
}

/* Успешная валидация */
.form-group.success input,
.form-group.success select,
.form-group.success textarea {
    border-color: var(--color-success);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2327AE60' stroke-width='2'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'%3E%3C/path%3E%3Cpolyline points='22 4 12 14.01 9 11.01'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 20px;
}

/* Ошибка валидации */
.form-group.error input,
.form-group.error select,
.form-group.error textarea {
    border-color: var(--color-error);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E74C3C' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 20px;
}

/* Доступность для disabled элементов */
input:disabled,
select:disabled,
textarea:disabled,
button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.accessibility-mode input:disabled,
.accessibility-mode select:disabled,
.accessibility-mode textarea:disabled,
.accessibility-mode button:disabled {
    opacity: 0.8;
    border: 3px solid var(--color-text-muted) !important;
}

/* ========================================
   7. ДОСТУПНОСТЬ ТАБЛИЦ
   ======================================== */

/* Чёткие границы таблиц */
.accessibility-mode table,
.accessibility-mode th,
.accessibility-mode td {
    border: 2px solid var(--color-border) !important;
    border-collapse: collapse;
}

.accessibility-mode-high-contrast table,
.accessibility-mode-high-contrast th,
.accessibility-mode-high-contrast td {
    border: 3px solid #000000 !important;
}

/* Чередование строк для лучшей читаемости */
.accessibility-mode tbody tr:nth-child(even) {
    background-color: var(--color-bg);
}

.accessibility-mode-high-contrast tbody tr:nth-child(even) {
    background-color: #F0F0F0 !important;
}

/* Выделение заголовков */
.accessibility-mode th {
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* ========================================
   8. ДОСТУПНОСТЬ ИЗОБРАЖЕНИЙ
   ======================================== */

/* Увеличение изображений */
.accessibility-mode img {
    max-width: 100%;
    height: auto;
}

/* Рамки для изображений в режиме контраста */
.accessibility-mode-high-contrast img {
    border: 3px solid #000000 !important;
}

/* Альтернативный текст всегда видим (для отладки) */
/* Раскомментировать при необходимости */
/*
img[alt]:not([alt=""])::after {
    content: attr(alt);
    display: block;
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: 4px;
}
*/

/* ========================================
   9. ДОСТУПНОСТЬ МОДАЛЬНЫХ ОКОН
   ======================================== */

/* Фокус ловушка визуально */
.modal-overlay.active {
    outline: none;
}

/* Кнопка закрытия более заметная */
.accessibility-mode .modal-close {
    width: 50px !important;
    height: 50px !important;
    font-size: 2rem !important;
    border: 3px solid var(--color-border) !important;
}

.accessibility-mode-high-contrast .modal-close {
    background-color: #FFFFFF !important;
    color: #000000 !important;
    border: 3px solid #000000 !important;
}

/* ========================================
   10. ДОСТУПНОСТЬ НАВИГАЦИИ
   ======================================== */

/* Текущая страница более заметна */
.accessibility-mode .nav-link.active {
    font-weight: 700 !important;
    text-decoration: underline !important;
}

.accessibility-mode-high-contrast .nav-link.active {
    background-color: #000000 !important;
    color: #FFFFFF !important;
    border: 2px solid #000000 !important;
}

/* Хлебные крошки (если будут добавлены) */
.breadcrumb {
    font-size: var(--font-size-sm);
}

.breadcrumb a:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
}

/* ========================================
   11. ДОСТУПНОСТЬ АККОРДЕОНОВ
   ======================================== */

/* Индикатор состояния аккордеона */
.accordion-summary {
    position: relative;
}

.accordion-summary::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 0;
    background-color: var(--color-primary);
    transition: height var(--transition-base);
}

.accordion-item[open] .accordion-summary::before {
    height: 80%;
}

.accessibility-mode .accordion-summary {
    font-size: 1.2rem !important;
    padding: 20px !important;
}

.accessibility-mode .accordion-content {
    font-size: 1.1rem !important;
    padding: 20px !important;
}

.accessibility-mode-high-contrast .accordion-item {
    border: 3px solid #000000 !important;
}

/* ========================================
   12. ДОСТУПНОСТЬ КАРТОЧЕК
   ======================================== */

/* Карточки с более чёткими границами */
.accessibility-mode .doctor-card,
.accessibility-mode .service-card,
.accessibility-mode .news-card,
.accessibility-mode .memo-card {
    border: 2px solid var(--color-border);
}

.accessibility-mode-high-contrast .doctor-card,
.accessibility-mode-high-contrast .service-card,
.accessibility-mode-high-contrast .news-card,
.accessibility-mode-high-contrast .memo-card {
    border: 3px solid #000000 !important;
}

/* Увеличение карточек при фокусе */
.accessibility-mode .doctor-card:focus-within,
.accessibility-mode .service-card:focus-within,
.accessibility-mode .news-card:focus-within {
    transform: none !important;
    box-shadow: 0 0 0 4px var(--color-primary) !important;
}

/* ========================================
   13. ДОСТУПНОСТЬ ФОРМЫ ЗАПИСИ
   ======================================== */

.accessibility-mode .appointment-form .form-group {
    margin-bottom: 24px !important;
}

.accessibility-mode .appointment-form label {
    font-size: 1.2rem !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
}

.accessibility-mode .appointment-form input,
.accessibility-mode .appointment-form select,
.accessibility-mode .appointment-form textarea {
    font-size: 1.2rem !important;
    padding: 16px !important;
}

.accessibility-mode .checkbox-group label {
    font-size: 1.1rem !important;
}

/* ========================================
   14. ИНДИКАТОРЫ СОСТОЯНИЙ
   ======================================== */

/* Успех */
.status-success {
    color: var(--color-success);
}

.status-success::before {
    content: '✓ ';
    font-weight: 700;
}

/* Ошибка */
.status-error {
    color: var(--color-error);
}

.status-error::before {
    content: '✕ ';
    font-weight: 700;
}

/* Предупреждение */
.status-warning {
    color: var(--color-warning);
}

.status-warning::before {
    content: '⚠ ';
}

/* Информация */
.status-info {
    color: var(--color-info);
}

.status-info::before {
    content: 'ℹ ';
}

/* В режиме высокого контраста */
.accessibility-mode-high-contrast .status-success {
    color: #008000 !important;
}

.accessibility-mode-high-contrast .status-error {
    color: #FF0000 !important;
}

.accessibility-mode-high-contrast .status-warning {
    color: #FFA500 !important;
}

.accessibility-mode-high-contrast .status-info {
    color: #0000FF !important;
}

/* ========================================
   15. ДОСТУПНОСТЬ ЦВЕТОВ (Color Blind)
   ======================================== */

/* Не полагаться только на цвет для передачи информации */
.btn-primary::before,
.btn-accent::before {
    /* Можно добавить иконки для различия кнопок */
    content: '';
}

/* Ссылки всегда подчёркнуты в режиме контраста */
.accessibility-mode-high-contrast a {
    text-decoration: underline !important;
}

/* Графики и диаграммы (если будут) */
.chart-legend-item::before {
    content: '● ';
    font-size: 1.5em;
}

/* ========================================
   16. ДОСТУПНОСТЬ ВРЕМЕНИ
   ======================================== */

/* Предупреждение о таймаутах */
.timeout-warning {
    background-color: var(--color-warning-light);
    border: 2px solid var(--color-warning);
    padding: var(--spacing-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-4);
}

/* Увеличение времени для анимаций */
.accessibility-mode {
    --transition-fast: 300ms ease;
    --transition-base: 500ms ease;
    --transition-slow: 800ms ease;
}

/* ========================================
   17. ДОСТУПНОСТЬ КЛАВИАТУРЫ
   ======================================== */

/* Видимый индикатор фокуса для всех интерактивных элементов */
[tabindex]:focus,
a[href]:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
}

/* Усиленный фокус в режиме доступности */
.accessibility-mode [tabindex]:focus,
.accessibility-mode a[href]:focus,
.accessibility-mode button:focus,
.accessibility-mode input:focus,
.accessibility-mode select:focus,
.accessibility-mode textarea:focus {
    outline: 4px solid var(--color-accent) !important;
    outline-offset: 3px !important;
    box-shadow: 0 0 0 6px rgba(76, 175, 80, 0.4) !important;
}

/* Фокус для карточек с кнопками */
.doctor-card:focus-within,
.service-card:focus-within,
.news-card:focus-within,
.memo-card:focus-within {
    box-shadow: 0 0 0 4px var(--color-primary), var(--shadow-lg);
}

/* ========================================
   18. ПАНЕЛЬ УПРАВЛЕНИЯ ДОСТУПНОСТЬЮ
   ======================================== */

.accessibility-panel {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: var(--z-popover);
}

.accessibility-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background-color: var(--color-bg-white);
    border: 2px solid var(--color-primary);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
}

.accessibility-btn:hover,
.accessibility-btn:focus {
    background-color: var(--color-primary);
    color: var(--color-white);
    box-shadow: var(--shadow-lg);
}

.accessibility-btn[aria-pressed="true"] {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.accessibility-btn .icon-eye {
    font-size: var(--font-size-lg);
}

/* Мобильная версия панели */
@media (max-width: 768px) {
    .accessibility-panel {
        top: 10px;
        right: 10px;
    }

    .accessibility-btn .accessibility-text {
        display: none;
    }

    .accessibility-btn {
        padding: 10px 12px;
    }
}

/* ========================================
   19. ВСПЛЫВАЮЩИЕ ПОДСКАЗКИ (TOOLTIPS)
   ======================================== */

/* Доступные тултипы */
[data-tooltip] {
    position: relative;
}

[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    padding: 8px 12px;
    background-color: var(--color-black);
    color: var(--color-white);
    font-size: var(--font-size-sm);
    border-radius: var(--radius-sm);
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-fast);
    z-index: var(--z-tooltip);
}

[data-tooltip]:hover::after,
[data-tooltip]:focus::after {
    opacity: 1;
    visibility: visible;
}

.accessibility-mode [data-tooltip]::after {
    font-size: 1rem !important;
    padding: 12px 16px !important;
}

/* ========================================
   20. АРИА-АТРИБУТЫ (Визуальные индикаторы)
   ======================================== */

/* Индикатор обязательных полей */
[aria-required="true"]::after,
label[aria-required="true"]::after {
    content: ' *';
    color: var(--color-error);
}

/* Индикатор текущего состояния */
[aria-current="page"] {
    font-weight: 700;
}

[aria-current="page"]::after {
    content: ' (текущая)';
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

/* Индикатор развёрнутого состояния */
[aria-expanded="true"] .accordion-icon {
    transform: rotate(45deg);
}

/* Индикатор нажатой кнопки */
[aria-pressed="true"] {
    background-color: var(--color-primary);
    color: var(--color-white);
}

/* ========================================
   21. ЗАГРУЗКА И СОСТОЯНИЯ
   ======================================== */

/* Индикатор загрузки */
.loading {
    position: relative;
    pointer-events: none;
}

.loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 24px;
    height: 24px;
    margin: -12px 0 0 -12px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Отключение анимации загрузки */
.accessibility-reduce-motion .loading::after {
    animation: none;
    border-top-color: var(--color-border);
}

/* ========================================
   22. ПЕЧАТНЫЕ СТИЛИ ДЛЯ ДОСТУПНОСТИ
   ======================================== */

@media print {
    .accessibility-panel,
    .skip-link,
    .search-overlay,
    .modal-overlay {
        display: none !important;
    }

    body {
        font-size: 12pt;
        line-height: 1.5;
    }

    a {
        text-decoration: underline;
    }

    a[href]::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
    }

    /* Ссылки на телефоны и email не дублировать */
    a[href^="tel:"]::after,
    a[href^="mailto:"]::after {
        content: "";
    }
}

/* ========================================
   23. ВЫСОКИЙ КОНТРАСТ (СИСТЕМНЫЙ)
   ======================================== */

@media (prefers-contrast: high) {
    :root {
        --color-primary: #0000FF;
        --color-accent: #00FF00;
        --color-border: #000000;
    }

    .btn {
        border-width: 3px;
    }

    a {
        text-decoration: underline;
    }

    input,
    select,
    textarea {
        border-width: 3px;
    }
}

/* ========================================
   24. УВЕЛИЧЕННЫЙ ТЕКСТ (СИСТЕМНЫЙ)
   ======================================== */

/* Поддержка системного увеличения текста */
@media (min-resolution: 120dpi) {
    html {
        font-size: 18px;
    }
}

/* Масштабирование до 200% без потери функциональности */
@media (max-width: 768px) and (max-resolution: 200dpi) {
    .accessibility-mode {
        font-size: 24px !important;
    }
}

/* ========================================
   25. СОВМЕСТИМОСТЬ СО СКРИНРИДЕРАМИ
   ======================================== */

/* NVDA, JAWS, VoiceOver совместимость */
[role="alert"] {
    font-weight: 600;
}

[role="status"] {
    font-style: italic;
}

[role="button"] {
    cursor: pointer;
}

[role="link"] {
    color: var(--color-primary);
    text-decoration: underline;
}

/* Landmark роли для навигации */
[role="banner"],
[role="navigation"],
[role="main"],
[role="contentinfo"] {
    outline: none;
}

/* ========================================
   26. МИНИМАЛЬНЫЕ РАЗМЕРЫ КАСАНИЯ
   ======================================== */

/* Минимальный размер для тач-интерфейсов (44x44px по WCAG) */
@media (pointer: coarse) {
    .btn,
    .nav-link,
    .search-btn,
    .modal-close,
    .pagination-link,
    .social-link {
        min-height: 44px;
        min-width: 44px;
    }

    input,
    select,
    textarea {
        min-height: 44px;
    }

    .checkbox-group input[type="checkbox"],
    .checkbox-group input[type="radio"] {
        min-width: 24px;
        min-height: 24px;
    }
}

/* ========================================
   27. КОНТРАСТ ТЕКСТА
   ======================================== */

/* Обеспечение контраста не менее 4.5:1 для обычного текста */
.text-muted {
    color: var(--color-text-light);
}

.accessibility-mode-high-contrast .text-muted {
    color: #000000 !important;
}

/* Контраст для заголовков не менее 7:1 */
h1, h2, h3, h4, h5, h6 {
    color: var(--color-black);
}

.accessibility-mode-high-contrast h1,
.accessibility-mode-high-contrast h2,
.accessibility-mode-high-contrast h3,
.accessibility-mode-high-contrast h4,
.accessibility-mode-high-contrast h5,
.accessibility-mode-high-contrast h6 {
    color: #000000 !important;
}

/* ========================================
   28. АДАПТАЦИЯ ДЛЯ РАЗЛИЧНЫХ ТИПОВ ДАЛЬТОНИЗМА
   ======================================== */

/* Протанопия (красно-зелёный) */
.accessibility-protanopia {
    filter: url('#protanopia');
}

/* Дейтеранопия (красно-зелёный) */
.accessibility-deuteranopia {
    filter: url('#deuteranopia');
}

/* Тританопия (сине-жёлтый) */
.accessibility-tritanopia {
    filter: url('#tritanopia');
}

/* SVG фильтры для дальтонизма (добавить в HTML) */
/*
<svg style="display: none;">
    <filter id="protanopia">...</filter>
    <filter id="deuteranopia">...</filter>
    <filter id="tritanopia">...</filter>
</svg>
*/

/* ========================================
   29. ЭКРАННЫЕ ЧИТАТЕЛИ (УЛУЧШЕНИЯ)
   ======================================== */

/* Паузы для скринридеров */
.pause-short::after {
    content: ',';
    speak: punctuation;
}

.pause-long::after {
    content: '.';
    speak: punctuation;
}

/* Числа читаются по цифрам */
.read-digit-by-digit {
    speak-as: spell-out;
}

/* Аббревиатуры */
abbr[title] {
    cursor: help;
    text-decoration: underline dotted;
}

.accessibility-mode abbr[title] {
    text-decoration: underline dotted 2px;
}

/* ========================================
   30. УНИВЕРСАЛЬНЫЕ КЛАССЫ ДОСТУПНОСТИ
   ======================================== */

/* Скрыть от всех */
.hidden {
    display: none !important;
}

/* Скрыть визуально, оставить для скринридеров */
.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;
}

/* Показать только при фокусе */
.focus-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.focus-only:focus {
    position: static;
    width: auto;
    height: auto;
    padding: inherit;
    margin: inherit;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/* Блокировка скролла при модальном окне */
.body-no-scroll {
    overflow: hidden;
}

/* Высокий контраст для всего */
.high-contrast-all {
    filter: contrast(1.2);
}

/* Увеличение межбуквенного интервала */
.letter-spacing-large {
    letter-spacing: 0.05em;
}

/* Увеличение межстрочного интервала */
.line-height-large {
    line-height: 2;
}

/* ========================================
   31. ТЕСТИРОВАНИЕ ДОСТУПНОСТИ (DEV)
   ======================================== */

/* Раскомментировать для отладки доступности */
/*
* {
    outline: 1px solid rgba(255, 0, 0, 0.3);
}

img:not([alt]),
img[alt=""],
a:not([href]),
button:not([type]) {
    outline: 3px solid red !important;
    background-color: rgba(255, 0, 0, 0.1) !important;
}
*/

/* ========================================
   32. ЗАГРУЗКА ШРИФТОВ (FOUT/FOIT)
   ======================================== */

/* Предотвращение мигания текста при загрузке шрифтов */
html {
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
}

/* Фоллбэк шрифты */
body {
    font-family: var(--font-body), -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading), -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}