/* 1. ПОДКЛЮЧЕНИЕ ШРИФТОВ */
/* Regular (400) */
@font-face { 
    font-family: 'Oswald'; 
    src: url('../fonts/regular.woff2') format('woff2'),
         url('../fonts/regular.ttf') format('truetype'); 
    font-weight: 400; 
    font-style: normal;
    font-display: swap; /* Чтобы текст не пропадал при загрузке */
}

/* Semi-Bold (600) */
@font-face { 
    font-family: 'Oswald'; 
    src: url('../fonts/600.woff2') format('woff2'),
         url('../fonts/600.ttf') format('truetype'); 
    font-weight: 600; 
    font-style: normal;
    font-display: swap;
}

/* Light (300) */
@font-face { 
    font-family: 'Oswald'; 
    src: url('../fonts/300.woff2') format('woff2'),
         url('../fonts/300.ttf') format('truetype'); 
    font-weight: 300; 
    font-style: normal;
    font-display: swap;
}

/* 2. БАЗОВЫЕ НАСТРОЙКИ */
html {
    /* Фикс прыжка контента в 6пкс при появлении скролла */
    overflow-y: scroll; 
}

* { 
    margin: 0; 
    padding: 0; 
    box-sizing: border-box; 
}

body { 
    font-family: 'Oswald', sans-serif; 
    color: #333; 
    line-height: 1.2; 
    /* Фоновый цвет для мобилок, где картинка не грузится */
    background-color: #f4f4f4; 
}

/* --- ТОНКАЯ СЕРАЯ ЛИНИЯ HR --- */
hr {
    border: none;
    height: 1px;
    background-color: #e0e0e0;
    margin: 20px 0;
}

/* ФОН ТОЛЬКО ДЛЯ ДЕСКТОПА (Физически не грузится на мобильных) */
@media (min-width: 1001px) {
    body {
        background-image: url('../images/design/fon.webp'); 
        background-repeat: repeat-y; 
        background-size: 1920px auto; 
        background-position: center top;
        background-attachment: fixed; /* Паралакс включается скриптом */
        background-color: #fff;
        image-rendering: -webkit-optimize-contrast;
    }
}

/* --- ХЛЕБНЫЕ КРОШКИ --- */
.breadcrumbs {
    margin-top: 10px; 
    margin-bottom: 15px;
    padding-bottom: 8px;
    border-bottom: 1px solid #f0f0f0;
    font-size: 13px;
    color: #aaa;
    font-family: Arial, sans-serif;
}

/* Поднимаем крошки выше на больших экранах */
@media (min-width: 1001px) {
    .breadcrumbs {
        margin-top: -15px; 
    }
}

/* --- ГЛОБАЛЬНЫЕ СТИЛИ ЗАГОЛОВКОВ --- */
h1, h2, h3 {
    font-family: 'Oswald', sans-serif;
    font-weight: 300; /* Тонкое начертание */
    color: var(--main-color) !important;
    margin-bottom: 15px;
    line-height: 1.2;
}

h1 { 
    font-size: 36px; 
    border-bottom: 1px solid #eee; 
    padding-bottom: 5px; 
}


h2 { 
    font-size: 30px; 
    border-bottom: 1px solid #f4f4f4; 
    padding-bottom: 5px;
    margin-top: 30px; 
}

h3 { 
    font-size: 24px;
	border-bottom: 1px solid #f4f4f4; 
	padding-bottom: 10px;	
    margin-top: 25px; 
}

/* ГЛАВНЫЙ КОНТЕЙНЕР (Строго 1200px для ПК) */
.container { 
    width: 1200px !important; 
    margin: 0 auto; 
    padding: 0 15px;
}

/* 3. ШАПКА — теперь фон только здесь */
.main-header { 
    padding: 20px 0; 
	background-color: #46428e !important; /* Меняем фон */
    /*background-image: url('../images/design/fon-header.webp');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;*/
    width: 100%;
    display: block;
    border-bottom: 1px solid #eee; /* Тонкая линия, чтобы отделить от меню */
}

.header-row { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
}

