/* ===================================================
   ФОТОН — Мобильная адаптация
   Устройства: iPhone SE/12-16, Samsung Galaxy S21-S25,
   Google Pixel 6-9, iPad Mini/Air/Pro, Android tablets
   =================================================== */

/* --- Safe area support (iPhone notch / Dynamic Island / home indicator) --- */
@supports (padding: env(safe-area-inset-top)) {
    body {
        padding-top: env(safe-area-inset-top);
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
    #input-area {
        padding-bottom: calc(15px + env(safe-area-inset-bottom));
    }
}

/* --- Оффлайн-бэйдж для мобильных: компактный пил у нижнего края, над input-area --- */
@media screen and (max-width: 768px) {
    .offline-banner {
        top: auto;
        left: 50%;
        right: auto;
        bottom: calc(90px + env(safe-area-inset-bottom, 0px));
        transform: translateX(-50%);
        padding: 7px 14px;
        border-radius: 999px;
        font-size: 12px;
        gap: 8px;
        max-width: calc(100% - 32px);
        white-space: nowrap;
        box-shadow: 0 4px 14px rgba(0,0,0,0.45);
        animation: offline-pill-in 0.22s ease-out;
    }
    .offline-banner-text-full { display: none; }
    .offline-banner-text-short { display: inline; }
    /* На мобильных не поднимаем тело — бэйдж плавающий */
    body.offline-mode { padding-top: 0; }
    @supports (padding: env(safe-area-inset-top)) {
        body.offline-mode { padding-top: env(safe-area-inset-top); }
    }
}
@keyframes offline-pill-in {
    from { transform: translate(-50%, 10px); opacity: 0; }
    to   { transform: translate(-50%, 0); opacity: 1; }
}

/* --- Soul Panel — адаптация для всех экранов --- */
@media screen and (max-width: 768px) {
    /* На мобилке пилюля с кнопками — горизонтально внизу по центру */
    #side-panel-btns {
        top: auto;
        right: auto;
        bottom: 10px;
        left: 50%;
        transform: translateX(-50%);
        flex-direction: row;
    }
    #side-panel-btns > button {
        width: 44px;
        height: 44px;
    }
    #soul-panel {
        width: 280px;
        top: 20px;
        bottom: 20px;
        padding: 20px;
        right: 15px;
    }
    /* Скрываем «Промпт Фотона» и «Директивы Фотона» на мобильных */
    #photon_soul-panel-btn,
    #additions-panel-btn { display: none; }
}
@media screen and (max-width: 480px) {
    #side-panel-btns > button {
        width: 42px;
        height: 42px;
    }
    #soul-panel {
        width: calc(100vw - 30px);
        max-width: 320px;
        top: 10px;
        bottom: 10px;
        padding: 20px 18px;
        border-radius: 12px;
        right: 10px;
    }
    #soul-input {
        min-height: 60px;
        font-size: 14px;
    }
    .soul-label {
        font-size: 9px;
        letter-spacing: 1.5px;
    }
    .soul-candidate {
        padding: 12px;
    }
    .soul-candidate-content {
        font-size: 13px;
    }
    .soul-candidate-actions button {
        padding: 8px 10px;
        font-size: 10px;
    }
}
@media screen and (max-width: 375px) {
    #side-panel-btns > button {
        width: 40px;
        height: 40px;
    }
    #soul-panel {
        width: calc(100vw - 20px);
        top: 8px;
        bottom: 8px;
        padding: 16px 14px;
        right: 8px;
    }
}
@media screen and (max-width: 900px) and (max-height: 500px) and (orientation: landscape) {
    #side-panel-btns > button {
        width: 36px;
        height: 36px;
    }
    #soul-panel {
        width: 240px;
        top: 8px;
        bottom: 8px;
        padding: 14px;
    }
}
@media (hover: none) and (pointer: coarse) {
    #soul-panel-btn,
    #soul-save-btn,
    .soul-btn-accept,
    .soul-btn-forget {
        -webkit-tap-highlight-color: transparent;
    }
    .soul-btn-accept:active {
        color: #64ff96;
        border-color: rgba(100, 255, 150, 0.5);
    }
    .soul-btn-forget:active {
        color: #ff6464;
        border-color: rgba(255, 100, 100, 0.4);
    }
    #soul-save-btn:active {
        color: #64c8ff;
        border-color: rgba(100, 200, 255, 0.5);
    }
}

