/* BOTIX Mobile Bottom Navigation — public + cabinet + admin.
 * Перенос из studio85-rent с адаптацией под BRANDBOOK BOTIX.
 * Цвета BOTIX: #007AFF (синий, акцент), #1d1d1f (текст), #86868B (приглушённый),
 *              #E5E5EA (рамки), #FF3B30 (бейдж).
 * Без CSS-флага override, без фиолетового, без админского body-класса rent.
 */

:root {
    /* Локальные переменные модуля mobile-menu (--mm-*) */
    --mm-text: #1d1d1f;
    --mm-muted: #86868B;
    --mm-accent: #007AFF;
    --mm-bg: #ffffff;
    --mm-border: #E5E5EA;
    --mm-active: #007AFF;
    --mm-badge-bg: #FF3B30;
    --mm-badge-fg: #ffffff;

    /* Геометрия меню */
    --mobile-nav-height: 70px;
    --mobile-nav-offset: 116px;
    --mobile-nav-bg: rgba(255, 255, 255, 0.82);
    --mobile-nav-border: rgba(229, 229, 234, 0.7);
    --mobile-nav-shadow: 0 20px 45px rgba(15, 23, 42, 0.18), 0 6px 14px rgba(15, 23, 42, 0.08);
    --mobile-nav-radius: 999px;
    --mobile-nav-item-radius: 999px;

    /* Отступы меню (значения обновляются из админки PHP) */
    --mn-pad-sides: 12px;
    --mn-pad-bottom: 8px;
    --mn-tpad-sides: 12px;
    --mn-tpad-bottom: 8px;
}

/* Стабилизация body для мобильных устройств */
html {
    overflow-x: hidden;
}

body.has-mobile-nav {
    /*
     * ВАЖНО: НЕ использовать -webkit-overflow-scrolling: touch на body!
     * Это ломает position: fixed - меню начинает скроллиться вместе со страницей.
     * overscroll-behavior-y: contain - безопасен и предотвращает "bounce" скролл.
     */
    overscroll-behavior-y: contain;
    overflow-x: hidden;
    /* Разрешить только вертикальный скролл и tap, запретить pinch-zoom */
    touch-action: pan-y;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
}

/* Базовые стили — все меню скрыты по умолчанию */
.mobile-nav,
.cabinet-tabbar,
.admin-tabbar {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1100;
    padding: 10px var(--mn-pad-sides) calc(var(--mn-pad-bottom) + env(safe-area-inset-bottom, 0px));
    /* Фиксация для iOS/Android — предотвращает "плавание" при скролле */
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    /* Дополнительная стабилизация */
    pointer-events: auto;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
}

/* Внутренний контейнер */
.mobile-nav__inner,
.cabinet-tabbar__inner,
.admin-tabbar__inner {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 10px;
    align-items: center;
    width: min(100vw - 2 * var(--mn-pad-sides), 560px);
    min-height: var(--mobile-nav-height);
    margin: 0 auto;
    padding: 10px 16px;
    background: rgba(255, 255, 255, 0.98);
    border-radius: var(--mobile-nav-radius);
    box-shadow: var(--mobile-nav-shadow);
    border: 1px solid var(--mobile-nav-border);
}

/* Общие стили элементов */
.mobile-nav__item,
.tabbar-item {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 8px 6px;
    border-radius: var(--mobile-nav-item-radius);
    color: var(--mm-muted);
    background: transparent;
    border: 0;
    box-shadow: none;
    font-size: 0.72rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.15s ease, color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
    -webkit-tap-highlight-color: transparent;
}

.mobile-nav__item i,
.tabbar-item i {
    font-size: 22px;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    color: var(--mm-accent);
}
.mobile-nav__item svg.bi,
.tabbar-item svg.bi {
    width: 22px;
    height: 22px;
    color: var(--mm-accent);
    flex-shrink: 0;
}

.mobile-nav__item span,
.tabbar-item span {
    line-height: 1;
}

.mobile-nav__item.is-active,
.tabbar-item.active {
    color: var(--mm-active);
    background: rgba(255, 255, 255, 0.7);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8), 0 6px 12px rgba(15, 23, 42, 0.08);
}