.logo img { 
    height: 70px; 
    display: block; 
}
/* Анимация света по логотипу
@media (min-width: 1001px) {
    .logo-shine {
        position: relative;
        display: inline-block;
        overflow: hidden;
        vertical-align: middle;
    }

    .logo-shine::after {
        content: "";
        position: absolute;
        top: 0;
        left: -200%; 
        width: 250px; 
        height: 100%;
        background: linear-gradient(
            to right, 
            rgba(255,255,255,0) 0%, 
            rgba(255,255,255,0.6) 50%, 
            rgba(255,255,255,0) 100%
        );
        transform: skewX(-25deg);        
        
        animation: shine-once 6s ease-in-out forwards;        
        
        animation-delay: 0s; 
    }

    @keyframes shine-once {
        0% { left: -200%; }
        100% { left: 200%; }
    }
}
*/

.header-contacts { 
    display: flex; 
    flex-direction: column; 
    gap: 5px; 
    align-items: flex-start;
}

.c-item { 
    display: flex; 
    align-items: center; 
    gap: 10px; 
    font-size: 20px; 
}

.c-item img { 
    width: 28px; 
    height: 28px; 
}

/* Контакты: белый цвет для синей шапки */
.c-item a { 
    text-decoration: none !important; 
    color: #fff !important; 
    font-weight: 600; 
}

/* МЕНЮ */
#topMenu { 
    width: 100%;
    background-color: #f4f4f4 !important; /* Тот самый серый цвет меню */
    position: relative; 
    z-index: 10; /* Поднимаем над фоном шапки */
    box-shadow: 0 2px 5px rgba(0,0,0,0.05); /* Легкая тень для объема */
}

/* 4. ОСНОВНОЙ БЛОК КОНТЕНТА */
main.container { 
    padding: 40px 30px; 
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    /* Острый верх, скругленный низ */
    border-radius: 0 0 20px 20px; 
    margin-bottom: 15px; 
}

/* --- ПРЕВЬЮ --- */


/* --- КАРТОЧКИ --- */
.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 30px;
    margin: 40px 0;
}

.card-item {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 0 0 8px 8px; 
    overflow: hidden;
    text-decoration: none;
    color: #333;
    transition: transform 0.4s ease, box-shadow 0.4s ease; 
    display: flex;
    flex-direction: column;
}

.card-item:hover {
    transform: translateY(-2px); 
    box-shadow: 0 6px 15px rgba(0,0,0,0.07); 
}

/* Контейнер картинки должен обрезать всё, что выходит за его пределы */
.card-image { 
    height: 285px; 
    overflow: hidden; /* КРИТИЧНО: чтобы картинка не вылезала при увеличении */
}

/* Сама картинка внутри карточки */
.card-image img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    transition: transform 0.6s ease; /* Плавность анимации */
}

/* Эффект при наведении на ВСЮ карточку */
.card-item:hover .card-image img {
    transform: scale(1.1); /* Увеличение на 10% */
}

.card-info { padding: 20px; }
.card-info h3 {
    font-weight: 300; font-size: 26px; margin: 0 0 15px 0; color: #000;
    position: relative; padding-bottom: 10px;
	line-height: 1.35 !important;
}
.card-info h3::after {
    content: ''; position: absolute; left: 0; bottom: -2px; width: 0; height: 1px;
    background: #d1d1d1; transition: width 0.4s ease;
}
.card-item:hover .card-info h3::after { width: 100%; }

/* --- КАРТОЧКА ТОВАРА: ИТОГОВЫЙ ВАРИАНТ --- */

/* Контейнер карточки */
.card-item.product-card {
    display: flex;
    flex-direction: column;
    text-align: center;
    border-radius: 20px;
    border: 1px solid #f0f0f0;
    padding: 0;           /* Убираем внутренние отступы, чтобы фото прилегало к краям */
    background: #fff;
    overflow: hidden;    /* Важно для скругления углов картинки */
    transition: 0.3s;
    height: 100%;
}

.card-item.product-card:hover {
    box-shadow: 0 10px 25px rgba(0,0,0,0.07);
    transform: translateY(-3px);
}

/* Квадратная область для картинки */
.card-item.product-card .card-image {
    width: 100%;
    aspect-ratio: 1 / 1; /* Жесткий квадрат 1:1 */
    height: auto;
    margin: 0;
    padding: 0;
    background: #fff;
    display: block;
}