/* --- Tablets & large phones (≤768px) — iPad Mini, iPad Air landscape split --- */
@media screen and (max-width: 768px) {
    /* Десктопный padding в #dashboard оставляет 110px справа под боковую
       панель/виджеты — на мобиле это лишнее, возвращаем симметричные 24px. */
    #dashboard {
        padding: 30px 24px 96px;
    }

    #chat-container {
        padding: 50px 5%;
        padding-right: 80px;
        gap: 20px;
    }

    .msg {
        max-width: 90%;
        padding: 16px 20px 28px;
        font-size: 16px;
        line-height: 1.7;
        letter-spacing: 0.3px;
    }

    #input-area {
        padding: 25px 5%;
        gap: 10px;
        flex-wrap: wrap;
    }

    /* Textarea на всю ширину — кнопки уходят на вторую строку */
    #input-area #userInput,
    #input-area .textarea-emoji-wrap {
        width: 100%;
        flex: 1 1 100%;
    }

    /* Ряд кнопок под инпутом */
    .attachBtn, .ttsToggleBtn, .micBtn, .sendBtn {
        width: 50px;
        min-width: 50px;
        height: 50px;
    }

    /* Кнопка отправки прижата вправо */
    .sendBtn {
        margin-left: auto;
    }

    input {
        padding: 14px 20px;
        font-size: 16px; /* предотвращает zoom на iOS при фокусе */
    }

    #user-profile-details {
        width: 260px;
        top: 20px;
        bottom: 20px;
        padding: 20px;
    }
    #user-profile-details.active {
        right: 15px;
    }

}

/* --- Phones (≤480px) — iPhone, Samsung Galaxy, Pixel --- */
@media screen and (max-width: 480px) {
    body {
        height: 100dvh; /* dynamic viewport height — учитывает адресную строку браузера */
    }

    #chat-container {
        padding: 50px 4% 20px;
        padding-right: 80px;
        gap: 16px;
    }

    .msg {
        max-width: 92%;
        padding: 14px 16px 26px;
        font-size: 15px;
        line-height: 1.65;
        border-radius: 12px;
    }

    .user {
        border-right-width: 2px;
    }
    .foton {
        border-left-width: 2px;
        border-radius: 12px;
    }

    .loading {
        padding: 14px 16px;
        font-size: 14px;
    }

    #input-area {
        padding: 15px 4%;
        gap: 8px;
        flex-wrap: wrap;
    }

    #input-area #userInput,
    #input-area .textarea-emoji-wrap {
        width: 100%;
        flex: 1 1 100%;
    }
    #input-area #userInput {
        padding: 13px 18px;
        font-size: 16px;
        border-radius: 24px;
    }

    .sendBtn, .attachBtn, .micBtn, .ttsToggleBtn, .emoji-btn {
        height: 46px;
        border-radius: 23px;
    }
    /* Три вспомогательные кнопки (attach/tts/mic) занимают одну полную
       ширину строки, разделённую поровну. Send-кнопка идёт отдельной
       полной строкой ниже и квадратная (как в десктоп). */
    #input-area .attachBtn,
    #input-area .micBtn,
    #input-area .ttsToggleBtn {
        flex: 1 1 0;
        min-width: 0;
        width: auto;
    }
    .sendBtn {
        flex-basis: 100%;
        min-width: 0;
        width: auto;
        margin-left: 0;
        border-radius: 8px;
    }
    .sendBtn > img { width: 18px; }
    .attachBtn > img, .micBtn > img, .ttsToggleBtn > img { width: 18px; }
    .msg-attachment-img { max-width: 180px; max-height: 140px; }
    .file-chip { max-width: 160px; }

    /* Панели — полноэкранные на телефонах */
    #user-profile-details {
        width: calc(100vw - 30px);
        max-width: 320px;
        top: 10px;
        bottom: 10px;
        right: -110%;
        padding: 20px 18px;
        border-radius: 12px;
    }
    #user-profile-details.active {
        right: 10px;
    }

    /* Аватар */
    #avatar-preview {
        width: 76px;
        height: 76px;
        margin-bottom: 10px;
    }

    #avatar-upload-label {
        font-size: 10px;
        padding: 5px 12px;
    }

    /* Поля профиля */
    .profile-field {
        margin-bottom: 16px;
    }
    .profile-field label {
        font-size: 9px;
        letter-spacing: 1.5px;
        margin-bottom: 6px;
    }
    .profile-field input {
        padding: 10px 12px;
        font-size: 14px;
        border-radius: 8px;
    }

    .profile-save-btn {
        padding: 8px;
        font-size: 10px;
        border-radius: 8px;
    }

    .profile-logout-btn {
        padding: 10px;
        font-size: 10px;
        border-radius: 8px;
    }

    /* Кнопка закрытия — увеличенная зона тача */
    .closed {
        width: 36px;
        height: 36px;
        font-size: 22px;
        top: 8px;
        right: 8px;
    }

}

/* --- Small phones (≤375px) — iPhone SE, older Androids, Galaxy A series --- */
@media screen and (max-width: 375px) {
    #chat-container {
        padding: 46px 3% 16px;
        padding-right: 80px;
        gap: 14px;
    }

    .msg {
        max-width: 95%;
        padding: 12px 14px 24px;
        font-size: 14.5px;
        line-height: 1.6;
    }

    #input-area {
        padding: 12px 3%;
        gap: 6px;
    }

    #input-area #userInput {
        padding: 12px 14px;
    }

    .sendBtn, .attachBtn, .micBtn, .ttsToggleBtn, .emoji-btn {
        width: 44px;
        min-width: 44px;
        height: 44px;
    }

    #user-profile-details {
        width: calc(100vw - 20px);
        top: 8px;
        bottom: 8px;
        padding: 16px 14px;
    }
    #user-profile-details.active {
        right: 8px;
    }

    #avatar-preview {
        width: 64px;
        height: 64px;
    }
}

