/*
Theme Name: humidity
Theme URI: https://humidity.ru/
Author: You
Description: Humidity
Version: 1.0
*/


/* Общие */

/* Марджины для картинок в контенте */
.entry-content img,
.post-content img,
.page-content img,
.wp-block-image img {
    margin: 30px 0 !important;
    display: block;
    height: auto;
}

* {
    font-family: 'Montserrat', Arial, sans-serif !important;
}

body {
    margin: 0 !important;
    padding: 0 !important;
} 


header .t794__list_item a {
    color: var(--color-text) !important;
}

a {
    text-decoration-color: currentColor !important;
}


/* ---- СКРУГЛЕНИЕ ДЛЯ ВСЕХ КАРТИНОК В КОНТЕНТЕ ------ */
.entry-content img,
.wp-block-image img,
.wp-block-media-text img,
.wp-block-cover img,
.wp-block-group img,
.page-content img,
.post-content img,
.t-bgimg,
.tn-atom__img {
    border-radius: 20px !important;
    overflow: hidden;
}



/* ============================================
   HUMIDITY — ГЛОБАЛЬНЫЕ СТИЛИ
   ============================================ */

:root {
    /* Контейнеры */
    --container-desktop: 900px;    /* от 1200px */
    --container-tablet: 748px;      /* от 768px до 1199px */
    --container-mobile: 340px;      /* до 767px */
    --container-news: 1200px;       /* контейнер для блоков новостей */
    --container-product: 1280px;    /* контейнер для продуктовой страницы и слайдера */
    
    /* Шрифты */
    --font-main: 'Montserrat', Arial, sans-serif;
    --font-size-base: 16px;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-bold: 600;
    --font-weight-light: 300;
    
    /* Цвета */
    --color-text: #000000;
    --color-accent: rgb(40, 137, 199);
    --color-gray: rgb(119, 119, 119);
    --color-light-gray: rgba(0,0,0,0.5);
    
    /* Отступы */
    --gap-sm: 10px;
    --gap-md: 20px;
    --gap-lg: 40px;
    
    /* Скругления */
    --radius-sm: 10px;      /* фото товаров */
    --radius-md: 20px;      /* картинки в контенте, миниатюры */
    --radius-lg: 30px;      /* кнопки */
    
    /* Высоты */
    --btn-height: 45px;
    
    /* Прозрачность */
    --opacity-light: 0.65;
}

/* ============================================
   1. ТИПОГРАФИЯ
   ============================================ */

/* Заголовок специальный — 64px, bold, акцентный */
.title-64 {
    font-size: 64px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-accent);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