/* Сама картинка: заполняет весь квадрат без полей */
.card-item.product-card .card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;   /* Растягивает фото на весь квадрат без дырок по бокам */
    display: block;
}

/* Блок с текстом под картинкой */
.card-item.product-card .card-info {
    padding: 15px 15px 20px 15px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    /* justify-content: space-between заставит нижний блок всегда быть внизу */
    justify-content: space-between !important; 
}

/* Название: шрифт Oswald 300, как в h1/h3 страниц */
.card-item.product-card .card-info h3 {
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    font-size: 24px;
    color: #333;
    margin: 0 0 10px 0;
    padding: 0 0 10px 0; /* Добавили отступ снизу для линии */
    line-height: 1.1;
    display: inline-block; /* Чтобы линия была по ширине текста */
    position: relative;    /* Чтобы линия привязалась к заголовку */
}

/* Создаем анимированную линию */
.card-item.product-card .card-info h3::after {
    content: ''; 
    position: absolute; 
    left: 0; 
    bottom: -2px; 
    width: 0; 
    height: 1px;
    background: #d1d1d1; 
    transition: width 0.4s ease; /* Плавное появление */
}

/* Анимация: при наведении на всю карточку линия удлиняется */
.card-item.product-card:hover .card-info h3::after { 
    width: 100%; 
}

.card-desc {
    font-family: 'Oswald', sans-serif; /* Тот же шрифт, что на всем сайте */
    font-weight: 300;                  /* Тонкое начертание */
    font-size: 20px;                   /* Размер текста */
    color: #444;                       /* Темно-серый цвет */
    line-height: 1.4;
    margin-top: 10px;
    text-align: left;                  /* Выравнивание по левому краю */
}

/* Цена на карточке */
.product-price {
    font-family: 'Oswald', sans-serif;
    color: #4d534c;
    font-size: 28px;
    font-weight: 500;
    margin: 0;
}

.product-price span {
    font-size: 18px;
    font-weight: 300;
    color: #4d534c;
}

/* На ПК: Цена слева, Кнопка строго справа внизу */
.price-buy-row {
    display: flex !important;
    justify-content: space-between !important; 
    align-items: flex-end !important;
    width: 100% !important;
    margin-top: auto !important;
    padding-top: 15px;
}

/* Эта магия прижмет кнопку вправо, даже если цены нет */
.price-buy-row .buy-btn {
    margin-left: auto !important; 
    width: auto !important;
    min-width: 130px !important;
    padding: 8px 15px !important;
}

/* --- КАРТОЧКА ТОВАРА (ВНУТРЕННЯЯ СТРАНИЦА) --- */
.product-card-top {
    display: flex;          /* Включаем колонки */
    gap: 40px;             /* Расстояние между фото и текстом */
    margin-bottom: 30px;
    align-items: flex-start; /* Выравнивание по верху */
}

/* Левая колонка с фото — Настройки для ПК */
.product-card-image {
    flex: 0 0 450px !important; /* Возвращаем твои 450px для десктопа */
    max-width: 100%;
}

/* Убираем отступ у фото, так как оно теперь в колонке */
.product-card-image .main-featured-image {
    margin-bottom: 0 !important;
}

/* Правая колонка с инфо */
.product-card-info {
    flex: 1;               /* Занимает остаток ширины */
    display: flex;
    flex-direction: column;
}

/* 1. Возвращаем линию заголовку h1 в карточке */
.product-card-info h1 {
    border-bottom: 1px solid #eee !important; /* Линия под заголовком */
    padding-bottom: 10px;
    margin-bottom: 15px;
    font-size: 32px;
}

/* 2. Настраиваем описание (убираем у него нижнюю линию, чтобы не двоилось) */
.product-short-desc {
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    font-size: 20px;
    color: #333;
    line-height: 1.4;
    margin-bottom: 20px;
    border-bottom: none; /* Убрали снизу */
}