/* --- Very small screens (≤320px) — iPhone SE 1st gen, budget Androids --- */
@media screen and (max-width: 320px) {
    .msg {
        max-width: 98%;
        padding: 10px 12px 22px;
        font-size: 14px;
    }

    input {
        padding: 11px 12px;
        font-size: 16px;
    }

    .sendBtn, .attachBtn, .micBtn, .ttsToggleBtn, .emoji-btn {
        width: 40px;
        min-width: 40px;
        height: 40px;
    }
    .sendBtn > img, .attachBtn > img, .micBtn > img, .ttsToggleBtn > img {
        width: 16px;
    }

    #user-profile-details {
        width: calc(100vw - 12px);
        padding: 14px 12px;
    }
    #user-profile-details.active {
        right: 4px;
    }

}

/* --- Landscape phones — предотвращает потерю пространства --- */
@media screen and (max-width: 900px) and (max-height: 500px) and (orientation: landscape) {
    #chat-container {
        padding: 10px 8%;
        padding-right: 80px;
        gap: 10px;
    }

    .msg {
        padding: 10px 16px 22px;
        font-size: 14px;
        line-height: 1.5;
    }

    #input-area {
        padding: 8px 8%;
    }

    input {
        padding: 10px 16px;
    }

    .sendBtn, .attachBtn, .micBtn, .ttsToggleBtn, .emoji-btn {
        width: 44px;
        min-width: 44px;
        height: 44px;
    }

    .sendBtn {
        margin-left: auto;
    }

    #user-profile-details {
        top: 8px;
        bottom: 8px;
        width: 240px;
        padding: 14px;
    }
}

/* --- Touch optimizations --- */
@media (hover: none) and (pointer: coarse) {
    /* Увеличенные зоны нажатия для пальцев */
    .sendBtn,
    .attachBtn,
    .ttsToggleBtn,
    .micBtn,
    #side-panel-btns > button,
    .closed,
    .profile-save-btn,
    .profile-logout-btn,
    #avatar-upload-label {
        -webkit-tap-highlight-color: transparent;
    }

    /* Убираем hover-эффекты на тач-устройствах (предотвращает залипание) */
    .sendBtn:hover:not(:disabled) {
        background: transparent;
        color: #fff;
        border-color: #333;
        box-shadow: none;
    }

    /* Active state вместо hover для тач */
    .sendBtn:active:not(:disabled) {
        background: #707070;
        color: #000;
        border-color: #fff;
        box-shadow: 0 0 20px rgba(255, 255, 255, 0.3);
    }

    .profile-save-btn:active {
        color: #fff;
        border-color: rgba(255, 255, 255, 0.3);
    }

    .profile-logout-btn:active {
        color: #ff5050;
        border-color: rgba(255, 80, 80, 0.5);
    }

    #avatar-upload-label:active {
        color: #fff;
        border-color: rgba(255, 255, 255, 0.3);
    }

    /* Плавная прокрутка с инерцией для iOS */
    #chat-container {
        -webkit-overflow-scrolling: touch;
    }

    /* Предотвращаем случайные выделения при скролле */
    .msg {
        -webkit-user-select: text;
        user-select: text;
    }
}

/* --- Prevent iOS input zoom (font-size < 16px triggers zoom) --- */
@media screen and (max-width: 768px) {
    input[type="text"],
    input[type="password"],
    input[type="file"],
    textarea,
    select {
        font-size: 16px !important;
    }
}

