/**
 * Комплексная мобильная оптимизация
 * Улучшения для всех компонентов сайта на мобильных устройствах
 */

/* ==================== ОБЩИЕ УЛУЧШЕНИЯ ==================== */

@media (max-width: 768px) {
    /* Основные отступы */
    body {
        padding-top: 70px;
    }
    
    main {
        padding: 10px 5px !important;
    }
    
    .container {
        padding: 0 10px !important;
        max-width: 100% !important;
    }
    
    /* Улучшаем читаемость текста */
    h1 {
        font-size: 1.75rem !important;
        line-height: 1.3 !important;
        margin-bottom: 15px !important;
    }
    
    h2 {
        font-size: 1.5rem !important;
        line-height: 1.3 !important;
        margin-bottom: 12px !important;
    }
    
    h3 {
        font-size: 1.25rem !important;
        line-height: 1.3 !important;
        margin-bottom: 10px !important;
    }
    
    p {
        font-size: 15px !important;
        line-height: 1.6 !important;
    }
}

/* ==================== ТАБЛИЦЫ ==================== */

@media (max-width: 768px) {
    /* Делаем все таблицы скроллируемыми */
    .table-wrapper,
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        width: 100%;
        margin: 0 -10px;
        padding: 0 10px;
    }
    
    table {
        min-width: 600px;
        font-size: 14px;
    }
    
    table th,
    table td {
        padding: 8px 6px !important;
        font-size: 13px !important;
        white-space: nowrap;
    }
    
    /* Скрываем менее важные колонки на маленьких экранах */
    @media (max-width: 480px) {
        table th:nth-child(n+5),
        table td:nth-child(n+5) {
            display: none;
        }
    }
    
    /* Альтернативный вариант: карточки вместо таблиц */
    .table-card-view {
        display: none;
    }
}

/* Преобразование таблиц в карточки на очень маленьких экранах */
@media (max-width: 480px) {
    .table-card-view {
        display: block;
    }
    
    .table-card-view .table {
        display: none;
    }
    
    .table-card {
        background: white;
        border-radius: 8px;
        padding: 15px;
        margin-bottom: 15px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    }
    
    .table-card-row {
        display: flex;
        justify-content: space-between;
        padding: 8px 0;
        border-bottom: 1px solid #f0f0f0;
    }
    
    .table-card-row:last-child {
        border-bottom: none;
    }
    
    .table-card-label {
        font-weight: 600;
        color: #666;
        font-size: 12px;
        text-transform: uppercase;
        min-width: 100px;
    }
    
    .table-card-value {
        color: #333;
        font-size: 14px;
        text-align: right;
        flex: 1;
    }
}

/* ==================== ФОРМЫ ==================== */

@media (max-width: 768px) {
    /* Формы */
    form {
        width: 100%;
    }
    
    .form-group {
        margin-bottom: 20px;
    }
    
    .form-control,
    .form-select,
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    textarea,
    select {
        width: 100% !important;
        font-size: 16px !important; /* Предотвращает зум на iOS */
        padding: 12px 15px !important;
        border-radius: 8px !important;
        min-height: 44px !important; /* Минимальный touch-размер */
    }
    
    textarea {
        min-height: 120px !important;
        resize: vertical;
    }
    
    /* Кнопки в формах */
    .form-actions {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }
    
    .form-actions .btn {
        width: 100% !important;
        min-height: 48px !important;
        font-size: 16px !important;
        padding: 12px 20px !important;
    }
    
    /* Фильтры */
    .filter-form {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }
    
    .filter-group {
        width: 100% !important;
    }
}

/* ==================== КАРТОЧКИ ==================== */