/* Надпись "Цена:" — серая, тонкая, как обычный текст */
.product-main-price .price-label {
    font-family: 'Oswald', sans-serif;
    font-weight: 300;         /* Нежирный */
    font-size: 20px;          /* Размер как у текста на странице */
    color: #888;              /* Серый цвет */
    margin-right: 10px;       /* Отступ от цифр */
    text-transform: none;     /* Отмена заглавных, если были */
    display: inline-block;
    vertical-align: middle;
}

/* Цена на самой странице товара */
.product-main-price {
    font-family: 'Oswald', sans-serif;
    font-size: 30px;
    color: #4d534c;
    font-weight: 600;
    border-top: 1px solid #eee; /* Линия НАД ценой */
    padding-top: 15px;
    margin-top: 10px;
}


/* --- Стили блока "Вам может быть интересно" --- */
.related-section {
    margin-top: 10px !important;    /* УБРАЛИ ДЫРУ НАД ЛИНИЕЙ (было 60px) */
    padding-top: 15px !important;   /* УМЕНЬШИЛИ ОТСТУП ПОД ЛИНИЕЙ (было 30px) */
    border-top: 1px solid #eee;
    clear: both; /* На всякий случай, чтобы текст не обтекал блок */
}

.related-title {
    font-family: 'Oswald', sans-serif;
    font-size: 24px;
    font-weight: 300; /* Как у <p> в .entry */
    margin-bottom: 20px;
    text-transform: none; /* Убираем капс, чтобы было как в тексте */
    color: #333;
    line-height: 1.4;
    border-bottom: 1px solid #eee;
    padding-bottom: 10px;
    
    /* Жесткий сброс для мобилок */
    white-space: normal !important; 
    display: block !important;
    overflow: visible !important;
    width: 100% !important;
}

/* Контейнер для скролла (как в хлебных крошках) */
.related-scroll-container {
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none; /* Скрываем скроллбар в Firefox */
    -webkit-overflow-scrolling: touch;
    padding-bottom: 10px;
}

@media (max-width: 768px) {
    .related-scroll-container {
        /* Принудительно расширяем контейнер за пределы экрана */
        margin-left: -10px !important;  
        margin-right: -10px !important; 
        padding-left: 10px !important;  
        padding-right: 15px !important; 
        
        /* КРИТИЧНО: ширина должна быть больше 100%, чтобы "прилипнуть" */
        width: calc(100% + 20px) !important; 
        max-width: none !important; 
        box-sizing: border-box !important;
    }
}

.related-scroll-container::-webkit-scrollbar {
    display: none; /* Скрываем скроллбар в Chrome/Safari */
}

.related-grid {
    display: flex;
    gap: 20px;
    min-width: max-content; /* Чтобы карточки не сжимались, а уходили за экран */
}

.related-card {
    width: 220px;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border: 1px solid #f0f0f0;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

.related-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}

.related-card-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: #fff; /* Меняем серый фон на белый */
}

.related-card-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Фото будет заполнять весь квадрат без серых дырок */
    padding: 0;        /* Удаляем внутренний отступ */
}

.related-card-info {
    padding: 15px 10px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    /* Выравниваем содержимое: заголовок вверху, цена внизу */
    justify-content: space-between !important;
}

.related-card-info h3 {
    font-size: 20px;
    line-height: 1.4 !important;
    margin: 0 0 auto 0 !important; /* Отталкивает цену вниз */
    font-weight: 300;
    font-family: 'Oswald', sans-serif;
    display: block !important;
    white-space: normal !important; 
    overflow: visible !important;
    height: auto !important; 
    min-height: auto !important; 
    border-bottom: none !important; 
    padding-bottom: 0;
}

/* Добавляем линию ТОЛЬКО если в карточке есть цена */
.related-card-info:has(.related-card-price) h3 {
    border-bottom: 1px solid #eee !important;
    padding-bottom: 8px !important; /* Уменьшили отступ над линией */
    margin-bottom: 5px !important;  /* Уменьшили пустоту ПОД линией */
}

.related-card-price {
    margin-top: 5px !important;     
    font-weight: 600;
    font-size: 25px !important; /* УВЕЛИЧИЛИ: теперь как заголовок над ней */
    color: #333;
}

.related-card-price span {
    font-size: 15px !important; /* Чуть увеличили "руб." для баланса */
    font-weight: normal;
    color: #888;
}