.mobile-nav__item:active,
.tabbar-item:active {
    transform: translateY(1px) scale(0.98);
}

/* Бейджи */
.tabbar-badge,
.tabbar-item .badge {
    position: absolute;
    top: 4px;
    right: 14px;
    background: var(--mm-badge-bg);
    color: var(--mm-badge-fg);
    font-size: 9px;
    font-weight: 600;
    padding: 2px 5px;
    border-radius: 10px;
    min-width: 16px;
    text-align: center;
    line-height: 1.2;
}

/* ====== NARROW/WIDE ПЕРЕКЛЮЧЕНИЕ ====== */
/* По умолчанию все варианты скрыты */
.mobile-nav--narrow,
.mobile-nav--wide,
.cabinet-tabbar--narrow,
.cabinet-tabbar--wide,
.admin-tabbar--narrow,
.admin-tabbar--wide {
    display: none;
}

/* ====== ТЕЛЕФОНЫ (< 768px) — показываем меню ======
 * Специфичность повышена через `body` для перебивки базового `display: none`,
 * без CSS-флага override.
 */
@media (max-width: 767px) {
    body .mobile-nav--wide,
    body .cabinet-tabbar--wide,
    body .admin-tabbar--wide {
        display: none;
    }

    body .mobile-nav,
    body .mobile-nav--narrow,
    body .cabinet-tabbar,
    body .cabinet-tabbar--narrow,
    body .admin-tabbar,
    body .admin-tabbar--narrow {
        display: flex;
        justify-content: center;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1100;
        padding: 10px var(--mn-pad-sides) calc(var(--mn-pad-bottom) + env(safe-area-inset-bottom, 0px));
        /* Фиксация для iOS/Android */
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
        will-change: transform;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
    }

    body.has-mobile-nav .page-content,
    body.has-mobile-nav .cabinet-content {
        padding-bottom: calc(var(--mobile-nav-offset) + env(safe-area-inset-bottom, 0px));
    }

    body.has-mobile-nav .footer {
        display: none;
    }
}

/* ====== ПЛАНШЕТЫ (>= 768px touch) — показываем меню ====== */
@media (min-width: 768px) and (pointer: coarse) {
    body .mobile-nav--narrow,
    body .cabinet-tabbar--narrow,
    body .admin-tabbar--narrow {
        display: none;
    }

    body .mobile-nav,
    body .mobile-nav--wide,
    body .cabinet-tabbar,
    body .cabinet-tabbar--wide,
    body .admin-tabbar,
    body .admin-tabbar--wide {
        display: flex;
        justify-content: center;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1100;
        padding: 10px var(--mn-tpad-sides) calc(var(--mn-tpad-bottom) + env(safe-area-inset-bottom, 0px));
        /* Фиксация для iOS/Android */
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
        will-change: transform;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
    }

    body.has-mobile-nav .page-content,
    body.has-mobile-nav .cabinet-content {
        padding-bottom: calc(var(--mobile-nav-offset) + env(safe-area-inset-bottom, 0px));
    }

    /* На планшете .footer виден (как на десктопе), просто отодвинут от низа,
       чтобы не залезал под фиксированный mobile-nav. .lfm-footer (mobile-only)
       не показывается — у него media (max-width: 767px). */
    body.has-mobile-nav .footer {
        padding-bottom: calc(var(--mobile-nav-offset) + 16px + env(safe-area-inset-bottom, 0px));
    }
}

/* ====== ДЕСКТОП С УЗКИМ ОКНОМ (для тестирования) ====== */
@media (min-width: 768px) and (max-width: 1024px) and (pointer: fine) {
    body .mobile-nav--narrow,
    body .cabinet-tabbar--narrow,
    body .admin-tabbar--narrow {
        display: none;
    }

    body .mobile-nav,
    body .mobile-nav--wide,
    body .cabinet-tabbar,
    body .cabinet-tabbar--wide,
    body .admin-tabbar,
    body .admin-tabbar--wide {
        display: flex;
        justify-content: center;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1100;
        padding: 10px var(--mn-tpad-sides) calc(var(--mn-tpad-bottom) + env(safe-area-inset-bottom, 0px));
        /* Фиксация для iOS/Android */
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
        will-change: transform;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
    }
}