/* --- Планировщик — адаптация для мобильных --- */
@media screen and (max-width: 768px) {
    #events-panel {
        padding: 22px 20px;
        gap: 12px;
    }
    #events-panel-resizer { display: none; }
    /* Пилюля управления — снизу по центру, как у #side-panel-btns. */
    #events-panel-controls {
        position: fixed !important;
        top: auto !important;
        right: auto !important;
        left: 50% !important;
        bottom: 10px;
        transform: translateX(-50%);
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 10px;
        padding: 10px;
        border-radius: 30px;
        background: #000;
        border: 1px solid rgba(255, 255, 255, 0.08);
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
        z-index: 110;
    }
    body.light #events-panel-controls {
        background: #fff;
        border-color: rgba(0, 0, 0, 0.08);
        box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
    }
    #events-panel-controls > button {
        width: 44px;
        height: 44px;
        min-width: 44px;
    }
    /* Тултипы на мобилке — над кнопкой, той же высоты что и кнопка (44px). */
    #events-panel-controls > button[data-tooltip]::after {
        top: auto !important;
        bottom: calc(100% + 10px) !important;
        left: 50% !important;
        transform: translateX(-50%) translateY(4px) !important;
        height: 44px !important;
        padding: 0 14px !important;
    }
    #events-panel-controls > button[data-tooltip]:hover::after,
    #events-panel-controls > button[data-tooltip]:focus-visible::after {
        transform: translateX(-50%) translateY(0) !important;
    }
    .events-title.panel-header {
        font-size: 12px;
        letter-spacing: 2px;
    }
    .events-tabs { margin: 0; }
    .events-tab-btn {
        padding: 10px 8px;
        font-size: 11px;
        letter-spacing: 1.5px;
    }
    #events-create-btn,
    #companies-create-btn {
        padding: 12px 10px;
        font-size: 12px;
        letter-spacing: 1.5px;
        min-height: 44px;
    }
    .events-input {
        padding: 11px 12px;
        font-size: 14px;
    }
    /* События */
    .events-item { padding: 12px; }
    .events-item-when { font-size: 11px; }
    .events-item-title { font-size: 14px; padding-right: 34px; }
    .events-item-place, .events-item-details { font-size: 12px; }
    .events-item > .events-item-del {
        width: 34px;
        height: 34px;
        padding: 0;
        font-size: 24px;
        top: 6px;
        right: 6px;
    }

    /* Группы */
    .company-card { padding: 12px; gap: 10px; }
    .company-card-name-text { font-size: 14px; }
    .company-card-actions button {
        padding: 10px 10px;
        font-size: 10px;
        min-height: 42px;
    }
    .company-card-section-title { font-size: 9px; }
    .company-card-members-title { font-size: 9px; }
    .company-event-item { padding: 10px; font-size: 13px; }
    .company-event-item .company-event-role { font-size: 9px; }
    .company-card-member { font-size: 11px; max-width: 100%; }
    .company-card-member img { width: 20px; height: 20px; }
    .company-card-member-remove {
        font-size: 18px;
        padding: 0 6px;
        min-width: 26px;
        min-height: 26px;
    }
    .company-card-top-actions .company-card-del {
        width: 34px;
        height: 34px;
        font-size: 22px;
    }
    .company-card-top-actions { gap: 6px; }
    .company-card-meta-line { font-size: 10px; }

    /* Приглашения */
    .group-invite-item { padding: 10px 12px; font-size: 13px; }
    .group-invite-item .gi-actions button {
        padding: 9px 10px;
        font-size: 10px;
        min-height: 40px;
    }

    /* GCal */
    #gcal-section { padding: 12px 14px; }
    .gcal-disconnected { gap: 11px; }
    .gcal-disconnected-icon { width: 40px; height: 40px; }
    .gcal-disconnected-title { font-size: 14px; }
    .gcal-disconnected-sub { font-size: 12px; }
    .gcal-btn {
        padding: 11px 14px;
        font-size: 14px;
        min-height: 44px;
    }
    .gcal-btn-block { padding: 13px 14px; font-size: 14px; }
    .gcal-actions { gap: 10px; }

    /* Модалки групп на мобилках — на всю ширину */
    .companies-modal {
        padding: 10px;
        padding-top: calc(10px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
        align-items: flex-start;
    }
    .companies-modal-content {
        padding: 18px 16px;
        max-width: 100%;
        max-height: calc(100vh - 20px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
        border-radius: 12px;
        box-sizing: border-box;
        -webkit-overflow-scrolling: touch;
        /* На мобиле touch-скролл — резервировать gutter не нужно */
        scrollbar-gutter: auto;
    }
    .companies-modal-wide {
        max-width: 100%;
        width: 100%;
    }
    .companies-modal-content > * { box-sizing: border-box; }
    .companies-modal-content h3 { font-size: 15px; padding-right: 40px; }
    .companies-modal-close {
        width: 36px;
        height: 36px;
        font-size: 22px;
        top: 8px;
        right: 8px;
    }
    .companies-modal-content .events-field-label {
        font-size: 12px;
        margin-top: 10px;
        display: block;
    }
    .companies-modal-content .events-input,
    .companies-modal-content input[type="text"],
    .companies-modal-content input[type="email"],
    .companies-modal-content input[type="date"],
    .companies-modal-content input[type="time"],
    .companies-modal-content textarea,
    .companies-modal-content select {
        font-size: 16px; /* iOS: блокирует авто-зум при фокусе */
        min-height: 44px;
        padding: 11px 12px;
        box-sizing: border-box;
        width: 100%;
        display: block;
    }
    .companies-modal-content textarea { min-height: 84px; line-height: 1.4; }
    .companies-modal-content .events-select {
        width: 100%;
        display: block;
    }
    .companies-modal-content .events-select-button {
        width: 100%;
        min-height: 44px;
        font-size: 16px;
        padding: 11px 12px;
        padding-right: 32px;
        box-sizing: border-box;
    }

    /* Нижняя панель действий — sticky, с горизонтальным паддингом */
    .companies-modal-actions {
        flex-wrap: wrap;
        position: sticky;
        bottom: 0;
        background: var(--t-panel);
        padding: 10px 0 6px 0;
        margin-top: 14px;
        z-index: 2;
    }
    .companies-modal-actions button {
        flex: 1 1 calc(50% - 4px);
        min-height: 44px;
        padding: 10px 12px;
        font-size: 13px;
        box-sizing: border-box;
    }
    .companies-modal-actions .danger-btn { flex: 1 1 100%; margin-right: 0; }

    /* Drag&drop роли — в одну колонку */
    .company-roles { flex-direction: column; gap: 10px; margin-top: 12px; }
    .company-role-col { min-width: 0; padding: 12px; }
    .company-role-title { font-size: 11px; margin-bottom: 8px; }
    .company-role-list { min-height: 48px; gap: 6px; }
    .member-chip {
        font-size: 13px;
        padding: 8px 10px;
        min-height: 38px;
        box-sizing: border-box;
    }
    .member-chip img { width: 24px; height: 24px; }
    .member-chip-remove {
        font-size: 18px;
        padding: 0 6px;
        min-width: 26px;
        min-height: 26px;
    }

    /* Кнопки «Прикрепить файл» / «Добавить участников» — единый вид */
    #company-event-attach-btn,
    #company-event-report-attach-btn,
    #company-event-add-members-btn {
        display: block;
        width: 100%;
        min-height: 44px;
        padding: 12px 14px;
        font-size: 13px;
        background: var(--t-surface-strong);
        color: var(--t-text);
        border: 1px solid var(--t-border);
        border-radius: 8px;
        cursor: pointer;
        box-sizing: border-box;
        margin-top: 10px;
        text-align: center;
    }
    #company-event-attach-btn:active,
    #company-event-report-attach-btn:active,
    #company-event-add-members-btn:active {
        background: var(--t-input-bg-focus);
    }

    /* Прикреплённые файлы — плашки */
    .company-event-files { margin: 8px 0 12px 0; }
    .company-event-files #company-event-files-list {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-top: 10px;
        font-size: 13px;
    }
    .company-file-chip {
        padding: 8px 10px 8px 8px;
        font-size: 13px;
    }
    .company-file-chip a.cf-name { max-width: 160px; }
    .company-file-chip .cf-remove {
        font-size: 18px;
        padding: 0 4px;
        min-width: 24px;
    }

    /* Отчёты (список) */
    #company-event-reports-list { max-height: none; }
    .company-report-item { font-size: 13px; padding: 10px; }

    /* Участники в модалке — скролл-контейнер */
    .company-members-results { max-height: 55vh; }
    .company-member-row { padding: 12px 10px; min-height: 48px; }
    .company-member-row img { width: 32px; height: 32px; }
    .company-member-row .cm-name { font-size: 14px; }

    /* Пуш-уведомления — на всю ширину экрана */
    .invitation-push-container {
        top: auto;
        left: 10px;
        right: 10px;
        bottom: calc(90px + env(safe-area-inset-bottom, 0px));
        max-width: none;
    }
    .invitation-push { padding: 12px; font-size: 13px; }
    .invitation-push-actions button { min-height: 42px; }
}