/* Кнопки навигации ленты */
.rel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    transition: all 0.2s ease;
    opacity: 0; /* Скрыты по умолчанию */
}

/* Показываем стрелки при наведении на всю секцию */
.related-section-wrapper:hover .rel-nav {
    opacity: 1;
}

.rel-nav:hover {
    background: var(--main-color);
    color: #fff;
    border-color: var(--main-color);
}

.rel-prev { left: -20px; }
.rel-next { right: -20px; }

/* На мобилках стрелки не нужны */
@media (max-width: 1000px) {
    .rel-nav { display: none !important; }
    .related-scroll-container { padding: 0 10px; }
    .rel-prev { left: 0; }
    .rel-next { right: 0; }
}

/* Кнопка прокрутки экрана вверх */
#scrollToTop {
    display: flex;
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 999;
    width: 50px;
    height: 50px;
    background-color: #ffffff;
    color: var(--main-color);
    border: 1px solid #eee;
    border-radius: 50%;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    font-size: 26px; /* Чуть увеличили для наглядности */
    
    /* ИСПРАВЛЕНИЕ ЦЕНТРА: */
    padding-bottom: 4px !important; 
    
    transform: rotate(90deg) scale(0);
    transition: transform 0.3s ease-in-out, opacity 0.3s, background-color 0.2s;
    opacity: 0;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* Состояние, когда кнопка должна появиться (добавляется скриптом) */
#scrollToTop.visible {
    transform: rotate(90deg) scale(1) !important;
    opacity: 1 !important;
}

#scrollToTop:hover {
    /* Светло-серый фон вместо темного */
    background-color: #fcfcfc !important; 
    /* Делаем майн-цвет стрелки визуально светлее через прозрачность */
    color: var(--main-color) !important;
    opacity: 0.8 !important;
    border-color: #ddd !important;
    box-shadow: 0 6px 16px rgba(0,0,0,0.1);
}

@media (max-width: 768px) {
    #scrollToTop {
        bottom: 20px;
        right: 20px;
        width: 45px;
        height: 45px;
    }
}


/* На мобильных уменьшаем ширину карточек в рекомендациях */
@media (max-width: 600px) {
    /* Рассчитываем ширину так, чтобы в экран входило 2 полных и кусочек третьей */
    .related-card {
        width: calc((100vw - 45px) / 2.3) !important; 
        min-width: 140px !important;
        flex-shrink: 0 !important;
    }

    /* Уменьшаем зазор между ними */
    .related-grid {
        gap: 15px !important;
    }
	.related-card-info h3 {
        font-size: 17px !important; /* Уменьшили с 20px до 17px для мобильных */
        line-height: 1.2 !important;
        white-space: normal !important; /* Гарантируем перенос строк */
        margin-bottom: 8px !important;
    }
	/* ВОЗВРАЩАЕМ ЦЕНУ В 17px ТОЛЬКО ДЛЯ МОБИЛЬНЫХ */
    .related-card-price {
        font-size: 18px !important;
        margin-top: 2px !important;
    }
    
    .related-card-price span {
        font-size: 13px !important; /* Уменьшаем "руб." обратно */
    }
}

/* Адаптивность для мобильных */
@media (max-width: 900px) {
    .product-card-top {
        flex-direction: column; 
        gap: 0 !important; /* Убираем gap, который создавал дыру между фото и текстом */
    }
    .product-card-image {
        flex: none !important;
        width: 100% !important;
        margin-bottom: 0 !important; /* Убираем отступ снизу у контейнера фото */
    }
}

/* 5. ФУТЕР */
footer { 
    width: 100%;
    background: transparent; 
    padding: 30px 0; /* Увеличили отступ, чтобы тексту было просторно */
    text-align: center; 
    clear: both;
    position: relative;
    z-index: 10;
}

footer p { 
    font-family: 'Oswald', sans-serif; /* Тот же шрифт, что и на сайте */
    font-weight: 200;                  /* Легкое начертание */
    color: #999;                       /* Приятный серый цвет */
    font-size: 20px;                   /* Размер как у основного шрифта сайта */
    margin: 0;
}

/* ТЕКСТ */

