/* ========================================================================= */
/* ===         05_RESPONSIVE.CSS - АДАПТИВНОСТЬ ДЛЯ МОБИЛЬНЫХ           ===  */
/* ========================================================================= */
/* Этот файл содержит все стили, которые применяются только на               */
/* устройствах с шириной экрана 992px и меньше. Он переопределяет            */
/* десктопные стили для корректного отображения на мобильных.                */
/* ========================================================================= */

@media (max-width: 992px) {
    
    /* --- ГЛОБАЛЬНЫЕ ИЗМЕНЕНИЯ --- */

    body {
        overflow-y: auto; /* Разрешаем вертикальную прокрутку для всей страницы на мобильных */
    }

    /* Когда открыт чат, запрещаем прокрутку страницы, чтобы скроллился только сам чат */
    body.chat-is-active {
        overflow: hidden;
    }
    
    
    /* --- ОСНОВНАЯ СТРУКТУРА (LAYOUT) --- */

    .main-container {
        flex-direction: column;
        height: auto;
        min-height: 100vh;
        padding: 0 0.5rem; /* ✔️ Оставляем ТОЛЬКО боковые отступы */
        gap: 0;            /* ✔️ Обнуляем gap, чтобы управлять отступами вручную */
        z-index: auto;
        background-color: transparent;
    }

    /* Когда чат активен, заставляем контейнер занять всю высоту видимой области */
    body.chat-is-active .main-container {
        height: 100vh; /* Используем vh, JS будет это корректировать */
        padding: 0; /* Убираем отступы, чтобы JS мог точно рассчитать высоту */
        gap: 0;
    }
    
    /* Общие стили для всех панелей на мобильных */
    .panel {
        flex-basis: auto;
        width: 100%;
        max-height: none;
        overflow-y: visible;
        padding: 1rem;
        border: none;
    }

    /* --- ВЕРХНЯЯ ПАНЕЛЬ УПРАВЛЕНИЯ --- */
    .controls-panel {
        order: 1;
        position: relative;
        z-index: 2;
        background-color: transparent;

    }
    .controls-panel .panel-logo,
    .controls-panel .logo-text {
        display: none;
    }
    .user-block {
        margin-bottom: 0;
    }
    #mobile-menu-toggle {
        margin-right: auto;
    }

    
    /* --- ЦЕНТРАЛЬНАЯ РАБОЧАЯ ОБЛАСТЬ --- */
    .generation-space {
        order: 2;
        position: relative;
        z-index: 1;
        background-color: transparent;
        border-radius: 0;

        /* ✔️ ГЛАВНОЕ ИСПРАВЛЕНИЕ: */
        /* Заставляем центральную область РАСТЯГИВАТЬСЯ, чтобы занять все свободное место */
        display: flex;          /* Включаем Flexbox для дочерних элементов */
        flex-direction: column; /* Элементы внутри будут в столбец */
        flex-grow: 1;           /* <<-- ВОТ ОНО! Растягиваемся на всю доступную высоту */
        min-height: 0;          /* Трюк для надежной работы flexbox */
        padding: 0;             /* Убираем отступы, чтобы контент мог занимать всю область */
    }

    /* ✔️ ГЛАВНОЕ ИСПРАВЛЕНИЕ: */
    /* Заставляем центральную область РАСТЯГИВАТЬСЯ, чтобы занять все свободное место */
    body.chat-is-active .generation-space {
        display: flex;          /* Включаем Flexbox для дочерних элементов */
        flex-direction: column; /* Элементы внутри будут в столбец */
        flex-grow: 1;           /* <<-- ВОТ ОНО! Растягиваемся на всю доступную высоту */
        min-height: 0;          /* Трюк для надежной работы flexbox */
        padding: 0;
    }
    #results-grid {
        grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
        gap: 0.5rem;
        padding-right: 0;
    }
    .result-card:hover {
        transform: none;
    }

    /* --- ВЫДВИЖНАЯ ПАНЕЛЬ РЕЖИМОВ --- */
    .modes-panel {
        position: fixed;
        top: 0; 
        left: 0; 
        height: 100%;
        width: 280px;
        z-index: 1045;
        background-color: transparent;
        transform: translateX(-100%);
        transition: transform 0.3s ease-in-out;
        box-shadow: 4px 0 15px rgba(0,0,0,0.4);
        overflow-y: auto;
        padding: 1.5rem;
    }
    .modes-panel.is-open {
        transform: translateX(0);
    }
    .modes-panel h5 {
        display: block;
        padding: 0.5rem 0;
    }
    #modes-menu {
        display: flex;
        flex-direction: column;
        overflow-x: hidden;
        padding-bottom: 0;
        gap: 0.5rem;
    }
    .mode-button {
        margin-bottom: 0;
        justify-content: flex-start;
        font-size: 1rem;
        padding: 1rem;
    }

    /* ====================================================== */
    /* ===        ✔️ ФИНАЛЬНЫЙ БЛОК ДЛЯ ЧАТА             ✔️ === */
    /* ====================================================== */

    /* Когда чат активен, запрещаем прокрутку страницы */
    body.chat-is-active {
        overflow: hidden;
    }

    /* Главный контейнер в режиме чата занимает всю высоту, заданную JS */
    body.chat-is-active .main-container {
        height: 100vh; /* JS будет это переопределять на точное значение */
        padding: 0;
        gap: 0;
    }

    /* Прячем десктопный список участников на мобильных */
    #chat-participants-view {
        display: none !important;
    }

    /* Стили для счетчика "Онлайн" */
    #mobile-participants-counter {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        position: absolute;
        top: 1rem;
        right: 1rem;
        z-index: 10;
        background-color: rgba(0, 0, 0, 0.3);
        backdrop-filter: blur(5px);
        padding: 0.25rem 0.75rem;
        border-radius: 2rem;
        font-size: 0.8rem;
        color: var(--text-secondary);
        font-weight: 500;
    }
    #mobile-participants-counter strong {
        color: var(--text-primary);
    }

    /* Добавляем "безопасные" отступы для формы ввода, чтобы она не залезала под системные кнопки */
    #chat-send-form {
        padding-left: calc(0.75rem + env(safe-area-inset-left));
        padding-right: calc(0.75rem + env(safe-area-inset-right));
        /* Важно: отступ снизу добавляется только если есть системная панель */
        padding-bottom: calc(5rem + env(safe-area-inset-bottom));
    }

    /* --- РАДИО-ПЛЕЕР --- */

    /* Плеер по умолчанию скрыт */
    #radio-player-container {
        margin-top: 1rem;
        display: none;
    }
    /* Когда панель активна, показываем плеер */
    .modes-panel.radio-active #radio-player-container {
        display: block;
    }
    /* Футер с иконками НЕ скрывается на мобильных */
    /*
    .modes-panel.radio-active #panel-footer-icons {
        display: flex;
    }
    */
    /* Косметические правки для мобильного плеера */
    #radio-player-container .player-track-info {
        padding: 0.5rem;
        border-top: none;
        background-color: var(--background-tertiary);
        border-radius: 0.5rem;
    }
    #radio-player-container .player-controls {
        padding: 0.5rem 1rem 0 1rem;
        justify-content: space-between; /* Распределяем кнопки по краям */
    }
    #radio-player-container .volume-control-container {
        display: flex; /* Показываем блок с громкостью */
    }
    /* Убираем анимацию появления слайдера на мобильных */
    .player-controls:hover .volume-slider,
    #radio-player-container .volume-slider {
        width: 70px;
        opacity: 1;
    }
    

    /* --- МОДАЛЬНОЕ ОКНО --- */

    /* Прячем стрелки навигации в галерее, так как будет свайп */
    .gallery-nav-btn { 
        display: none; 
    }

    #chat-participants-view {
        display: none /* Полностью скрываем список участников на мобильных */
    }

    #mobile-participants-counter {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        position: absolute;
        top: 1rem;
        right: 1rem;
        z-index: 10;
        background-color: rgba(0, 0, 0, 0.3);
        backdrop-filter: blur(5px);
        padding: 0.25rem 0.75rem;
        border-radius: 2rem;
        font-size: 0.8rem;
        color: var(--text-secondary);
        font-weight: 500;
    }

    #profile-view .history-header {
        margin-top: 1.5rem; /* Добавляем верхний отступ для заголовка истории */
    }
    
} /* Конец главного медиа-запроса @media (max-width: 992px) */