/* Заголовок h1 — 40px, акцентный, bold, line-height 1.2 */
.title-xxl {
    font-size: 40px;
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    color: var(--color-accent);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

/* Заголовок h2 — 32px, базовый, bold, line-height 1.2 */
.title-xl {
    font-size: 32px;
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

/* Заголовок h3 — 24px, базовый, normal, line-height 1.2 */
.title-lg {
    font-size: 24px;
    font-weight: var(--font-weight-normal);
    line-height: 1.2;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

/* Заголовки блоков (например "Смотрите также") — 24px, light */
.title-block {
    font-size: 24px;
    font-weight: var(--font-weight-light);
    line-height: 1.2;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 30px 0;
}

/* ===== Заголовки внутри контента (посты и страницы) ===== */
.post-content h1 {
    font-size: 40px !important;
    font-weight: var(--font-weight-bold) !important;
    line-height: 1.2 !important;
    color: var(--color-accent) !important;
    font-family: var(--font-main) !important;
    margin: 0 0 20px 0 !important;
}

.page-content h1 {
    font-size: 64px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-accent);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

.post-content h2,
.page-content h2 {
    font-size: 32px !important;
    font-weight: var(--font-weight-bold) !important;
    line-height: 1.2 !important;
    color: var(--color-text) !important;
    font-family: var(--font-main) !important;
    margin: 0 0 20px 0 !important;
}

.post-content h3,
.page-content h3 {
    font-size: 24px !important;
    font-weight: var(--font-weight-normal) !important;
    line-height: 1.2 !important;
    color: var(--color-text) !important;
    font-family: var(--font-main) !important;
    margin: 0 0 20px 0 !important;
}

/* ===== Основные тексты ===== */
.text-base {
    font-size: 16px;
    font-weight: var(--font-weight-normal);
    line-height: 1.7;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 20px 0;
}

/* Параграфы и списки внутри контента */
.post-content p,
.post-content ol,
.post-content ul,
.page-content p,
.page-content ol,
.page-content ul {
    font-size: 16px;
    font-weight: var(--font-weight-normal);
    line-height: 1.7;
    color: var(--color-text);
    font-family: var(--font-main);
    margin-top: 0 !important;
    margin-bottom: 30px !important;
}

/* Текст для карточек товаров, заголовки элементов — 18px, bold, line-height 1.4 */
.text-card-title {
    font-size: 18px;
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Цена в товаре — тот же стиль, но акцентный цвет */
.text-card-price {
    font-size: 18px;
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-accent);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Заголовок в карточке слайдера — 20px, bold, базовый цвет */
.text-slide-title {
    font-size: 20px;
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Заголовок товара — 20px, light, line-height 1.3 */
.text-product-title {
    font-size: 20px;
    font-weight: var(--font-weight-light);
    line-height: 1.3;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Мелкие элементы (дата, хлебные крошки) — 14px, normal, прозрачность */
.text-small {
    font-size: 14px;
    font-weight: var(--font-weight-normal);
    line-height: 1.4;
    color: var(--color-text);
    opacity: var(--opacity-light);
    font-family: var(--font-main);
    margin: 0;
}

/* Дескрипт в карточке новости — 14px, light, обычная прозрачность */
.text-description {
    font-size: 14px;
    font-weight: var(--font-weight-light);
    line-height: 1.4;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Описание товара — 14px, light, непрозрачный */
.text-description-solid {
    font-size: 14px;
    font-weight: var(--font-weight-light);
    line-height: 1.4;
    color: var(--color-text);
    font-family: var(--font-main);
    margin: 0 0 10px 0;
}

/* Описание в контенте товара */
.product-content p {
    font-size: 14px !important;
    font-weight: var(--font-weight-light) !important;
    line-height: 1.4 !important;
    color: var(--color-text) !important;
    font-family: var(--font-main) !important;
    margin: 0 0 10px 0 !important;
}

/* Самый мелкий элемент (дата внутри карточки) — 10px, bold, с прозрачностью */
.text-tiny {
    font-size: 10px;
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-light-gray);
    letter-spacing: 1px;
    font-family: var(--font-main);
    margin: 0;
}

/* Артикул и примечания в товаре — серый, light, 14px */
.text-article {
    font-size: 14px;
    font-weight: var(--font-weight-light);
    line-height: 1.4;
    color: var(--color-gray);
    font-family: var(--font-main);
    margin: 0 0 5px 0;
}

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

/* Базовая кнопка (в карточках архивная) */
.btn {
    display: inline-block;
    font-size: 14px;
    font-weight: var(--font-weight-bold);
    text-align: center;
    text-decoration: none;
    border-radius: var(--radius-lg);
    transition: all 0.2s ease;
    cursor: pointer;
    border: 1px solid transparent;
    box-sizing: border-box;
    line-height: 1.2;
    height: var(--btn-height);
    padding: 12px 30px;
    width: 100%;
}

/* Основная кнопка — акцентный фон (на товаре) */
.btn-primary {
    background-color: var(--color-accent);
    color: #ffffff;
    border-color: var(--color-accent);
}

.btn-primary:hover {
    background-color: transparent;
    color: var(--color-accent);
}

/* Кнопка маленькая со стрелкой (для портфолио) */
.btn-arrowed {
    width: auto !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 0 16px;
    height: 30px;
    background-color: #2889c7;
    color: #ffffff !important;
    font-size: 16px;
    font-family: 'Montserrat', Arial, sans-serif;
    font-weight: 600;
    line-height: 1;
    border-radius: 30px;
    border: 1px solid #2889c7;
    cursor: pointer;
    transition: all 0.2s ease;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;
}

.btn-arrowed:hover {
    background-color: #ffffff;
    color: #2889c7 !important;
}

.btn-arrowed .btn-icon {
    width: 15px;
    height: 13px;
    display: inline-block;
    background-image: url('/wp-content/themes/humidity/images/arrow-white.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    transition: background-image 0.2s ease;
    flex-shrink: 0;
}

.btn-arrowed:hover .btn-icon {
    background-image: url('/wp-content/themes/humidity/images/arrow-blue.svg');
}

/* Кнопка для табов (новости, видео, портфолио, оборудование) */
.btn-tab {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 55px;
    font-size: 18px;
    font-weight: 400;
    text-align: center;
    background-color: transparent;
    color: #cecece;
    border: 1px solid #cecece;
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all 0.2s ease;
    padding: 0 20px;
    text-transform: uppercase;
    flex: 1;
    min-width: 0;
}

.btn-tab:hover,
.btn-tab.active {
    background-color: var(--color-accent);
    color: #ffffff;
    border-color: var(--color-accent);
}

/* ============================================
   3. КОНТЕЙНЕРЫ
   ============================================ */

/* Основной контейнер (900px) */
.container {
    max-width: var(--container-desktop);
    margin: 0 auto;
    padding: 0 var(--gap-md);
    box-sizing: border-box;
    width: 100%;
}

/* Контейнер для новостей и видео (1200px) */
.container-news {
    max-width: var(--container-news);
    margin: 0 auto;
    padding: 0 var(--gap-md);
    box-sizing: border-box;
    width: 100%;
}

/* Контейнер для товаров (1280px) */
.container-product {
    max-width: var(--container-product);
    margin: 0 auto;
    padding: 0 var(--gap-md);
    box-sizing: border-box;
    width: 100%;
}

/* Адаптация контейнеров */
@media (max-width: 1199px) {
    .container { max-width: var(--container-tablet); }
    .container-news { max-width: var(--container-tablet); }
}
@media (max-width: 767px) {
    .container { max-width: var(--container-mobile); }
    .container-news { max-width: var(--container-mobile); }
}

/* Специальная адаптация container-product */
@media (max-width: 1281px) { .container-product { max-width: 1200px; } }
@media (max-width: 1201px) { .container-product { max-width: 768px; } }
@media (max-width: 961px) { .container-product { max-width: 728px; } }
@media (max-width: 762px) {
    .container-product {
        max-width: 100%;
        padding: 0 15px;
    }
}

/* ============================================
   4. СЕТКИ
   ============================================ */

/* Сетка для новостей и видео */
.news-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gap-md);
}

@media (max-width: 768px) { .news-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .news-grid { grid-template-columns: 1fr; } }

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

/* Все картинки в контенте */
img,
.entry-content img,
.wp-block-image img,
.wp-block-media-text img,
.wp-block-cover img,
.wp-block-group img {
    border-radius: var(--radius-md);
    overflow: hidden;
}

/* Фото товаров */
.product-image,
.custom-card__image {
    border-radius: var(--radius-sm);
    overflow: hidden;
}

/* Миниатюры новостей (без радиуса) */
.news-card__image,
.custom-card__image--no-radius {
    border-radius: 0;
    overflow: hidden;
}

.news-card__image-wrapper {
    width: 100%;
    aspect-ratio: 380 / 314;
    overflow: hidden;
}

/* Миниатюра поста */
.post-thumbnail {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    aspect-ratio: 900 / 555;
    overflow: hidden;
}

.post-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (max-width: 600px) {
    .post-thumbnail {
        aspect-ratio: 1 / 1;
    }
}

/* ============================================
   6. БЛОК MEDIA-TEXT (Гутенберг)
   ============================================ */

/* Картинка слева → текст справа, паддинг слева */
.page-content .wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__content,
.post-content .wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__content {
    padding: 0 0 0 8% !important;
}

/* Картинка справа → текст слева, паддинг справа */
.page-content .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content,
.post-content .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
    padding: 0 8% 0 0 !important;
}

/* Адаптация на мобилках */
@media (max-width: 768px) {
    .page-content .wp-block-media-text,
    .post-content .wp-block-media-text {
        display: flex !important;
        flex-direction: column !important;
        gap: 20px !important;
        padding: 0 !important;
    }
    .page-content .wp-block-media-text .wp-block-media-text__content,
    .post-content .wp-block-media-text .wp-block-media-text__content {
        padding: 0 !important;
        margin: 0 !important;
    }
    .page-content .wp-block-media-text figure,
    .post-content .wp-block-media-text figure {
        margin: 0 !important;
        padding: 0 !important;
    }
}

/* ============================================
   7. ОБВОДКИ ДЛЯ ДИВОВ
   ============================================ */

/* Обводка сверху и снизу */
.border-y {
    border-top: 1px solid rgba(0,0,0,0.3);
    border-bottom: 1px solid rgba(0,0,0,0.3);
}

/* Обводка только сверху */
.border-top {
    border-top: 1px solid rgba(0,0,0,0.3);
}

/* Обводка только снизу */
.border-bottom {
    border-bottom: 1px solid rgba(0,0,0,0.3);
}

/* ============================================
   8. ТАБЫ
   ============================================ */

.tabs-wrapper {
    width: 100%;
}

.tabs-container {
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
    padding: 20px 0;
    gap: 20px;
}

/* ============================================
   9. АДАПТАЦИЯ ВСЕХ ЭЛЕМЕНТОВ
   ============================================ */

/* Планшеты (до 1024px) */
@media (max-width: 1024px) {
    /* Заголовки */
    .title-xxl, .post-content h1 { font-size: 32px; }
    .title-xl, .post-content h2, .page-content h2 { font-size: 28px; }
    .title-lg, .post-content h3, .page-content h3 { font-size: 22px; }
    .title-block { font-size: 22px; }
    .title-64, .page-content h1 { font-size: 48px; }
    
    /* Тексты */
    .text-card-title { font-size: 16px; }
    .text-slide-title { font-size: 18px; }
    .text-product-title { font-size: 18px; }
    
    /* Контейнеры */
    .container,
    .container-news,
    .container-product {
        padding: 0 20px;
    }
    
    /* Кнопка со стрелкой */
    .btn-arrowed {
        font-size: 14px;
        padding: 0 14px;
        height: 28px;
        gap: 8px;
    }
    .btn-arrowed .btn-icon {
        width: 13px;
        height: 11px;
    }
}

/* Мобилки (до 768px) */
@media (max-width: 768px) {
    /* Заголовки */
    .title-xxl, .post-content h1 { font-size: 28px; }
    .title-xl, .post-content h2, .page-content h2 { font-size: 24px; }
    .title-lg, .post-content h3, .page-content h3 { font-size: 20px; }
    .title-block { font-size: 20px; }
    .title-64, .page-content h1 { font-size: 36px; }
    
    /* Тексты */
    .text-base { font-size: 15px; }
    .text-card-title { font-size: 15px; }
    .text-slide-title { font-size: 16px; }
    .text-product-title { font-size: 16px; }
    .text-small { font-size: 13px; }
    .text-description { font-size: 13px; }
    
    /* Отступы */
    .mb-40 { margin-bottom: 30px !important; }
    .mb-60 { margin-bottom: 40px !important; }
    .gap-20 { gap: 15px !important; }
    
    /* Кнопки */
    .btn { padding: 10px 20px; font-size: 13px; height: auto; }
    .btn-tab { font-size: 14px; height: 48px; padding: 0 15px; }
    
    .btn-arrowed {
        font-size: 13px;
        padding: 0 12px;
        height: 26px;
        gap: 6px;
    }
    .btn-arrowed .btn-icon {
        width: 12px;
        height: 10px;
    }
}

/* Маленькие мобилки (до 480px) */
@media (max-width: 480px) {
    /* Заголовки */
    .title-xxl, .post-content h1 { font-size: 24px; }
    .title-xl, .post-content h2, .page-content h2 { font-size: 22px; }
    .title-lg, .post-content h3, .page-content h3 { font-size: 18px; }
    .title-64, .page-content h1 { font-size: 28px; }
    
    /* Тексты */
    .text-base { font-size: 14px; }
    .text-slide-title { font-size: 15px; }
    .text-small { font-size: 12px; }
    
    /* Контейнеры */
    .container,
    .container-news,
    .container-product {
        padding: 0 15px;
    }
    
    /* Кнопки */
    .btn { padding: 8px 16px; font-size: 12px; }
    .btn-tab { font-size: 13px; height: 44px; padding: 0 12px; }
    
    .btn-arrowed {
        font-size: 12px;
        padding: 0 10px;
        height: 24px;
        gap: 5px;
    }
    .btn-arrowed .btn-icon {
        width: 10px;
        height: 8px;
    }
}

/* ============================================
   10. АДАПТАЦИЯ СКРУГЛЕНИЙ
   ============================================ */

@media (max-width: 768px) {
    .entry-content img,
    .wp-block-image img,
    .page-content img,
    .t-bgimg {
        border-radius: 15px !important;
    }
    .product-image,
    .custom-card__image {
        border-radius: 8px !important;
    }
    .btn {
        border-radius: 25px !important;
    }
}

@media (max-width: 480px) {
    .entry-content img,
    .wp-block-image img,
    .page-content img,
    .t-bgimg {
        border-radius: 12px !important;
    }
}

/* ============================================
   11. РУЧНАЯ КОРРЕКЦИЯ ВИЗУАЛЬНЫХ РАСХОЖДЕНИЙ
   ============================================ */

/* Ссылки в контенте и некоторых блоках — акцентный цвет */
.post-content a,
.page-content a,
.portfolio-card__description a,
.oborudovanie-gallery a {
    color: var(--color-accent) !important;
    text-decoration: none !important;
}

.post-content a:hover,
.page-content a:hover,
.portfolio-card__description a:hover,
.oborudovanie-gallery a:hover {
    text-decoration: underline !important;
}



/* ======= СТИЛИ HUMIDITY END ====== */










/* ==== Глобальные классы ==== */

.w-auto { width: auto !important; }
.w-full { width: 100% !important; }
.h-auto { height: auto !important; }
.h-full { height: 100% !important; }
.max-w-full { max-width: 100% !important; }
.overflow-hidden { overflow: hidden !important; }
.w-400-hum { width: 400px !important; }



/* ======== ВСПОМОГАТЕЛЬНОЕ ДЛЯ РЕДАКТОРА ВП ========= */

p.w-400-hum {
    max-width: 400px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.wp-block-image.w-full {
    width: 100% !important;
}

.wp-block-image.w-full img {
    width: 100% !important;
    height: auto !important;
    object-fit: cover;
}



/* ==== Марджини ==== */
.m-0 { margin: 0 !important; }
.mb-10 { margin-bottom: 10px !important; }
.mb-20 { margin-bottom: 20px !important; }
.mb-30 { margin-bottom: 30px !important; }
.mb-40 { margin-bottom: 40px !important; }
.mb-50 { margin-bottom: 50px !important; }
.mb-60 { margin-bottom: 60px !important; }
.mb-80 { margin-bottom: 80px !important; }
.mb-100 { margin-bottom: 100px !important; }



.mt-10 { margin-top: 10px !important; }
.mt-20 { margin-top: 20px !important; }
.mt-30 { margin-top: 30px !important; }
.mt-40 { margin-top: 40px !important; }
.mt-100 { margin-top: 100px !important; }


/* Отрицательные марджины */
.mt-n10 { margin-top: -10px !important; }
.mt-n20 { margin-top: -20px !important; }
.mt-n30 { margin-top: -30px !important; }
.mt-n40 { margin-top: -40px !important; }

.mb-n10 { margin-bottom: -10px !important; }
.mb-n20 { margin-bottom: -20px !important; }
.mb-n30 { margin-bottom: -30px !important; }
.mb-n40 { margin-bottom: -40px !important; }

.ml-n10 { margin-left: -10px !important; }
.ml-n20 { margin-left: -20px !important; }
.ml-n30 { margin-left: -30px !important; }
.ml-n40 { margin-left: -40px !important; }

.mr-n10 { margin-right: -10px !important; }
.mr-n20 { margin-right: -20px !important; }
.mr-n30 { margin-right: -30px !important; }
.mr-n40 { margin-right: -40px !important; }


/* Общие паддинги (со всех сторон) */
.p-0 { padding: 0 !important; }
.p-20 { padding: 20px !important; }
.p-40 { padding: 40px !important; }
.p-90 { padding: 90px !important; }

/* Горизонтальные паддинги */
.px-20 { 
    padding-left: 20px !important; 
    padding-right: 20px !important; 
}
.px-40 { 
    padding-left: 40px !important; 
    padding-right: 40px !important; 
}
.px-90 { 
    padding-left: 90px !important; 
    padding-right: 90px !important; 
}

/* Вертикальные паддинги */
.pt-40 { padding-top: 40px !important; }
.pb-40 { padding-bottom: 40px !important; }
.pt-20 { padding-top: 20px !important; }
.pb-20 { padding-bottom: 20px !important; }

.py-20 { 
    padding-top: 20px !important; 
    padding-bottom: 20px !important; 
}
.py-40 { 
    padding-top: 40px !important; 
    padding-bottom: 40px !important; 
}

/* ==== Флексы ==== */
.flex { display: flex !important; }
.flex-row { flex-direction: row !important; }
.flex-col { flex-direction: column !important; }
.flex-wrap { flex-wrap: wrap !important; }
.flex-nowrap { flex-wrap: nowrap !important; }

.justify-start { justify-content: flex-start !important; }
.justify-center { justify-content: center !important; }
.justify-between { justify-content: space-between !important; }
.justify-end { justify-content: flex-end !important; }

.items-start { align-items: flex-start !important; }
.items-center { align-items: center !important; }
.items-end { align-items: flex-end !important; }
.items-stretch { align-items: stretch !important; }

/* Горизонтальные гапы (только column-gap) */
.gap-x-10 {
    column-gap: 10px !important;
    row-gap: 0 !important;
}
.gap-x-20 {
    column-gap: 20px !important;
    row-gap: 0 !important;
}
.gap-x-30 {
    column-gap: 30px !important;
    row-gap: 0 !important;
}
.gap-x-40 {
    column-gap: 40px !important;
    row-gap: 0 !important;
}

/* Вертикальные гапы (только row-gap) */
.gap-y-10 {
    row-gap: 10px !important;
    column-gap: 0 !important;
}
.gap-y-20 {
    row-gap: 20px !important;
    column-gap: 0 !important;
}
.gap-y-30 {
    row-gap: 30px !important;
    column-gap: 0 !important;
}
.gap-y-40 {
    row-gap: 40px !important;
    column-gap: 0 !important;
}

/* Универсальные (обе стороны) */
.gap-10 { gap: 10px !important; }
.gap-20 { gap: 20px !important; }
.gap-30 { gap: 30px !important; }
.gap-40 { gap: 40px !important; }
.gap-50 { gap: 50px !important; }
.gap-60 { gap: 60px !important; }

/* ==== Сетка ==== */
.col-1 { width: 8.333% !important; }
.col-2 { width: 16.666% !important; }
.col-3 { width: 25% !important; }
.col-4 { width: 33.333% !important; }
.col-5 { width: 41.666% !important; }
.col-6 { width: 50% !important; }
.col-7 { width: 58.333% !important; }
.col-8 { width: 66.666% !important; }
.col-9 { width: 75% !important; }
.col-10 { width: 83.333% !important; }
.col-11 { width: 91.666% !important; }
.col-12 { width: 100% !important; }

/* ==== Текст ==== */
.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }

.text-uppercase { text-transform: uppercase !important; }
.text-lowercase { text-transform: lowercase !important; }
.text-capitalize { text-transform: capitalize !important; }

.font-normal { font-weight: 400 !important; }
.font-medium { font-weight: 500 !important; }
.font-bold { font-weight: 700 !important; }

.text-12 { font-size: 12px !important; }
.text-14 { font-size: 14px !important; }
.text-16 { font-size: 16px !important; }
.text-18 { font-size: 18px !important; }
.text-20 { font-size: 20px !important; }
.text-24 { font-size: 24px !important; }
.text-30 { font-size: 30px !important; }
.text-36 { font-size: 36px !important; }

/* ==== Цвета ==== */
.color-white { color: #ffffff !important; }
.color-black { color: #000000 !important; }
.color-gray { color: #666666 !important; }
.color-blue { color: #2e528b !important; }
.color-darkblue { color: #1a3a5e !important; }

.bg-white { background-color: #ffffff !important; }
.bg-gray { background-color: #f5f5f5 !important; }
.bg-blue { background-color: #2e528b !important; }

/* ==== Границы и скругления ==== */
.rounded-10 { border-radius: 10px !important; }
.rounded-20 { border-radius: 20px !important; }
.rounded-30 { border-radius: 30px !important; }
.rounded-full { border-radius: 9999px !important; }

/* ==== Позиционирование ==== */
.relative { position: relative !important; }
.absolute { position: absolute !important; }
.static { position: static !important; }

/* ==== Отображение ==== */
.block { display: block !important; }
.inline-block { display: inline-block !important; }
.hidden { display: none !important; }


/* ===== АДАПТАЦИЯ ОТСТУПОВ ===== */

@media (max-width: 768px) {
    /* Паддинги */
    .p-40 { padding: 30px !important; }
    .px-40 { padding-left: 20px !important; padding-right: 20px !important; }
    .py-40 { padding-top: 30px !important; padding-bottom: 30px !important; }
    .pt-40 { padding-top: 30px !important; }
    .pb-40 { padding-bottom: 30px !important; }
    
    /* Марджины */
    .mb-40 { margin-bottom: 30px !important; }
    .mb-50 { margin-bottom: 40px !important; }
    .mb-60 { margin-bottom: 45px !important; }
    .mb-80 { margin-bottom: 60px !important; }
    .mb-100 { margin-bottom: 70px !important; }
    
    .mt-40 { margin-top: 30px !important; }
    .mt-100 { margin-top: 70px !important; }
    
    /* Отступы в контейнерах */
    .container-news,
    .container-1280,
    .container-product {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
}

@media (max-width: 480px) {
    .p-40 { padding: 20px !important; }
    .py-40 { padding-top: 20px !important; padding-bottom: 20px !important; }
    .pt-40 { padding-top: 20px !important; }
    .pb-40 { padding-bottom: 20px !important; }
    
    .mb-40 { margin-bottom: 20px !important; }
    .mb-50 { margin-bottom: 30px !important; }
    .mb-60 { margin-bottom: 35px !important; }
    .mb-80 { margin-bottom: 40px !important; }
    .mb-100 { margin-bottom: 50px !important; }
    
    .mt-40 { margin-top: 20px !important; }
    .mt-100 { margin-top: 50px !important; }
    
    .container-news,
    .container-1280,
    .container-product {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
}

/* ------- СТИЛИ АНИМАЦИЙ ---------- */


.stagger-container {
    --stagger-delay: 0.1s;
}

.stagger-container > * {
    animation-delay: calc(var(--stagger-item-index, 0) * var(--stagger-delay));
}

/* Анимация при появлении вьюпорта */
.stagger-container.scroll-fade-up > * {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
    transition-delay: calc(var(--stagger-item-index, 0) * 0.1s);
}

.stagger-container.visible > * {
    opacity: 1;
    transform: translateY(0);
}

/* Автоматический стаггер на основе индекса */
.scroll-fade-up {
    transition-delay: calc((var(--stagger-index, 1) - 1) * 0.15s);
}

.scroll-fade-left,
.scroll-fade-right,
.scroll-zoom-in {
    transition-delay: calc((var(--stagger-index, 1) - 1) * 0.15s);
}

/* Базовые анимации появления */
.animate-fade-in {
    animation: fadeIn 0.8s ease forwards;
}

.animate-fade-up {
    animation: fadeUp 0.8s ease forwards;
}

.animate-fade-down {
    animation: fadeDown 0.8s ease forwards;
}

.animate-fade-left {
    animation: fadeLeft 0.8s ease forwards;
}

.animate-fade-right {
    animation: fadeRight 0.8s ease forwards;
}

.animate-zoom-in {
    animation: zoomIn 0.8s ease forwards;
}

/* Анимации с задержками */
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-400 { animation-delay: 0.4s; }
.delay-500 { animation-delay: 0.5s; }
.delay-600 { animation-delay: 0.6s; }
.delay-700 { animation-delay: 0.7s; }
.delay-800 { animation-delay: 0.8s; }

/* Анимации для появления при скролле (через Intersection Observer) */
.scroll-fade-up {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.scroll-fade-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.scroll-fade-left {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.scroll-fade-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.scroll-fade-right {
    opacity: 0;
    transform: translateX(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.scroll-fade-right.visible {
    opacity: 1;
    transform: translateX(0);
}

.scroll-zoom-in {
    opacity: 0;
    transform: scale(0.9);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.scroll-zoom-in.visible {
    opacity: 1;
    transform: scale(1);
}

/* Ключевые кадры для анимаций */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes zoomIn {
    from {
        opacity: 0;
        transform: scale(0.8);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Анимации для внутренних элементов карточки */
.stagger-child > * {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s ease, transform 0.5s ease;
    transition-delay: calc(var(--child-index, 0) * 0.1s);
}

.stagger-child.visible > * {
    opacity: 1;
    transform: translateY(0);
}




/* Анимация для элементов с CSS-переменной --item-index */
.buh-exhibition-card [style*="--item-index"] {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
    transition-delay: calc(var(--item-index) * 0.15s);
}

.buh-exhibition-card.scroll-fade-up.visible [style*="--item-index"] {
    opacity: 1;
    transform: translateY(0);
}



/* ---- ОФОРМЛЕНИЕ ГАЛЕРЕИ ------ */

/* Отступы между картинками */
.wp-block-gallery.has-nested-images {
    gap: 20px !important;
}

/* Скругление углов для контейнеров картинок */
.wp-block-gallery.has-nested-images .wp-block-image {
    border-radius: 20px !important;
    overflow: hidden;
}

/* Скругление для самих изображений (на всякий случай) */
.wp-block-gallery.has-nested-images img {
    border-radius: 12px !important;
}

/* Для планшетов */
@media (min-width: 768px) {
    .wp-block-gallery.has-nested-images {
        gap: 30px !important;
    }
}

/* Для десктопов */
@media (min-width: 1024px) {
    .wp-block-gallery.has-nested-images {
        gap: 40px !important;
    }
}

/* ---- ДОП КЛАСС ДЛЯ РЕДАКТИРОВАНИЯ КОЛОНОК (надо прописывать в поле additional clases в редактировании выбранной галереи в редакторе, видно тильдовские стили перебивают, поэтому класс columns-4 из ВП спорит и не применяется) ------ */


/* ГАЛЕРЕЯ — 2 КОЛОНКИ */
.my-gallery-2 {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 3 КОЛОНКИ */
.my-gallery-3 {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 4 КОЛОНКИ */
.my-gallery-4 {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 5 КОЛОНОК */
.my-gallery-5 {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 6 КОЛОНОК */
.my-gallery-6 {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 7 КОЛОНОК */
.my-gallery-7 {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 20px !important;
}

/* ГАЛЕРЕЯ — 8 КОЛОНОК */
.my-gallery-8 {
    display: grid !important;
    grid-template-columns: repeat(8, 1fr) !important;
    gap: 20px !important;
}

/* ОБЩИЕ ПРАВИЛА ДЛЯ ВСЕХ ГАЛЕРЕЙ С МОИМИ КЛАССАМИ */
[class*="my-gallery-"] .wp-block-image {
    width: 100% !important;
    margin: 0 !important;
}

/* АДАПТИВ: на узких экранах уменьшаем кол-во колонок */
@media (max-width: 1024px) {
    [class*="my-gallery-"] {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 768px) {
    [class*="my-gallery-"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    [class*="my-gallery-"] {
        grid-template-columns: 1fr !important;
    }
}