/* Полная зачистка рамки, фона и тени для главной картинки в статьях */
.no-border-style .main-featured-image,
.no-border-style .main-featured-image img,
.no-border-style [class*="featured-image"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 auto !important;
    background: none !important;
    border-radius: 0 !important;
}

/* Единый стиль контента */
.entry { 
    font-weight: 300; 
    font-size: 20px; 
    text-align: left !important; 
    color: #333; 
    /* Устанавливаем 1.4 — это даст ту самую легкость, как в списках */
    line-height: 1.4 !important; 
    hyphens: auto;
}
/* Делаем все картинки в тексте адаптивными */
.entry img {
    max-width: 100% !important; 
    height: auto !important;      
    display: block;               
    margin: 20px auto;            /* По умолчанию (для мобильных) — центр */
    border-radius: 3px;           
}

/* Делаем все видео (iframe) в тексте адаптивными */
.entry iframe {
    max-width: 100% !important;
    border-radius: 8px; /* Добавим аккуратное скругление углов */
}

/* На мобильных принудительно делаем видео на всю ширину экрана с правильной пропорцией */
@media (max-width: 768px) {
    .entry iframe {
        width: 100% !important;
        height: auto !important;
        aspect-ratio: 16 / 9; /* Сохраняем классические пропорции видео, чтобы оно не сплющилось */
    }
}

/* СТРОГО ДЛЯ ПК: прижимаем фото в статьях к левому краю */
@media (min-width: 1001px) {
    .entry img {
        margin: 20px 0; 
    }
}

/* Настраиваем только отступы, не трогая интервал (он наследуется выше) */
.entry p { 
    margin-bottom: 20px; 
	line-height: 1.4 !important; 
}

/* --- СТИЛИ ДЛЯ ТАБЛИЦ В ТЕКСТЕ --- */
.entry table {
    width: 100% !important;
    border-collapse: collapse;
    margin: 30px 0;
    font-size: 17px; /* Чуть меньше основного текста для опрятности */
    background: #fff;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05); /* Мягкая тень */
    border-radius: 8px; /* Скругленные углы */
    overflow: hidden; /* Важно, чтобы скругления работали */
    border: 1px solid #d6d4d4 !important; /* Гасим жесткие черные рамки из редактора */
}

/* Прокрутка на мобильных (чтобы широкая таблица не ломала экран) */
@media (max-width: 768px) {
    .entry table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap; /* Не даем тексту сплющиваться в узкие столбики */
    }
}

/* Ячейки таблицы */
.entry table th, 
.entry table td {
    padding: 15px 20px;
    text-align: left;
    border: 1px solid #d6d4d4 !important; /* Нежные светло-серые разделители */
    vertical-align: middle;
}

/* Спец-стиль для заголовков (первой строки) */
.entry table th,
.entry table thead td,
.entry table tr:first-child td { /* Захватываем первую строку, даже если редактор не прописал th */
    background-color: #f8f9fa; /* Светло-серый фон шапки */
    font-weight: 600;
    color: var(--main-color); /* Акцентный цвет сайта */
    font-size: 16px;
}

/* Отменяем спец-стиль шапки для первой ячейки (где слово "Модель котла"), если нужно, 
   но обычно вся первая строка выглядит хорошо в акцентном цвете */

/* Зебра (чередование цвета строк) */
.entry table tbody tr:nth-child(even) {
    background-color: #fcfcfc;
}

/* Эффект подсветки строки при наведении (только на ПК) */
@media (min-width: 1001px) {
    .entry table tbody tr:hover,
    .entry table tr:hover td {
        background-color: #f0f5fa !important;
        transition: background 0.3s ease;
    }
}

/* Единый стиль для списков внутри контента (Десктоп) */
.entry ul, .entry ol {
    list-style-position: outside; 
    padding-left: 35px; /* Увеличили с 25 до 35, чтобы маркеры не вылезали влево */          
    margin-bottom: 20px;
}

.entry li {
    padding-left: 5px;            
    margin-bottom: 10px;          
    text-align: left;
    /* Наследует line-height: 1.4 от .entry автоматически */
}

/* АКЦЕНТНЫЙ цвет элементов */

