/* КРИТИЧЕСКОЕ ИСПРАВЛЕНИЕ ДЛЯ МОБИЛЬНЫХ УСТРОЙСТВ */
@media (max-width: 768px) {
    .btn-submit {
        max-width: none !important;
        width: 100% !important;
        flex: none !important;
        order: 1 !important;
        /* Дополнительные свойства из диагностических стилей */
        box-sizing: border-box !important;
        margin: 0 !important;
        padding: 20px 28px !important;
        position: relative !important;
        z-index: 9999 !important;
        min-width: 0 !important;
        left: 0 !important;
        right: 0 !important;
        font-size: 14px !important;
        font-weight: 400 !important;
    }

    .btn-submit:disabled {
        background-color: #cccccc !important;
        color: #666666 !important;
        cursor: not-allowed !important;
    }

    .btn-cancel {
        max-width: none !important;
        width: auto !important;
        flex: 0 0 auto !important;
        order: 2 !important;
        padding: 8px 12px !important;
        font-size: 14px !important;
        font-weight: 400 !important;
    }

    .form-actions {
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        padding: 0 !important;
        margin: 0 !important;
    }
}

/* ИСПРАВЛЕНИЕ ДЛЯ ПЛАНШЕТОВ И СРЕДНИХ ЭКРАНОВ */
@media (max-width: 1199px) and (min-width: 769px) {
    .btn-submit {
        max-width: none !important;
        width: 100% !important;
        flex: none !important;
        order: 1 !important;
        /* Дополнительные свойства из диагностических стилей */
        box-sizing: border-box !important;
        margin: 0 !important;
        padding: 18px 28px !important;
        position: relative !important;
        z-index: 9999 !important;
        min-width: 0 !important;
        left: 0 !important;
        right: 0 !important;
        font-size: 16px !important;
        font-weight: 600 !important;
    }

    .btn-submit:disabled {
        background-color: #cccccc !important;
        color: #666666 !important;
        cursor: not-allowed !important;
    }

    .btn-cancel {
        max-width: none !important;
        width: auto !important;
        flex: 0 0 auto !important;
        order: 2 !important;
        padding: 12px 20px !important;
        font-size: 14px !important;
    }

    .form-actions {
        flex-direction: column !important;
        gap: 12px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        padding: 0 !important;
        margin: 0 !important;
    }
}

/* ========================================
   АДАПТИВНЫЕ СТИЛИ ДЛЯ СИСТЕМЫ ЗАПИСИ
   ======================================== */

/* КРИТИЧЕСКИЕ СТИЛИ ДЛЯ МОБИЛЬНЫХ УСТРОЙСТВ */
@media (max-width: 768px) {
    .btn-submit {
        max-width: none !important;
        width: 100% !important;
        flex: none !important;
        order: 1 !important;
    }

    .btn-cancel {
        max-width: none !important;
        width: auto !important;
        flex: 0 0 auto !important;
        order: 2 !important;
    }

    .form-actions {
        flex-direction: column !important;
    }
}

/* Базовые переменные для адаптивности */
:root {
    --booking-container-padding: 20px;
    --booking-form-gap: 24px;
    --booking-button-height: 52px;
    --booking-input-padding: 14px 16px;
    --booking-border-radius: 8px;
    --vh: 1vh;
    /* Динамическая высота viewport */
}

/* ========================================
   БОЛЬШИЕ ЭКРАНЫ (1200px+)
   ======================================== */
@media (min-width: 1200px) {
    .booking-modal {
        max-width: 700px;
    }

    .booking-modal-body {
        padding: 16px 40px 40px 40px;
    }

    .booking-description {
        margin-bottom: 20px;
    }

    .form-actions {
        flex-direction: row;
        justify-content: space-between;
    }

    .btn-submit {
        flex: 1;
        max-width: 200px;
        order: 2;
    }

    .btn-cancel {
        flex: 0 0 auto;
        order: 1;
    }
}

/* ========================================
   СРЕДНИЕ ЭКРАНЫ (768px - 1199px)
   ======================================== */