@media screen and (max-width: 480px) {
    #events-panel {
        width: calc(100vw - 20px);
        right: 10px;
        top: 10px;
        bottom: 10px;
        padding: 18px 16px;
        gap: 10px;
    }
    .events-title.panel-header { font-size: 11px; letter-spacing: 1.5px; }
    .events-tab-btn { font-size: 10px; padding: 9px 6px; letter-spacing: 1px; }
    #events-create-btn,
    #companies-create-btn {
        margin: 6px 0 10px 0;
        padding: 11px 10px;
        font-size: 11px;
    }
    .events-input { padding: 10px 12px; }
    /* Группы — компактнее */
    .company-card { padding: 10px; gap: 8px; }
    .company-card-name-text { font-size: 13px; }
    .company-avatar { width: 56px; height: 56px; }
    .company-card-header { gap: 10px; }
    .company-card-actions button { font-size: 9px; padding: 9px; }
    .company-event-item { padding: 9px 10px; font-size: 12px; }
    .company-card-member { font-size: 11px; padding: 3px 8px 3px 3px; }
    .company-card-top-actions .company-card-del { font-size: 22px; width: 32px; height: 32px; }
    .company-card-meta-line { font-size: 10px; line-height: 1.25; }

    /* Модалки */
    .companies-modal {
        padding: 6px;
        padding-top: calc(6px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px));
    }
    .companies-modal-content {
        padding: 14px;
        border-radius: 10px;
        max-height: calc(100vh - 12px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    }
    .companies-modal-content h3 { font-size: 14px; margin-bottom: 10px; padding-right: 38px; }
    .companies-modal-actions { flex-direction: column; gap: 6px; }
    .companies-modal-actions button { flex: 1 1 100%; width: 100%; }
    .companies-modal-actions .danger-btn { order: 2; }
    .companies-modal-content .events-field-label { font-size: 11px; }
    .company-role-col { padding: 8px; }
    .member-chip { font-size: 12px; padding: 7px 9px; }

    /* GCal */
    #gcal-section { padding: 11px 12px; }
    .gcal-disconnected-icon { width: 38px; height: 38px; }
    .gcal-disconnected-icon svg { width: 22px; height: 22px; }
    .gcal-status-line { font-size: 13px; }
    .gcal-btn-ghost { flex: 0 0 auto; }
    .gcal-actions .gcal-btn-primary:not(.gcal-btn-block) { flex: 1 1 auto; }
}