/* Перекрашивание иконок через переменную из админки */
.c-item {
    display: flex;
    align-items: center;
    overflow: hidden; /* Скрываем оригинал, оставляем только цветную тень */
}

.c-item img {
    /* Делаем иконки белыми через тень */
    filter: drop-shadow(40px 0 0 #fff);
    position: relative;
    left: -40px;
}

/* Добавим плавную смену цвета для ссылок при наведении */
.c-item a {
    transition: color 0.3s ease;
}

.c-item a:hover {
    /* Вместо изменения цвета делаем текст немного прозрачнее */
    opacity: 0.8;
    color: #fff !important; /* Удерживаем белый цвет */
}


/* ==========================================
   МОБИЛЬНАЯ ВЕРСИЯ (ОБЩАЯ) 
   ========================================== */
@media (max-width: 1000px) {
    .container, main.container {
        width: 100% !important;
        max-width: 100% !important;
        padding: 15px;
        margin: 0 !important;
        border-radius: 0;
    }

    .main-header { padding: 5px 0 10px 0 !important; 
	background-image: none !important; 
        background-color: #46428e !important;}
    .logo img { height: 55px !important; } 
    .header-contacts { gap: 2px; margin-left: 10px; }
    .c-item { font-size: 16px; } 
    #topMenu { background-color: #aabcdf !important; height: 45px; }

    /* --- СТАТЬИ В КАТАЛОГЕ (1 в ряд) --- */
    .card-item:not(.product-card) .card-image {
        height: 200px !important; 
    }
    .card-item:not(.product-card) .card-info {
        padding: 8px 15px 5px 15px !important;
        text-align: left !important;
    }
    .card-item:not(.product-card) .card-info h3 {
        margin: 0 !important;
        padding-bottom: 2px !important;
        line-height: 1.3 !important;
        font-size: 17px !important; /* ЕДИНЫЙ РАЗМЕР */
    }
    /* Скрываем описание статей на всех мобильных экранах */
    .card-item:not(.product-card) .card-desc {
        display: none !important;
    }

    /* --- ТОВАРЫ (Левый край, отступы и линия) --- */
    .card-item.product-card .card-info {
        padding: 15px 15px 20px 15px !important;
        text-align: left !important;
    }

    .card-item.product-card .card-info h3 {
		font-size: 20px !important; /* ЕДИНЫЙ РАЗМЕР */
		line-height: 1.2 !important;
        border-bottom: 1px solid #eee !important; 
        padding-bottom: 10px !important;
        margin-bottom: 1px !important;
        display: block !important;
        width: 100%;
        min-height: 3.5em !important; 
        line-height: 1.3 !important;
        display: flex !important;
        align-items: flex-start !important;
    }

    /* --- ОСТАЛЬНЫЕ МОБИЛЬНЫЕ ПРАВКИ --- */
    /* Текст статьи и списки — приводим к общему 17px */
    .entry p, .entry ul, .entry ol, .entry li, .entry div {
        font-size: 18px !important; 
        line-height: 1.4 !important;
    }
	    /* Заголовки мобильные */
    h1 { font-size: 25px !important; }
    h2 { font-size: 23px !important; }
    h3 { font-size: 22px !important; } /* Заголовки на самой странице */

    /* Маркированный список (точки) */
    .entry ul {
        list-style-position: outside; 
        padding-left: 20px; /* Отступ всего блока от края */
        margin-bottom: 15px;
    }

    /* Нумерованный список (цифры) */
    .entry ol {
        list-style-position: outside; 
        padding-left: 22px; /* Уменьшили с 28px до 22px, чтобы прижать список к левому краю */
        margin-bottom: 15px;
    }

    /* Индивидуальная подстройка зазора до текста */
    .entry ul li {
        padding-left: 0px; /* МАКСИМАЛЬНО прижимаем текст к точке */
    }

    .entry ol li {
        padding-left: 5px; /* Оставляем небольшой зазор для цифр */
    }

    /* Общие стили для всех LI */
    .entry li {
        margin-bottom: 15px;           
        text-align: left;
    }
	
    footer { background: #fff !important; padding: 10px 0 !important; }
    footer p { font-size: 17px !important; color: #888; }
    .links-container li a { font-size: 17px !important; line-height: 1.3 !important; }
    .links-container img { width: 15px !important; height: 15px !important; }
    
    .breadcrumbs {
        display: flex; overflow-x: auto; white-space: nowrap;
        position: relative; padding-right: 30px;
    }
    .breadcrumbs::after {
        content: ''; position: absolute; right: 0; width: 30px; height: 100%;
        background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,1));
    }

    /* --- СТРАНИЦА ТОВАРА (Внутренняя) --- */
    .product-card-info h1 {
        font-size: 22px !important; /* Уменьшаем огромный заголовок */
        margin-top: 10px !important;
        line-height: 1.2 !important;
    }

    .product-short-desc {
        font-size: 17px !important; /* Приводим к единому стандарту 17px */
        line-height: 1.4 !important;
        margin-bottom: 15px !important;
    }

    .product-main-price {
        font-size: 24px !important; /* Цена чуть крупнее текста, но не огромная */
        margin-top: 15px !important;
        padding-top: 10px !important;
    }

    .product-main-price .price-label {
        font-size: 17px !important; /* Слово "Цена:" — 17px */
    }

    /* Кнопка "Добавить в корзину" на странице товара */
    .product-card-info .buy-btn {
        width: 100% !important; /* На мобилках лучше на всю ширину */
        font-size: 18px !important;
        padding: 12px 20px !important;
    }
}

/* ==========================================
   КОМПАКТНАЯ СЕТКА (2 В РЯД - СМАРТФОНЫ)
   ========================================== */
@media (max-width: 768px) {
    .cards-grid.compact-on {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
        margin: 20px 0 !important;
    }

    .compact-on .card-item { border-radius: 12px !important; }

    /* Картинки в статьях (2 в ряд) */
    .compact-on .card-item:not(.product-card) .card-image {
        height: 140px !important;
    }

    /* Информация в компактных карточках */
    .compact-on .card-info {
        padding: 8px 10px 5px 10px !important;
    }

    .compact-on .card-info h3 {
        font-size: 17px !important; /* ЕДИНЫЙ РАЗМЕР (был 15) */
        line-height: 1.3 !important;
        min-height: auto !important;
        margin: 0 !important;
        border: none !important;
    }

    /* Цены и кнопки в товарах (2 в ряд) */
    .compact-on .price-buy-row {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 6px !important;
    }
    .compact-on .product-price {
        font-size: 17px !important;
        text-align: left !important;
		font-weight: 700 !important; /* Делаем жирным как в рекомендациях */
    }
    .compact-on .buy-btn {
        width: 100% !important;
        height: 34px !important;
        font-size: 13px !important;
    }
}


/* --- КНОПКА СВЯЗИ MAX С АНИМАЦИЕЙ И СКРЫТИЕМ --- */
.max-float-btn {
    position: fixed;
    bottom: 95px;
    right: 30px;
    width: 50px;
    height: 50px;
    background-color: var(--main-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 998;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    transition: all 0.3s ease;
    
    /* Состояние "Скрыто" (пока не прокрутили 400px) */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px); 
}

/* Класс для показа (добавляется скриптом в index.php) */
.max-float-btn.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* АНИМАЦИЯ РАСХОДЯЩИХСЯ КРУГОВ (возвращаем её) */
.max-float-btn::before,
.max-float-btn::after {
    content: "";
    position: absolute;
    border: 1px solid var(--main-color);
    left: -5px; right: -5px; top: -5px; bottom: -5px;
    border-radius: 50%;
    animation: max-pulse 2s linear infinite;
    opacity: 0;
}

.max-float-btn::after {
    animation-delay: 1s;
}

@keyframes max-pulse {
    0% { transform: scale(1); opacity: 0.5; }
    100% { transform: scale(1.6); opacity: 0; }
}

/* Иконка внутри (делаем белой) */
.max-float-btn img {
    width: 28px;
    height: 28px;
    filter: brightness(0) invert(1);
}

/* Адаптация под мобилки */
@media (max-width: 768px) {
    .max-float-btn {
        bottom: 85px; /* Чуть выше стрелки "Наверх" на мобиле */
        right: 20px;
        width: 45px;
        height: 45px;
    }
}