/* ====== РАЗМЕРЫ ДЛЯ РАЗНЫХ ЭКРАНОВ ====== */

/* Телефоны */
@media (max-width: 640px) {
    .mobile-nav__inner,
    .cabinet-tabbar__inner,
    .admin-tabbar__inner {
        width: calc(100vw - 2 * var(--mn-pad-sides));
        max-width: 100%;
    }
}

/* Планшеты */
@media (min-width: 641px) and (pointer: coarse),
       (min-width: 641px) and (max-width: 1024px) {
    .mobile-nav__inner,
    .cabinet-tabbar__inner,
    .admin-tabbar__inner {
        width: min(100vw - 2 * var(--mn-tpad-sides), 760px);
    }
}

/* Маленькие телефоны */
@media (max-width: 400px) {
    .mobile-nav__item,
    .tabbar-item {
        font-size: 0.66rem;
    }

    .mobile-nav__item i,
    .tabbar-item i {
        font-size: 20px;
    }
    .mobile-nav__item svg.bi,
    .tabbar-item svg.bi {
        width: 20px;
        height: 20px;
    }
}

/* ====== PWA КНОПКА ======
 * Специфичность повышена через вложенность .mobile-nav ... — без CSS-флага override.
 */
.mobile-nav__pwa {
    cursor: pointer;
}

.mobile-nav__pwa-icon {
    width: 24px;
    height: 24px;
    border-radius: 6px;
}

.mobile-nav .mobile-nav__pwa--inactive,
.mobile-nav__item.mobile-nav__pwa--inactive {
    background: transparent;
    color: var(--mm-muted);
}

.mobile-nav .mobile-nav__pwa--inactive i,
.mobile-nav__item.mobile-nav__pwa--inactive i {
    color: var(--mm-accent);
}

.mobile-nav .mobile-nav__pwa--active,
.mobile-nav__item.mobile-nav__pwa--active {
    background: linear-gradient(135deg, #007AFF 0%, #0066D6 100%);
    color: #ffffff;
}

.mobile-nav .mobile-nav__pwa--active i,
.mobile-nav__item.mobile-nav__pwa--active i {
    color: #ffffff;
}

.mobile-nav .mobile-nav__pwa--active:active,
.mobile-nav__item.mobile-nav__pwa--active:active {
    background: linear-gradient(135deg, #0066D6 0%, #0052B3 100%);
}

/* Скрытие PWA-кнопки. Специфичность повышена через `body` чтобы перебить
 * `display: flex` из media-запросов выше — через специфичность, без override-флага. */
body .mobile-nav__pwa--hidden,
body .mobile-nav .mobile-nav__pwa--hidden,
body .mobile-nav__item.mobile-nav__pwa--hidden {
    display: none;
}

/* ====== CABINET-TABBAR — стили внутреннего контейнера ====== */
/* ВАЖНО: width применяется к __inner, НЕ к nav! */
@media (max-width: 767px) {
    .cabinet-tabbar .cabinet-tabbar__inner {
        width: calc(100vw - 2 * var(--mn-pad-sides));
        max-width: 560px;
    }
}

@media (min-width: 768px) and (pointer: coarse) {
    .cabinet-tabbar .cabinet-tabbar__inner {
        width: min(100vw - 2 * var(--mn-tpad-sides), 760px);
    }
}

/* ====== УВЕДОМЛЕНИЯ — ПОДНИМАЕМ НАД МЕНЮ ======
 * id-селекторы уже имеют высокую специфичность — override-флаг не нужен.
 */
@media (max-width: 1024px), (pointer: coarse) {
    #notification-toast-container {
        bottom: 130px;
    }

    #notification-floating-badge {
        bottom: 130px;
    }
}

/* ====== ACTION SHEET (открывается через пункт «Ещё», action_type='more') ======
 * Apple iOS bottom-sheet поверх bottom-bar. Backdrop затемняет фон,
 * sheet выезжает снизу. Закрытие — по backdrop / Отмена / свайп вниз.
 */
.mm-sheet-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 1098;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.mm-sheet-backdrop[data-open="1"] {
    opacity: 1;
}
.mm-sheet-backdrop[hidden] {
    display: none;
}