@media screen and (max-width: 375px) {
    #events-panel {
        top: 8px;
        bottom: 8px;
        right: 8px;
        width: calc(100vw - 16px);
        padding: 16px 14px;
        gap: 10px;
    }
    .company-card { padding: 10px; }
    .company-card-actions button { font-size: 9px; letter-spacing: 1px; }
    .company-event-item { padding: 8px 10px; }
    .companies-modal-content { padding: 12px; }
}

/* Тач-устройства: hover → active для gcal-кнопок */
@media (hover: none) and (pointer: coarse) {
    .gcal-btn { -webkit-tap-highlight-color: transparent; }
    .gcal-btn:hover:not(:disabled) { transform: none; }
    .gcal-btn:active:not(:disabled) {
        background: rgba(100, 200, 255, 0.25);
        border-color: rgba(100, 200, 255, 0.7);
    }
    .gcal-btn-ghost:active:not(:disabled) {
        background: rgba(255, 80, 80, 0.15);
        border-color: rgba(255, 120, 120, 0.55);
        color: rgba(255, 180, 180, 0.95);
    }
}

/* --- Календарь мероприятий на мобилке --- */
@media screen and (max-width: 768px) {
    .calendar-modal-content {
        max-width: 100%;
    }
    .calendar-header {
        padding-right: 36px;
        gap: 6px;
    }
    .calendar-title { font-size: 14px; }
    .calendar-nav-btn { width: 34px; height: 34px; font-size: 20px; }
    .calendar-today-btn { padding: 8px 10px; font-size: 10px; }
    .calendar-grid-viewport {
        min-height: 0;
    }
    .calendar-grid {
        grid-auto-rows: minmax(68px, auto);
        gap: 3px;
    }
    .calendar-day {
        min-height: 68px;
        padding: 3px;
        gap: 2px;
    }
    .calendar-day-num { font-size: 11px; padding: 0 2px; }
    /* Многодневные бары позиционируются абсолютно — на десктопе top: 30px
       под padding 6px + day-num ≈15px. На мобилке padding 3px и day-num
       мельче, спэйсер в flex-потоке стартует ~18px — выравниваем top,
       иначе бары налезают на одноденные плашки. */
    .calendar-day-md-wrap {
        top: 18px;
        left: 3px;
        right: 3px;
    }
    .calendar-event-tile {
        padding: 2px 4px;
        font-size: 9px;
        gap: 3px;
    }
    .calendar-event-tile .cal-ev-time { display: none; }
    .calendar-weekday { font-size: 9px; letter-spacing: 0.8px; }
    .calendar-tooltip {
        position: fixed;
        left: 10px !important;
        right: 10px;
        top: auto !important;
        bottom: 10px;
        max-width: none !important;
    }
    .calendar-agenda {
        position: fixed;
        left: 10px;
        right: 10px;
        bottom: 10px;
        top: auto;
        width: auto;
        max-height: 60vh;
    }
}

/* --- Боковые панели — единая раскладка на мобилке.
       Важно: этот блок размещён в самом конце, чтобы перекрыть
       все breakpoint-специфичные overrides выше по файлу. --- */