@media (min-width: 768px) and (max-width: 1199px) {
    :root {
        --booking-container-padding: 16px;
        --booking-form-gap: 20px;
    }

    .booking-float-btn {
        padding: 15px 22px;
        font-size: 15px;
    }

    .booking-modal {
        max-width: 90%;
    }

    .booking-modal-header {
        padding: 22px 28px;
    }

    .booking-modal-title {
        font-size: 22px;
    }

    .booking-modal-body {
        padding: var(--booking-container-padding);
    }

    .form-group {
        margin-bottom: var(--booking-form-gap);
    }
}

/* ========================================
   ПЛАНШЕТЫ (481px - 767px)
   ======================================== */
@media (min-width: 481px) and (max-width: 767px) {
    :root {
        --booking-container-padding: 12px;
        --booking-form-gap: 18px;
        --booking-button-height: 48px;
        --booking-input-padding: 12px 14px;
    }

    .booking-float-btn {
        bottom: 20px;
        right: 20px;
        padding: 14px 24px;
        font-size: 14px;
        max-width: calc(100vw - 40px);
    }

    .booking-modal-overlay {
        padding: 15px;
    }

    .booking-modal {
        border-radius: 12px;
        max-height: calc(100vh - 30px);
    }

    .booking-modal-header {
        padding: 20px 24px;
    }

    .booking-modal-title {
        font-size: 20px;
    }

    .booking-modal-body {
        padding: var(--booking-container-padding);
        padding-bottom: 0 !important;
        max-height: calc(100vh - 110px);
    }

    .form-group {
        margin-bottom: var(--booking-form-gap);
    }

    .form-input,
    .form-textarea {
        padding: var(--booking-input-padding);
        font-size: 15px;
    }

    .radio-label {
        padding: 14px 16px;
    }

    .btn-submit,
    .btn-cancel {
        min-height: 28px;
        font-size: 11px;
        padding: 5px 10px;
    }

    /* Двухколоночный layout для некоторых полей на планшетах */
    .form-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
    }
}

/* ========================================
   МОБИЛЬНЫЕ УСТРОЙСТВА (до 480px)
   ======================================== */