/* ===================================================================== */
/* ===         ✔️ НОВЫЙ ПОДХОД: Режим активной клавиатуры            ✔️ === */
/* ===================================================================== */

/* Когда JS добавляет этот класс, происходят следующие изменения: */

/* 1. Главный контейнер принудительно занимает всю видимую высоту экрана */
.main-container.keyboard-is-active {
    height: 100vh;
    overflow: hidden; /* Запрещаем прокрутку самого контейнера */
}

/* 2. Панель управления (верхняя) растягивается, чтобы заполнить этот контейнер */
.main-container.keyboard-is-active .controls-panel {
    flex-grow: 1; 
    display: flex;
    flex-direction: column;
}

/* 3. ОБЛАСТЬ С РЕЗУЛЬТАТАМИ ПОЛНОСТЬЮ ИСЧЕЗАЕТ, освобождая место */
.main-container.keyboard-is-active .generation-space {
    display: none;
}

/* 4. Форма внутри панели управления растягивается на всю высоту панели */
.main-container.keyboard-is-active #control-form,
.main-container.keyboard-is-active #music-mode-container {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* 5. Родительский блок для textarea растягивается на всю высоту формы */
.main-container.keyboard-is-active #lyrics-input-group,
.main-container.keyboard-is-active #prompt-group,
.main-container.keyboard-is-active #normal-music-mode .mb-3:has(#music-description-normal) {
     flex-grow: 1;
     display: flex;
     flex-direction: column; /* Важно для дочернего textarea */
     min-height: 0;
}

/* 6. И, наконец, сам textarea занимает 100% высоты своего родителя */
.main-container.keyboard-is-active textarea.form-control {
    flex-grow: 1; /* Растягиваем поле ввода */
    height: 100%; /* Дополнительно для надежности */
    resize: none;
}

/*
   =====================================================================
   ===  ✔️ FIX: Растягиваем поля ввода в Генераторе Текстов на 100%   ===
   =====================================================================
*/

/* 1. Заставляем контейнер экрана редактирования растягиваться на всю высоту */
#lyrics-edit-screen {
    display: flex;
    flex-direction: column;
    height: 100%; /* Очень важно! */
}

/* 2. Заставляем обертку для поля "Текст песни" занимать все свободное место */
#lyrics-edit-screen .d-flex.flex-column {
    flex-grow: 1;
    min-height: 0; /* Технический трюк для корректной работы flex-grow */
}

/* 3. И, наконец, само текстовое поле растягиваем внутри этой обертки */
#lyrics-edit-screen textarea#generated-lyrics-input {
    flex-grow: 1;
    height: 100%; /* Занимает всю высоту родителя */
    resize: none; /* Отключаем возможность ручного изменения размера на мобильных */
}