@media screen and (max-width: 768px) {
    #user-profile-details,
    #events-panel,
    #soul-panel,
    #candidates-panel,
    #additions-panel,
    #photon_soul-panel {
        min-width: unset;
        top: 10px;
        bottom: 10px;
        left: 10px;
        right: 10px;
        width: auto;
        max-width: none;
    }
    /* Профиль базово скрыт через right-позицию — на мобилке переводим
       на transform, чтобы left/right остались фиксированными. */
    #user-profile-details {
        transform: translateX(calc(100% + 30px));
        transition: transform 0.4s ease;
    }
    #user-profile-details.active {
        transform: translateX(0);
        right: 10px;
    }

    /* Скролл внутри списков — контейнеры табов работают как flex-колонки,
       а overflow висит на самих списках. */
    #events-tab-personal-content,
    #events-tab-group-content {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
    }
    #events-list,
    #companies-list {
        -webkit-overflow-scrolling: touch;
    }

    /* === Групповой чат — мобильная адаптация (≤768px) === */

    /* Модалка — на весь экран */
    .group-chat-modal-content {
        max-width: 100%;
        height: calc(100vh - 20px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
        max-height: none;
        border-radius: 12px;
    }

    /* Шапка — компактнее */
    .group-chat-header {
        padding: 10px 14px;
    }
    #group-chat-header-name {
        font-size: 14px;
    }
    .group-chat-header-close {
        width: 36px;
        height: 36px;
        font-size: 22px;
    }
    /* На мобилке модалка чатов и так занимает весь экран — кнопка fullscreen не нужна */
    .gc-header-fullscreen-btn {
        display: none;
    }

    /* Сайдбар участников — скрыт, показывается по шторке */
    .group-chat-members {
        display: none;
    }
    .group-chat-main {
        width: 100%;
    }

    /* Кнопка открытия сайдбара на мобилке (добавится через JS) */
    .gc-mobile-members-toggle {
        display: block;
        background: none;
        border: none;
        font-size: 20px;
        cursor: pointer;
        padding: 4px;
        line-height: 1;
        color: var(--t-text-muted);
        flex-shrink: 0;
    }
    .gc-mobile-members-toggle:active {
        color: var(--t-text);
    }

    /* Когда сайдбар открыт на мобилке */
    .group-chat-members.gc-mobile-open {
        display: flex;
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        width: 260px;
        max-width: 75vw;
        z-index: 10;
        background: var(--t-panel);
        border-right: 1px solid var(--t-border);
        box-shadow: 4px 0 20px rgba(0,0,0,0.3);
    }

    /* Сообщения — компактнее */
    .group-chat-messages {
        padding: 10px 10px 4px;
    }
    .gc-msg {
        gap: 6px;
        padding: 4px 0;
    }
    .gc-msg-avatar {
        width: 28px;
        height: 28px;
    }
    .gc-msg-body {
        padding: 10px 14px 36px;
        max-width: 88%;
    }
    .gc-msg-name { font-size: 12px; }
    .gc-msg-text { font-size: 14px; line-height: 1.55; letter-spacing: 0.3px; }
    /* Время — меньше шрифт. Размеры кнопок остаются как в чате Фотона
       (26×26, icon 14), чтобы оба чата выглядели одинаково. */
    .gc-msg-time { font-size: 10px; }
    .gc-date-divider { font-size: 10px; margin: 8px 0 4px; }

    /* Поле ввода */
    .group-chat-input-area {
        padding: 8px 10px;
        padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
        gap: 6px;
    }
    .group-chat-input-area textarea,
    .group-chat-input-area .textarea-emoji-wrap {
        font-size: 16px !important;
        width: 100%;
        flex: 1 1 100%;
    }
    .group-chat-input-area textarea {
        padding: 8px 10px;
        border-radius: 20px;
    }
    /* Три кнопки в ряд (attach/tts/mic) — полная ширина, поровну. */
    .group-chat-input-area .gc-attach-btn,
    .group-chat-input-area .gc-tts-toggle-btn,
    .group-chat-input-area .gc-mic-btn {
        flex: 1 1 0;
        min-width: 0;
        width: auto;
        height: 40px;
    }
    /* Кнопка отправки — отдельной полной строкой. */
    #group-chat-send-btn {
        flex-basis: 100%;
        width: auto;
        height: 40px;
        border-radius: 8px;
    }

    /* Кнопка чата в карточке группы — больше зона тача */
    .company-card-chat-btn {
        width: 34px;
        height: 34px;
        font-size: 19px;
    }

    /* В модалке Чатов основной input должен вести себя как .group-chat-input-area */
    body.chats-hub-mode #input-area {
        padding: 8px 10px;
        padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
        gap: 6px;
    }
    body.chats-hub-mode #userInput {
        font-size: 16px !important;
        padding: 8px 10px;
        border-radius: 20px;
    }
    body.chats-hub-mode .sendBtn {
        flex-basis: 100%;
        width: auto;
        height: 40px;
        border-radius: 8px;
        min-width: 0;
        margin-left: 0;
    }
    body.chats-hub-mode .attachBtn,
    body.chats-hub-mode .micBtn,
    body.chats-hub-mode .ttsToggleBtn {
        flex: 1 1 0;
        min-width: 0;
        width: auto;
        height: 40px;
        border-radius: 20px;
    }
}

/* === Групповой чат — маленькие телефоны (≤480px) === */
@media screen and (max-width: 480px) {
    .group-chat-modal-content {
        border-radius: 0;
        height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    }
    .group-chat-header {
        padding: 8px 12px;
    }
    .gc-msg-avatar {
        width: 26px;
        height: 26px;
    }
    .gc-msg-body { padding: 8px 12px 32px; max-width: 92%; }
    .gc-msg-text { font-size: 13px; line-height: 1.4; letter-spacing: 0.2px; }
}

/* === Групповой чат — landscape телефоны === */
@media screen and (max-width: 900px) and (max-height: 500px) and (orientation: landscape) {
    .group-chat-modal-content {
        height: calc(100vh - 16px);
        max-height: none;
        border-radius: 8px;
    }
    .group-chat-header { padding: 6px 12px; }
    .group-chat-messages { padding: 6px 10px 2px; }
    .gc-msg { padding: 2px 0; }
    .gc-msg-avatar { width: 24px; height: 24px; }
    .group-chat-input-area { padding: 6px 10px; }
}

/* Тач-оптимизация для чата */
@media (hover: none) and (pointer: coarse) {
    .group-chat-member-chip {
        -webkit-tap-highlight-color: transparent;
        min-height: 40px;
    }
    .group-chat-member-chip:active:not(.is-photon) {
        background: rgba(100, 200, 255, 0.12);
    }
    #group-chat-send-btn {
        -webkit-tap-highlight-color: transparent;
    }
    #group-chat-send-btn:active {
        background: rgba(100, 200, 255, 0.3);
    }
    .gc-msg-tts {
        min-width: 28px;
        min-height: 28px;
        padding: 6px;
    }
    .group-chat-messages {
        -webkit-overflow-scrolling: touch;
    }
}