@media (max-width: 768px) {
    .card {
        margin-bottom: 15px !important;
        border-radius: 12px !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    }
    
    .card-body {
        padding: 15px !important;
    }
    
    .card-title {
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
    }
    
    .card-text {
        font-size: 14px !important;
        line-height: 1.5 !important;
    }
    
    /* Сетки карточек */
    .card-grid,
    .row {
        display: flex;
        flex-direction: column;
        gap: 15px;
    }
    
    .col-md-4,
    .col-md-6,
    .col-md-3 {
        width: 100% !important;
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
}

/* ==================== КНОПКИ ==================== */

@media (max-width: 768px) {
    .btn {
        min-height: 44px !important;
        min-width: 44px !important;
        padding: 12px 20px !important;
        font-size: 15px !important;
        border-radius: 8px !important;
        touch-action: manipulation; /* Убирает задержку 300ms на iOS */
    }
    
    .btn-group {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 10px;
    }
    
    .btn-group .btn {
        width: 100%;
        margin: 0 !important;
    }
    
    /* Иконки в кнопках */
    .btn i {
        margin-right: 8px;
    }
}

/* ==================== МОДАЛЬНЫЕ ОКНА ==================== */

@media (max-width: 768px) {
    .modal-dialog {
        margin: 10px !important;
        max-width: calc(100% - 20px) !important;
    }
    
    .modal-content {
        border-radius: 12px !important;
        max-height: calc(100vh - 20px);
        overflow-y: auto;
    }
    
    .modal-header {
        padding: 15px !important;
        border-bottom: 1px solid #e0e0e0;
    }
    
    .modal-title {
        font-size: 1.25rem !important;
    }
    
    .modal-body {
        padding: 15px !important;
        font-size: 15px !important;
    }
    
    .modal-footer {
        padding: 15px !important;
        flex-direction: column-reverse;
        gap: 10px;
    }
    
    .modal-footer .btn {
        width: 100%;
        margin: 0 !important;
    }
}

/* ==================== ИЗОБРАЖЕНИЯ ==================== */

@media (max-width: 768px) {
    img {
        max-width: 100% !important;
        height: auto !important;
        border-radius: 8px;
    }
    
    .hero-image,
    .cover-image {
        height: 200px !important;
        object-fit: cover;
    }
    
    /* Галереи изображений */
    .image-gallery {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
    
    .image-gallery img {
        width: 100%;
        height: 150px;
        object-fit: cover;
    }
}

/* ==================== НАВИГАЦИЯ ==================== */
@media (max-width: 992px) {
    /* ==================== ГАМБУРГЕР-МЕНЮ ДЛЯ МОБИЛЬНЫХ ==================== */
    
    /* Кнопка гамбургер в header */
    .mobile-menu-toggle {
        display: flex !important;
        flex-direction: column !important;
        justify-content: space-around !important;
        width: 44px !important;
        height: 44px !important;
        background: transparent !important;
        border: none !important;
        cursor: pointer !important;
        padding: 10px 8px !important;
        z-index: 1001 !important;
        order: 0 !important;
        margin-right: 10px !important;
    }
    
    .hamburger-line {
        width: 100% !important;
        height: 3px !important;
        background: #fff !important;
        border-radius: 2px !important;
        transition: all 0.3s ease !important;
        transform-origin: center !important;
    }
    
    /* Анимация гамбургера при открытии */
    .mobile-menu-toggle.active .hamburger-line:nth-child(1) {
        transform: rotate(45deg) translate(8px, 8px) !important;
    }
    
    .mobile-menu-toggle.active .hamburger-line:nth-child(2) {
        opacity: 0 !important;
    }
    
    .mobile-menu-toggle.active .hamburger-line:nth-child(3) {
        transform: rotate(-45deg) translate(8px, -8px) !important;
    }
    
    /* Overlay (затемнение фона). Когда меню закрыто — не перехватывать клики (тапы по выпадающим спискам и т.д.) */
    .mobile-menu-overlay {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: rgba(0, 0, 0, 0.5) !important;
        z-index: 9998 !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transition: opacity 0.3s ease, visibility 0.3s ease !important;
    }
    
    .mobile-menu-overlay.active {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }
    
    /* Боковое меню: контент прокручивается */
    .mobile-menu {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: 280px !important;
        max-width: 85% !important;
        max-height: 100vh !important;
        max-height: 100dvh !important;
        background: linear-gradient(135deg, #000000, #1a0000, #d10000) !important;
        z-index: 9999 !important;
        transform: translateX(-100%) !important;
        transition: transform 0.3s ease-in-out !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
        box-shadow: 2px 0 20px rgba(0,0,0,0.5) !important;
    }
    
    .mobile-menu.active {
        transform: translateX(0) !important;
    }
    
    /* Заголовок меню (не скроллится) */
    .mobile-menu-header {
        flex-shrink: 0 !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 20px 20px 15px 20px !important;
        border-bottom: 1px solid rgba(255,255,255,0.1) !important;
        background: rgba(0,0,0,0.3) !important;
    }
    
    .mobile-menu-header h2 {
        color: #fff !important;
        font-size: 20px !important;
        font-weight: 600 !important;
        margin: 0 !important;
    }
    
    .mobile-menu-close {
        width: 44px !important;
        height: 44px !important;
        background: transparent !important;
        border: none !important;
        color: #fff !important;
        font-size: 24px !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 8px !important;
        transition: background 0.2s ease !important;
    }
    
    .mobile-menu-close:active {
        background: rgba(255,255,255,0.1) !important;
    }
    
    /* Блок пользователя вверху меню — как обычный пункт */
    .mobile-menu-user-block {
        display: flex !important;
        align-items: center !important;
        padding: 15px 20px !important;
        color: rgba(255,255,255,0.9) !important;
        text-decoration: none !important;
        transition: all 0.2s ease !important;
        border-bottom: 1px solid rgba(255,255,255,0.05) !important;
        min-height: 44px !important;
    }
    .mobile-menu-user-block:active {
        background: rgba(255,255,255,0.1) !important;
        color: #fff !important;
    }
    .mobile-menu-user-avatar {
        width: 28px !important;
        height: 28px !important;
        border-radius: 50% !important;
        overflow: hidden !important;
        flex-shrink: 0 !important;
        background: rgba(255,255,255,0.15) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin-right: 15px !important;
    }
    .mobile-menu-user-avatar img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        border-radius: 50% !important;
    }
    .mobile-menu-user-initials {
        font-size: 11px !important;
        font-weight: 600 !important;
        color: #fff !important;
        text-transform: uppercase !important;
    }
    .mobile-menu-user-name {
        flex: 1 !important;
        min-width: 0 !important;
        font-size: 16px !important;
        font-weight: 500 !important;
        color: rgba(255,255,255,0.9) !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    .mobile-menu-user-arrow {
        font-size: 12px !important;
        color: rgba(255,255,255,0.3) !important;
        flex-shrink: 0 !important;
        margin-left: 8px !important;
    }
    /* Кнопка входа — как обычный пункт меню */
    .mobile-menu-login-btn {
        display: flex !important;
        align-items: center !important;
        padding: 15px 20px !important;
        color: rgba(255,255,255,0.9) !important;
        text-decoration: none !important;
        transition: all 0.2s ease !important;
        border-bottom: 1px solid rgba(255,255,255,0.05) !important;
        min-height: 44px !important;
        background: transparent !important;
        border-radius: 0 !important;
        margin: 0 !important;
    }
    .mobile-menu-login-btn:active {
        background: rgba(255,255,255,0.1) !important;
        color: #fff !important;
    }
    .mobile-menu-login-btn i {
        font-size: 20px !important;
        margin-right: 15px !important;
        width: 24px !important;
        text-align: center !important;
    }
    .mobile-menu-login-btn span {
        font-size: 16px !important;
        font-weight: 500 !important;
    }
    
    /* Контент меню — прокручиваемая область */
    .mobile-menu-content {
        flex: 1 !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 10px 0 20px 0 !important;
    }
    
    .mobile-menu-item {
        display: flex !important;
        align-items: center !important;
        padding: 15px 20px !important;
        color: rgba(255,255,255,0.9) !important;
        text-decoration: none !important;
        transition: all 0.2s ease !important;
        border-bottom: 1px solid rgba(255,255,255,0.05) !important;
        min-height: 44px !important; /* Touch target */
    }
    
    .mobile-menu-item i {
        font-size: 20px !important;
        margin-right: 15px !important;
        width: 24px !important;
        text-align: center !important;
    }
    
    .mobile-menu-item span {
        font-size: 16px !important;
        font-weight: 500 !important;
    }
    
    /* Круглый бейдж количества уведомлений в бургер-меню */
    .mobile-menu-notif-badge {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 22px !important;
        min-height: 22px !important;
        padding: 0 2px !important;
        margin-left: 8px !important;
        flex-shrink: 0 !important;
        background: #dc3545 !important;
        color: white !important;
        border-radius: 50% !important;
        font-size: 0.75rem !important;
        font-weight: 600 !important;
        line-height: 1 !important;
    }
    
    .mobile-menu-item:active {
        background: rgba(255,255,255,0.1) !important;
        color: #fff !important;
    }
    
    .mobile-menu-divider {
        height: 1px !important;
        background: rgba(255,255,255,0.1) !important;
        margin: 10px 20px !important;
    }
    
    /* Убираем отступ снизу для контента (нижняя навигация удалена) */
    main {
        padding-bottom: 20px !important;
    }
    
    /* Скрываем десктопную навигацию */
    .nav-menu {
        display: none !important;
    }
    
    /* Показываем компактный переключатель языка - только флаг */
    /* ВАЖНО: Стили для .language-switcher .current-language перенесены в mobile-fixes-final.css */
    /* чтобы избежать конфликтов - border-radius задается там */
    .language-switcher {
        display: flex !important;
        margin-left: 8px !important;
        flex-shrink: 0 !important;
    }
    
    /* УДАЛЕНО: все стили для .current-language перенесены в mobile-fixes-final.css */
    /* чтобы избежать конфликтов border-radius и других свойств */
    
    .language-switcher .current-language .name {
        display: none !important; /* Скрываем текст */
    }
    
    .language-switcher .current-language .flag {
        display: none !important; /* Скрываем флаг на мобильных */
    }
    
    .language-switcher .current-language i.fa-globe,
    .language-switcher .current-language .fa-chevron-down {
        display: none !important; /* Скрываем иконки */
    }
    
    /* Скрываем кнопки Вход/Регистрация */
    .header .nav-link {
        display: none !important;
    }
    
    /* Упрощенный header на мобильных */
    .header {
        padding: 10px !important;
        justify-content: space-between !important;
    }
    
    /* Логотип компактнее */
    .logo .highlight-w {
        font-size: 28px !important;
    }
}

/* На десктопе скрываем мобильное меню и гамбургер */
@media (min-width: 993px) {
    .mobile-menu-toggle {
        display: none !important;
    }
    
    .mobile-menu,
    .mobile-menu-overlay {
        display: none !important;
    }
}

/* ==================== СПИСКИ ==================== */

@media (max-width: 768px) {
    .list-group-item {
        padding: 12px 15px !important;
        font-size: 15px !important;
        border-radius: 8px !important;
        margin-bottom: 8px !important;
    }
    
    /* Вертикальные списки */
    ul, ol {
        padding-left: 20px;
    }
    
    li {
        margin-bottom: 8px;
        line-height: 1.6;
    }
}

/* ==================== АЛЕРТЫ И УВЕДОМЛЕНИЯ ==================== */

@media (max-width: 768px) {
    .alert {
        padding: 12px 15px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
        margin-bottom: 15px !important;
    }
    
    .alert-dismissible {
        padding-right: 40px !important;
    }
    
    .alert-dismissible .btn-close {
        padding: 12px !important;
        font-size: 18px !important;
    }
}

/* ==================== ДРОПДАУНЫ ==================== */

@media (max-width: 768px) {
    .dropdown-menu {
        max-width: calc(100vw - 20px);
        left: 10px !important;
        right: 10px !important;
        transform: none !important;
        border-radius: 12px !important;
    }
    
    .dropdown-item {
        padding: 12px 20px !important;
        font-size: 15px !important;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    
    .dropdown-item i {
        margin-right: 10px;
        width: 20px;
    }
}

/* ==================== ЗАГРУЗОЧНЫЕ ИНДИКАТОРЫ ==================== */

@media (max-width: 768px) {
    .spinner-border,
    .spinner-grow {
        width: 30px !important;
        height: 30px !important;
    }
    
    .loading-text {
        font-size: 14px !important;
        margin-top: 10px;
    }
    
    /* Один спиннер на кнопке: убираем левый (form-loading-spinner), оставляем центральный (::after) */
    .btn-loading .form-loading-spinner {
        display: none !important;
    }
}

/* ==================== ПОИСК ==================== */

@media (max-width: 768px) {
    .search-results {
        max-height: 400px !important;
        border-radius: 8px !important;
    }
    
    .search-result-item {
        padding: 12px !important;
    }
    
    .search-result-icon {
        width: 35px !important;
        height: 35px !important;
    }
}

/* ==================== СТАТИСТИКА И ДАШБОРДЫ ==================== */

@media (max-width: 768px) {
    .stats-row,
    .stats-grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    
    .stat-box,
    .stat-card {
        padding: 15px !important;
        text-align: center;
    }
    
    .stat-number {
        font-size: 1.75rem !important;
    }
    
    .stat-label {
        font-size: 12px !important;
    }
    
    @media (max-width: 480px) {
        .stats-row,
        .stats-grid {
            grid-template-columns: 1fr !important;
        }
    }
}

/* ==================== ТАБЫ ==================== */

@media (max-width: 768px) {
    .nav-tabs {
        flex-wrap: wrap;
        border-bottom: 2px solid #dee2e6;
    }
    
    .nav-tabs .nav-link {
        padding: 10px 15px !important;
        font-size: 14px !important;
        min-height: 44px;
        border-radius: 8px 8px 0 0;
    }
    
    .tab-content {
        padding: 15px 0;
    }
}

/* ==================== УТИЛИТЫ ==================== */

@media (max-width: 768px) {
    /* Скрываем десктопные элементы */
    .desktop-only {
        display: none !important;
    }
    
    /* Показываем мобильные элементы */
    .mobile-only {
        display: block !important;
    }
    
    /* Убираем лишние отступы */
    .mt-5 {
        margin-top: 2rem !important;
    }
    
    .mb-5 {
        margin-bottom: 2rem !important;
    }
    
    .py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
}

/* ==================== ИСПРАВЛЕНИЕ ПРОБЛЕМ С ЗУМОМ НА IOS ==================== */

@media (max-width: 768px) {
    /* Убираем зум при фокусе на input */
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    input[type="tel"],
    input[type="url"],
    input[type="search"],
    select,
    textarea {
        font-size: 16px !important;
    }
}

/* ==================== УЛУЧШЕНИЕ ПРОИЗВОДИТЕЛЬНОСТИ ==================== */

@media (max-width: 768px) {
    /* GPU-ускорение — не применяем к полям ввода, чтобы на iOS работали длинное нажатие и «Вставить» */
    *:not(input):not(textarea):not(select) {
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
    }
    
    /* Улучшаем скроллинг */
    * {
        -webkit-overflow-scrolling: touch;
    }
    
    /* Оптимизация рендеринга */
    .card,
    .btn,
    .modal-content {
        will-change: transform;
    }
}

/* ==================== ПОДДЕРЖКА SAFE AREA (iPhone X и новее) ==================== */

@supports (padding: max(0px)) {
    .mobile-nav {
        padding-bottom: max(8px, env(safe-area-inset-bottom));
    }
    
    body {
        padding-top: max(70px, env(safe-area-inset-top));
    }
}