/* Sheet прижат к левому краю, ограничен по ширине (max-width: 280px).
 * Поднят над капсулой mobile-nav через bottom: var(--mobile-nav-offset).
 * Структура: handle → заголовок → .mm-sheet-scroll (overflow:auto) → .mm-sheet-cancel (sticky).
 * Заголовки групп .mm-sheet-section-title в стиле .nav-section-title из app.css.
 * Цвета: тёмно-серый #1d1d1f (как .nav-item), без синего. Иконки наследуют через currentColor.
 */
.mm-sheet {
    position: fixed;
    left: 12px;
    right: auto;
    width: calc(100% - 24px);
    max-width: 280px;
    bottom: var(--mobile-nav-offset, 116px);
    background: rgba(248, 248, 250, 0.96);
    -webkit-backdrop-filter: saturate(180%) blur(30px);
    backdrop-filter: saturate(180%) blur(30px);
    border-radius: 18px;
    z-index: 1099;
    max-height: calc(85vh - var(--mobile-nav-offset, 116px));
    display: flex;
    flex-direction: column;
    transform: translateY(calc(100% + var(--mobile-nav-offset, 116px)));
    transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
    color: #1d1d1f;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
}
.mm-sheet[data-open="1"] {
    transform: translateY(0);
}
.mm-sheet[hidden] {
    display: none;
}

.mm-sheet-handle {
    flex-shrink: 0;
    width: 36px;
    height: 5px;
    background: rgba(60, 60, 67, 0.3);
    border-radius: 999px;
    margin: 8px auto 4px;
}
.mm-sheet-h {
    flex-shrink: 0;
    text-align: center;
    padding: 8px 0 12px;
    font-size: 17px;
    font-weight: 600;
    color: #1d1d1f;
    border-bottom: 0.5px solid rgba(60, 60, 67, 0.12);
}

/* Scroll-зона: только список разделов, Cancel вынесен наружу — всегда виден */
.mm-sheet-scroll {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 0 12px 4px;
}

/* Заголовок группы — стиль .nav-section-title из app.css:479 (десктоп) */
.mm-sheet-section {
    margin-top: 18px;
}
.mm-sheet-section:first-child {
    margin-top: 12px;
}
.mm-sheet-section-title {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: #8E8E93;
    padding: 0 16px 6px;
    margin: 0;
    opacity: 0.85;
}

.mm-sheet-group {
    background: #FFFFFF;
    border-radius: 14px;
    overflow: hidden;
}
.mm-sheet-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    border-bottom: 0.5px solid rgba(60, 60, 67, 0.06);
    font-size: 16px;
    cursor: pointer;
    min-height: 44px;
    color: #1d1d1f;
    text-decoration: none;
}
.mm-sheet-row:last-child {
    border-bottom: none;
}
/* SVG-иконки наследуют тёмно-серый через currentColor — никакого синего */
.mm-sheet-row svg.bi {
    width: 22px;
    height: 22px;
    color: #1d1d1f;
    flex-shrink: 0;
}
/* Активный пункт — тёмный + bold, БЕЗ синего фона/текста */
.mm-sheet-row.is-active {
    color: #1d1d1f;
    font-weight: 600;
}
.mm-sheet-row.is-active svg.bi {
    color: #1d1d1f;
}
.mm-sheet-row .label {
    flex: 1;
}

/* ====== ФУТЕР Action Sheet (клиент/админ) ======
 * Паритет с десктопным sidebar-footer: плитка тарифа + юзер-карта + Поддержка
 * + Install + Выйти. Скроллится вместе с группами модулей внутри .mm-sheet-scroll.
 */
