/* ---------------------------------- */
/* АДАПТИВНОСТЬ (МОБИЛЬНЫЕ УСТРОЙСТВА)*/
/* ---------------------------------- */

@media (max-width: 768px) {
    /* Левая панель – выезжающая (управляется через React) */
    .chats-panel {
        position: fixed;
        left: 0;
        top: 0;
        bottom: 0;
        width: 280px;
        z-index: var(--z-modal);
        transition: transform var(--transition-slow) ease;
        border-radius: 0;
        background: var(--bg-surface);
        backdrop-filter: blur(16px);
        transform: translateX(0);
    }
    .chats-panel.hidden-mobile {
        transform: translateX(-100%);
    }
    .mobile-chats-toggle {
        display: inline-flex !important;
    }

    /* Область чата – на всю ширину */
    .chat-area {
        width: 100%;
        position: relative;
        height: 100%;
        display: flex;
        flex-direction: column;
    }

    /* Контейнер сообщений занимает всё доступное место */
    .messages {
        flex: 1;
        overflow-y: auto;
        padding: var(--spacing-md) var(--spacing-md);
        -webkit-overflow-scrolling: touch;
    }

    /* Кнопка назад в шапке чата */
    .mobile-back-btn {
        display: inline-flex !important;
        margin-right: var(--spacing-sm);
    }

    /* Панель ввода – фиксируется снизу */
    .input-area {
        padding: var(--spacing-sm) var(--spacing-md);
        gap: var(--spacing-sm);
        background: var(--bg-surface);
        border-top: 1px solid var(--border);
        position: sticky;
        bottom: 0;
        z-index: var(--z-sticky);
    }

    /* Сообщения */
    .message {
        max-width: 85%;
    }
    .message-bubble {
        padding: var(--spacing-sm) var(--spacing-md);
    }
    .message-text {
        font-size: 13px;
    }
    .message-avatar {
        width: 32px;
        height: 32px;
        font-size: 12px;
    }

    /* Поле ввода */
    .message-input {
        padding: var(--spacing-sm) 0;
        font-size: 14px;
    }
    .input-area button,
    .input-area .input-icon-btn {
        width: 40px;
        height: 40px;
    }
    .input-area button i,
    .input-area .input-icon-btn i {
        font-size: 1.2rem;
    }

    /* Шапка чата */
    .chat-header {
        padding: var(--spacing-sm) var(--spacing-md);
    }
    .chat-name-header {
        font-size: 16px;
    }
    .online-status {
        font-size: 10px;
    }

    /* Кнопка скролла вниз */
    .scroll-down-button {
        bottom: 70px;
        right: var(--spacing-md);
        width: 44px;
        height: 44px;
        font-size: 18px;
    }

    /* Панель записи голоса */
    .voice-recorder-panel {
        min-height: 180px;
        backdrop-filter: blur(16px);
    }
    .voice-recorder-panel-microphone {
        width: 60px;
        height: 60px;
    }
    .voice-recorder-panel-cancel-btn {
        width: 44px;
        height: 44px;
        font-size: 20px;
    }
    .voice-recorder-panel-visual {
        width: 160px;
        height: 160px;
    }

    /* Пин-бар */
    .pinned-bar {
        padding: 6px var(--spacing-md);
        gap: var(--spacing-sm);
    }
    .pinned-message-bar-item {
        padding: 4px 10px;
        font-size: 11px;
    }

    /* Панель ответа */
    .reply-bar {
        bottom: 68px;
        left: var(--spacing-md);
        right: var(--spacing-md);
        padding: 6px var(--spacing-md);
        font-size: 11px;
    }

    /* Резервный фон для браузеров без backdrop-filter */
    @supports not (backdrop-filter: blur(5px)) {
        .chat-area,
        .messages {
            background: var(--bg-dark) !important;
        }
        .chat-header,
        .input-area,
        .chats-panel,
        .voice-recorder-panel,
        .pinned-bar,
        .reply-bar {
            background: rgba(10, 15, 28, 0.95) !important;
            backdrop-filter: none !important;
        }
        body.light-theme .chat-header,
        body.light-theme .input-area,
        body.light-theme .chats-panel,
        body.light-theme .voice-recorder-panel,
        body.light-theme .pinned-bar,
        body.light-theme .reply-bar {
            background: rgba(242, 244, 248, 0.95) !important;
        }
        .btn-icon,
        .input-area button {
            background: rgba(255, 255, 255, 0.1) !important;
            color: var(--text) !important;
        }
        .btn-icon:hover,
        .input-area button:hover {
            background: var(--primary) !important;
            color: white !important;
        }
        body.light-theme .btn-icon,
        body.light-theme .input-area button {
            background: rgba(0, 0, 0, 0.05) !important;
        }
    }
}

/* Дополнительно: чтобы клавиатура не перекрывала поле ввода на iOS */
body {
    position: fixed;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
#root, .app, .chat-area {
    height: 100%;
    overflow: hidden;
}

/* На очень маленьких экранах панель чатов на всю ширину */
@media (max-width: 768px) {
    .chats-panel {
        width: 100% !important;
        left: 0;
        right: 0;
        max-width: none;
        min-width: auto;
    }
    .resize-handle {
        display: none !important;
    }
}

/* Уважение prefers-reduced-motion – только для анимированных элементов в медиа */
@media (prefers-reduced-motion: reduce) {
    .chats-panel,
    .chats-panel.hidden-mobile {
        transition: none;
    }
}