/* Мобильная оптимизация для всех страниц */

/* Базовые стили для планшетов */
@media (max-width: 992px) {
    .container {
        max-width: 100%;
        padding-left: 20px;
        padding-right: 20px;
    }
}

/* Базовые стили для мобильных устройств */
@media (max-width: 768px) {
    /* Общие */
    body {
        font-size: 14px;
        overflow-x: hidden;
    }
    
    .container {
        padding-left: 15px;
        padding-right: 15px;
    }
    
    /* Заголовки */
    h1 {
        font-size: 1.75rem !important;
        line-height: 1.3;
    }
    
    h2 {
        font-size: 1.5rem !important;
        line-height: 1.3;
    }
    
    h3 {
        font-size: 1.25rem !important;
    }
    
    h4 {
        font-size: 1.1rem !important;
    }
    
    /* Кнопки */
    .btn {
        font-size: 0.9rem;
        padding: 0.65rem 1.2rem;
    }
    
    .btn-lg {
        font-size: 1rem;
        padding: 0.75rem 1.5rem;
    }
    
    /* Карточки */
    .card {
        margin-bottom: 1rem;
    }
    
    .card-body {
        padding: 1rem;
    }
    
    /* Таблицы */
    .table {
        font-size: 0.85rem;
    }
    
    .table th,
    .table td {
        padding: 0.5rem;
    }
    
    /* Навигация */
    .navbar-brand {
        font-size: 1.1rem;
    }
    
    .nav-link {
        font-size: 0.95rem;
        padding: 0.5rem 1rem;
    }
    
    .dropdown-menu {
        font-size: 0.9rem;
    }
    
    /* Формы */
    .form-control {
        font-size: 0.95rem;
        padding: 0.65rem 1rem;
    }
    
    .form-label {
        font-size: 0.9rem;
    }
    
    .input-group {
        flex-wrap: nowrap;
    }
    
    /* Отступы */
    .page-container {
        padding: 1rem 0;
    }
    
    .mb-4, .my-4 {
        margin-bottom: 1.5rem !important;
    }
    
    .mt-4, .my-4 {
        margin-top: 1.5rem !important;
    }
    
    .mb-5, .my-5 {
        margin-bottom: 2rem !important;
    }
    
    .mt-5, .my-5 {
        margin-top: 2rem !important;
    }
    
    /* Списки устройств */
    .device-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }
    
    .device-card {
        padding: 1rem;
    }
    
    .device-image {
        max-width: 100px;
        max-height: 100px;
    }
    
    /* Результаты поиска */
    .search-result-item {
        padding: 1rem;
    }
    
    .search-result-image {
        width: 60px;
        height: 60px;
    }
    
    /* Спецификации устройства */
    .spec-table {
        font-size: 0.85rem;
    }
    
    .spec-key {
        font-size: 0.85rem;
        padding: 0.5rem;
    }
    
    .spec-value {
        font-size: 0.85rem;
        padding: 0.5rem;
    }
    
    /* Модальные окна */
    .modal-dialog {
        margin: 0.5rem;
    }
    
    .modal-content {
        border-radius: 12px;
    }
    
    .modal-header {
        padding: 1rem;
    }
    
    .modal-body {
        padding: 1rem;
    }
    
    /* Алерты */
    .alert {
        font-size: 0.9rem;
        padding: 0.75rem 1rem;
    }
    
    /* Badge */
    .badge {
        font-size: 0.75rem;
        padding: 0.35rem 0.65rem;
    }
}

/* Очень маленькие экраны */
@media (max-width: 576px) {
    body {
        font-size: 13px;
    }
    
    .container {
        padding-left: 10px;
        padding-right: 10px;
    }
    
    h1 {
        font-size: 1.5rem !important;
    }
    
    h2 {
        font-size: 1.3rem !important;
    }
    
    h3 {
        font-size: 1.15rem !important;
    }
    
    .btn {
        font-size: 0.85rem;
        padding: 0.6rem 1rem;
    }
    
    .card-body {
        padding: 0.75rem;
    }
    
    .table {
        font-size: 0.8rem;
    }
    
    .table th,
    .table td {
        padding: 0.4rem;
    }
    
    /* Скрытие длинных текстов */
    .text-truncate-mobile {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

/* Ландшафтная ориентация на мобильных */
@media (max-width: 768px) and (orientation: landscape) {
    .hero-section {
        padding: 30px 20px;
    }
    
    .modal-dialog {
        max-width: 90%;
    }
}

/* Адаптация для touch устройств */
@media (hover: none) and (pointer: coarse) {
    /* Увеличиваем области клика */
    .btn {
        min-height: 44px;
        min-width: 44px;
    }
    
    .nav-link {
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    
    /* Убираем hover эффекты */
    .btn:hover,
    .nav-link:hover,
    .card:hover {
        transform: none;
    }
}

/* Скрытие элементов на мобильных */
.hide-mobile {
    display: none !important;
}

@media (min-width: 769px) {
    .hide-mobile {
        display: block !important;
    }
    
    .show-mobile {
        display: none !important;
    }
}

/* Дополнительные стили для страниц устройств и поиска */
@media (max-width: 768px) {
    /* Grid системы */
    .categories-grid,
    .devices-grid,
    .similar-devices-grid {
        grid-template-columns: 1fr !important;
    }
    
    /* Карточки */
    .category-card,
    .device-card,
    .similar-device-card {
        transition: background 0.2s ease;
    }
    
    .category-card:active,
    .device-card:active {
        background: rgba(102, 126, 234, 0.1);
    }
    
    /* Текст */
    .text-truncate {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    
    /* Длинные слова */
    .device-name,
    .category-name,
    .device-title,
    .page-title {
        word-break: break-word;
        hyphens: auto;
    }
}

/* Улучшение читаемости на маленьких экранах */
@media (max-width: 576px) {
    /* Увеличенная высота строк */
    p, li, td {
        line-height: 1.6;
    }
    
    /* Больше контраста */
    strong {
        font-weight: 600;
    }
}