.mm-footer {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid rgba(60,60,67,.10);
}
/* Плитка тарифа */
.mm-footer-plan {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 14px;
    border-radius: 12px;
    text-decoration: none;
    border: 1px solid transparent;
    margin: 0 12px 8px;
    min-height: 48px;
}
.mm-footer-plan .plan-tile__ai {
    font-size: 10px; font-weight: 700;
    background: #E53935; color: #fff;
    padding: 2px 6px; border-radius: 5px;
    letter-spacing: .3px;
    flex-shrink: 0;
}
.mm-footer-plan .plan-tile__name {
    flex: 1;
    font-size: 14px; font-weight: 700;
    letter-spacing: -.1px;
    color: inherit;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mm-footer-plan .plan-tile__meter {
    flex-shrink: 0;
    font-size: 14px; font-weight: 700;
    color: inherit;
}
.mm-footer-plan.plan-tile--trial   { background: #FDEBD0; border-color: rgba(217,119,6,.18); color: #92400e; }
.mm-footer-plan.plan-tile--bot     { background: linear-gradient(160deg,#f0fdf4,#d1fae5); border-color: rgba(52,199,89,.25); color: #15803d; }
.mm-footer-plan.plan-tile--ac      { background: linear-gradient(160deg,#fffbf0,#fef3c7); border-color: rgba(217,175,6,.4); color: #b45309; }
.mm-footer-plan.plan-tile--acl     { background: linear-gradient(160deg,#fff5f0,#ffe0cc); border-color: rgba(229,57,53,.3); color: #b91c1c; }
.mm-footer-plan.plan-tile--blocked { background: rgba(229,57,53,.08); border-color: rgba(229,57,53,.25); color: #b91c1c; }

/* Юзер-карта */
.mm-footer-user {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px;
    background: #FFFFFF;
    border-radius: 12px;
    text-decoration: none;
    color: #1d1d1f;
    margin: 0 12px 8px;
    min-height: 56px;
}
.mm-footer-user__avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #007AFF, #5856D6);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; font-weight: 700;
    flex-shrink: 0;
}
.mm-footer-user__box { flex: 1; min-width: 0; }
.mm-footer-user__name {
    font-size: 14px; font-weight: 600; line-height: 1.2;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mm-footer-user__email {
    font-size: 12px; color: #8E8E93; line-height: 1.3;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    margin-top: 2px;
}

/* Группа действий — Apple-style список */
.mm-footer-actions {
    background: #FFFFFF;
    border-radius: 12px;
    margin: 0 12px;
    overflow: hidden;
}
.mm-footer-action {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px;
    text-decoration: none;
    color: #1d1d1f;
    border-bottom: 1px solid rgba(60,60,67,.06);
    min-height: 44px;
    width: 100%;
    background: transparent;
    border-left: 0; border-right: 0; border-top: 0;
    font: inherit;
    cursor: pointer;
    text-align: left;
}
.mm-footer-action:last-child { border-bottom: 0; }
.mm-footer-action .ico {
    width: 28px; height: 28px;
    border-radius: 7px;
    background: rgba(0,122,255,.08);
    color: #007AFF;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.mm-footer-action .ico svg { width: 14px; height: 14px; }
.mm-footer-action .label { flex: 1; font-size: 15px; font-weight: 500; }
.mm-footer-action--logout .ico { background: rgba(229,57,53,.08); color: #E53935; }
.mm-footer-action--logout .label { color: #E53935; }

/* Cancel — flex-shrink:0, всегда виден, не уезжает в скролл */
.mm-sheet-cancel {
    flex-shrink: 0;
    background: #FFFFFF;
    border-radius: 14px;
    margin: 10px 12px;
    padding: 14px;
    text-align: center;
    font-size: 17px;
    font-weight: 600;
    color: #1d1d1f;
    cursor: pointer;
    border: 0;
    font-family: inherit;
}

/* ====== СКРЫТЬ КЛАССИЧЕСКИЙ САЙДБАР НА МОБИЛЬНОМ ======
 * Специфичность `body.has-mobile-nav .main-content` (0,2,0) перекрывает
 * `.main-content` (0,1,0) и `body.sidebar-collapsed .main-content` (0,2,0)
 * за счёт порядка загрузки (mobile-nav.css загружается после app.css).
 * Без !important — см. docs/BRANDBOOK.md и feedback_no_important.md.
 */
@media (max-width: 767px) {
    body.has-mobile-nav .sidebar,
    body.has-mobile-nav aside.sidebar {
        display: none;
    }
    body.has-mobile-nav .main-content {
        margin-left: 0;
        padding-bottom: var(--mobile-nav-offset);
    }
}