@media (max-width: 480px) {
    :root {
        --booking-container-padding: 8px;
        --booking-form-gap: 16px;
        --booking-button-height: 44px;
        --booking-input-padding: 12px 14px;
        --booking-border-radius: 6px;
    }

    /* Плавающая кнопка на всю ширину внизу экрана только для мобильных */
    .booking-float-btn {
        position: fixed;
        bottom: 0;
        left: 50%;
        width: 100%;
        margin: 0;
        padding: 12px 16px;
        border-radius: 0;
        border-top: 1px solid rgba(108, 156, 2, 0.2);
        font-size: 14px;
        font-weight: 600;
        text-align: center;
        display: block;
        z-index: 1001;
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
        transform: translateX(-50%) translateZ(0);
        /* Центрируем по горизонтали */
        -webkit-transform: translateX(-50%) translateZ(0);
        will-change: transform;
        /* Оптимизация для анимации */
    }

    /* Отступ снизу для body, чтобы контент не скрывался под кнопкой */
    body {
        padding-bottom: 70px !important;
    }

    /* На мобильных кнопка всегда видна */
    .booking-float-btn {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* Полноэкранное модальное окно */
    .booking-modal-overlay {
        padding: 0 !important;
        /* Убираем все отступы */
        align-items: stretch;
        justify-content: stretch;
    }

    .booking-modal {
        height: 100vh;
        max-height: 100vh;
        border-radius: 0;
        display: flex;
        flex-direction: column;
        width: 100%;
        max-width: 100%;
        margin: 0;
        position: relative;
        box-sizing: border-box;
        /* Важно для правильного расчета ширины */
    }

    .booking-modal-header {
        padding: 16px 20px;
        flex-shrink: 0;
    }

    .booking-modal-title {
        font-size: 18px;
    }

    .booking-modal-body {
        flex: 1;
        overflow-y: visible !important;
        padding: var(--booking-container-padding);
        padding-bottom: 0 !important;
        -webkit-overflow-scrolling: touch;
    }

    .booking-description {
        margin-bottom: 20px;
    }

    .booking-description p {
        font-size: 14px;
    }

    .booking-privacy {
        font-size: 12px !important;
        padding: 8px 12px;
    }

    .form-group {
        margin-bottom: var(--booking-form-gap);
    }

    .form-label {
        font-size: 14px;
        margin-bottom: 6px;
    }

    .form-input,
    .form-textarea {
        padding: var(--booking-input-padding);
        font-size: 16px;
        /* Важно: предотвращает зум на iOS */
        border-radius: var(--booking-border-radius);
    }

    .form-textarea {
        min-height: 80px;
        resize: none;
    }

    .timezone-badge {
        font-size: 10px;
        padding: 2px 6px;
        display: block;
        margin: 4px 0 0 0;
        width: fit-content;
    }

    .form-helper {
        font-size: 12px;
        margin-top: 4px;
    }

    /* Радиокнопки в вертикальном стеке */
    .radio-group {
        gap: 8px;
    }

    .radio-label {
        padding: 12px 14px;
        border-radius: var(--booking-border-radius);
    }

    .radio-text {
        font-size: 13px;
        flex-wrap: wrap;
    }

    .urgency-icon {
        font-size: 16px;
    }

    /* Чекбокс */
    .checkbox-label {
        gap: 10px;
    }

    .checkbox-text {
        font-size: 13px;
    }

    /* Кнопки формы */
    .form-actions {
        margin-top: 24px;
        gap: 10px;
        padding-top: 16px;
        border-top: 1px solid #e0e0e0;
        flex-direction: column;
    }

    .btn-submit {
        min-height: 28px;
        padding: 5px 10px;
        font-size: 11px;
        border-radius: var(--booking-border-radius);
        flex: none !important;
        max-width: none !important;
        width: 100% !important;
        /* Принудительно переопределяем стили больших экранов */
        order: 1 !important;
    }

    .btn-cancel {
        min-height: 28px;
        padding: 5px 10px;
        font-size: 11px;
        border-radius: var(--booking-border-radius);
        flex: 0 0 auto;
        max-width: none;
        width: auto;
    }

    /* Убираем отступ снизу body при открытом модальном окне */
    body.booking-modal-open {
        padding-bottom: 0;
    }

    /* На мобильных устройствах НЕ скрываем кнопку при открытом модальном окне */
    /* Кнопка остается видимой всегда */
}

/* ========================================
   ОЧЕНЬ МАЛЕНЬКИЕ ЭКРАНЫ (до 360px)
   ======================================== */
@media (max-width: 360px) {
    :root {
        --booking-container-padding: 6px;
        --booking-form-gap: 14px;
    }

    .booking-modal-header {
        padding: 14px 16px;
    }

    .booking-modal-title {
        font-size: 16px;
    }

    .booking-modal-body {
        padding: var(--booking-container-padding);
    }

    .form-input,
    .form-textarea {
        padding: 10px 12px;
        font-size: 15px;
    }

    .radio-label {
        padding: 10px 12px;
    }

    .radio-text {
        font-size: 12px;
    }

    .btn-submit {
        padding: 5px 8px;
        font-size: 11px;
        min-height: 26px;
        flex: none !important;
        max-width: none !important;
        width: 100% !important;
    }

    .btn-cancel {
        padding: 5px 8px;
        font-size: 11px;
        min-height: 26px;
        flex: 0 0 auto;
        max-width: none;
        width: auto;
    }
}

/* ========================================
   АЛЬБОМНАЯ ОРИЕНТАЦИЯ НА МОБИЛЬНЫХ
   ======================================== */
@media (max-width: 768px) and (orientation: landscape) and (max-height: 500px) {
    .booking-modal-header {
        padding: 12px 20px;
    }

    .booking-modal-title {
        font-size: 16px;
    }

    .booking-modal-body {
        padding: 16px 20px;
    }

    .booking-description {
        margin-bottom: 16px;
    }

    .form-group {
        margin-bottom: 14px;
    }

    .form-actions {
        margin-top: 16px;
        flex-direction: row;
        gap: 12px;
    }

    .btn-submit {
        order: 2;
    }

    .btn-cancel {
        order: 1;
        flex: 0 0 auto;
    }
}

/* ========================================
   ВЫСОКИЕ ЭКРАНЫ (iPhone X и подобные)
   ======================================== */
@media (max-width: 480px) and (min-height: 800px) {
    .booking-modal-body {
        padding-bottom: 0 !important;
    }

    .form-actions {
        margin-top: 32px;
    }
}

/* ========================================
   АДАПТАЦИЯ ДЛЯ TOUCH УСТРОЙСТВ
   ======================================== */
@media (pointer: coarse) {

    .form-input,
    .form-textarea,
    .btn-submit,
    .btn-cancel {
        min-height: 44px;
        /* Минимальный размер для удобного касания */
    }

    .radio-label,
    .checkbox-label {
        min-height: 44px;
        padding: 12px 16px;
    }

    .booking-modal-close {
        min-width: 44px;
        min-height: 44px;
        padding: 10px;
    }
}

/* ========================================
   СПЕЦИАЛЬНЫЕ УСТРОЙСТВА
   ======================================== */

/* iPhone SE и подобные маленькие экраны */
@media (max-width: 375px) and (max-height: 667px) {
    .booking-float-btn {
        font-size: 14px;
        padding: 12px;
    }

    .form-textarea {
        min-height: 60px;
    }
}

/* Galaxy Fold и подобные узкие экраны */
@media (max-width: 320px) {
    .booking-modal-title {
        font-size: 14px;
    }

    .radio-text {
        font-size: 11px;
    }

    .btn-submit {
        font-size: 13px;
        padding: 8px 12px;
        min-height: 36px;
        flex: none !important;
        max-width: none !important;
        width: 100% !important;
    }

    .btn-cancel {
        font-size: 13px;
        padding: 8px 12px;
        min-height: 36px;
        flex: 0 0 auto;
        max-width: none;
        width: auto;
    }
}

/* ========================================
   ПРИНТ СТИЛИ
   ======================================== */
@media print {

    .booking-float-btn,
    .booking-modal-overlay {
        display: none !important;
    }

    .booking-form {
        max-width: 100%;
        font-size: 12px;
    }

    .form-input,
    .form-textarea {
        border: 1px solid #000;
        background: white;
    }

    .form-actions {
        display: none;
    }
}

/* ========================================
   ОТКЛЮЧЕНИЕ АНИМАЦИЙ НА СЛАБЫХ УСТРОЙСТВАХ
   ======================================== */
@media (prefers-reduced-motion: reduce) {

    .booking-modal-overlay,
    .booking-modal,
    .booking-float-btn,
    .form-input,
    .form-textarea,
    .radio-label,
    .btn-submit,
    .btn-cancel {
        animation: none !important;
        transition: none !important;
    }
}

/* ========================================
   ВЫСОКАЯ КОНТРАСТНОСТЬ
   ======================================== */
@media (prefers-contrast: high) {

    .form-input,
    .form-textarea,
    .radio-label {
        border-width: 3px;
    }

    .btn-submit {
        background: #000;
        color: white;
        border: 3px solid #000;
    }

    .btn-cancel {
        background: white;
        color: #000;
        border: 3px solid #000;
    }
}

/* ========================================
   ПОДДЕРЖКА СТАРЫХ БРАУЗЕРОВ
   ======================================== */

/* Fallback для браузеров без поддержки grid */
@supports not (display: grid) {
    .form-row {
        display: flex;
        flex-wrap: wrap;
        margin: 0 -8px;
    }

    .form-row .form-group {
        flex: 1;
        min-width: calc(50% - 16px);
        margin: 0 8px 16px 8px;
    }
}

/* Fallback для браузеров без поддержки CSS переменных */
@supports not (--css: variables) {
    .booking-modal-body {
        padding: 20px;
    }

    .form-group {
        margin-bottom: 16px;
    }

    .form-input,
    .form-textarea {
        padding: 12px 14px;
    }

    .btn-submit,
    .btn-cancel {
        min-height: 44px;
    }
}

/* ========================================
   ACCESSIBILITY УЛУЧШЕНИЯ
   ======================================== */

/* Увеличенные элементы управления для пользователей с ограниченной моторикой */
@media (pointer: coarse) and (max-width: 480px) {

    .radio-label,
    .checkbox-label {
        min-height: 48px;
        padding: 14px 16px;
    }

    .btn-submit {
        min-height: 48px;
        padding: 14px 20px;
        flex: none !important;
        max-width: none !important;
        width: 100% !important;
    }

    .btn-cancel {
        min-height: 48px;
        padding: 14px 20px;
        flex: 0 0 auto;
        max-width: none;
        width: auto;
    }

    .booking-modal-close {
        min-width: 48px;
        min-height: 48px;
    }
}