/* === Видеозвонки — мобильная адаптация === */
@media screen and (max-width: 768px) {
    .call-video-wrap {
        width: 100%;
        max-height: none;
        border-radius: 0;
        aspect-ratio: auto;
        flex: 1;
    }
    .call-local-wrap {
        width: 100px;
        height: 75px;
        bottom: 8px;
        right: 8px;
        border-radius: 8px;
    }
    .call-local-avatar-img { width: 36px; height: 36px; }
    /* .call-remote-avatar на мобилке остаётся под управлением базовой формулы
       clamp(96px, 40cqmin, 260px) — адаптируется к размеру блока автоматически. */
    .call-controls {
        padding: 12px;
        gap: 12px;
    }
    .call-ctrl-btn {
        width: 46px;
        height: 46px;
    }
}

/* ===================================================
   Fullscreen модалки и выдвижные панели на мобиле
   Разворачивает выдвижные панели и «большие» модалки
   на всю высоту экрана без отступов от краёв.
   Подтверждающие диалоги (.additions-modal, .candidates-modal,
   .photon_soul-modal) остаются центрированными.
   Этот блок намеренно размещён последним, чтобы перекрыть
   все breakpoint-специфичные overrides выше.
   =================================================== */
@media screen and (max-width: 768px) {
    /* --- Выдвижные панели --- */
    #user-profile-details,
    #events-panel,
    #soul-panel,
    #candidates-panel,
    #additions-panel,
    #photon_soul-panel {
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100vw;
        max-width: none;
        min-width: 0;
        border-radius: 0;
        box-sizing: border-box;
        padding-top: calc(20px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    }
    /* Профиль скрывается translateX(100%) — правый сдвиг ровно на ширину */
    #user-profile-details {
        transform: translateX(100%);
        transition: transform 0.35s ease;
    }
    #user-profile-details.active {
        transform: translateX(0);
        right: 0;
    }

    /* --- Основные модалки (формы, большие диалоги) — fullscreen --- */
    .companies-modal {
        padding: 0;
        align-items: stretch;
        justify-content: stretch;
    }
    .companies-modal-content {
        max-width: none;
        width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        border-radius: 0;
        box-sizing: border-box;
        padding-top: calc(16px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
    }
    .companies-modal-wide {
        max-width: none;
    }
    .calendar-modal-content {
        max-width: none;
    }

    /* --- Групповой чат — убираем закругления, фиксируем высоту --- */
    .group-chat-modal-content {
        border-radius: 0;
        height: 100dvh;
        max-height: 100dvh;
    }

    /* --- Email-verify / recovery-email / recovery-code --- */
    .email-verify-modal {
        padding: 0;
    }
    .email-verify-modal-content {
        max-width: none;
        width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        border-radius: 0;
        box-sizing: border-box;
        padding-top: calc(28px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(22px + env(safe-area-inset-bottom, 0px));
    }

    /* Подтверждающие диалоги (.additions-modal / .candidates-modal /
       .photon_soul-modal) намеренно не трогаем — остаются центрированными. */

    /* Модалки участников группы (company-members, member-profile) —
       возвращаем прежний вид: центрированные с отступом от краёв. */
    .companies-modal.companies-modal-over {
        padding: 10px;
        padding-top: calc(10px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
        align-items: center;
        justify-content: center;
    }
    .companies-modal.companies-modal-over .companies-modal-content {
        width: 100%;
        max-width: 100%;
        height: auto;
        max-height: calc(100vh - 20px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
        border-radius: 12px;
        padding: 18px 16px;
    }
}

@media screen and (max-width: 480px) {
    .companies-modal.companies-modal-over {
        padding: 6px;
        padding-top: calc(6px + env(safe-area-inset-top, 0px));
        padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px));
    }
    .companies-modal.companies-modal-over .companies-modal-content {
        padding: 14px;
        border-radius: 10px;
        max-height: calc(100vh - 12px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    }
}

/* === iOS safe-area для верхнего ряда кнопок =========================
   На мобилке боковые панели уходят в fullscreen (top:0). Их inline-контент
   уже сдвинут правилом padding-top: calc(20px + env(safe-area-inset-top)),
   но абсолютно позиционированные кнопки (календарь, экспорт, плашка
   ПРО-слотов, крестик закрытия) не подчиняются padding и оказываются под
   системной строкой iPhone (часы/сеть/нотч). Сдвигаем их ниже на
   env(safe-area-inset-top). ================================================ */
@media screen and (max-width: 768px) {
    #events-panel #events-calendar-btn,
    #events-panel #events-export-btn,
    #events-panel #pro-seats-plaque,
    #user-profile-details .closed,
    #events-panel .closed,
    #soul-panel .closed,
    #candidates-panel .closed,
    #additions-panel .closed,
    #photon_soul-panel .closed {
        top: calc(8px + env(safe-area-inset-top, 0px)) !important;
    }
    /* Модалка группового чата — шапка прибита к верху fullscreen-контейнера,
       крестик и кнопка fullscreen уходят под статус-бар без этого отступа. */
    .group-chat-header {
        padding-top: calc(10px + env(safe-area-inset-top, 0px));
    }
}
