/**
 * Insteria Child Theme — child-main.css
 *
 * Кастомные CSS-переопределения поверх родительской темы.
 * Этот файл подключается ПОСЛЕ стилей insteria.
 * Оригинальные файлы insteria не трогаем.
 */


/* ═══════════════════════════════════════════════════════════════
   ГЛАВНАЯ СТРАНИЦА: баннер (слайдер) на всю ширину
   ═══════════════════════════════════════════════════════════════

   Проблема: .first-section внутри .main имеет max-width и ограничен
   родительским layout-контейнером.

   Решение: вытаскиваем блок на 100vw через отрицательные margin.
   Метод работает независимо от padding родителя.
*/

/* Убираем горизонтальный скролл от 100vw трюка */
.page-template-front-page .full-height-content {
    overflow-x: hidden;
}

.page-template-front-page .main > .d-flex:first-child {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    max-width: 100vw;
    overflow: hidden;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Сам слайдер — полная ширина без ограничения */
.page-template-front-page .first-section {
    max-width: 100% !important;
    width: 100% !important;
}


/* ═══════════════════════════════════════════════════════════════
   КАТАЛОГ: отступ текста в карточке категории
   ═══════════════════════════════════════════════════════════════

   Проблема: .card-catalog-v1-title позиционирован абсолютно,
   ширина задана в px — длинный текст переполняет блок.

   Решение: box-sizing:border-box — padding вычитается из width,
   а не добавляется к нему. overflow:hidden отсекает любой остаток.
   word-break:break-word разбивает слово если оно всё равно не лезет.
*/

/* Шрифт заголовков карточек каталога управляется из IG → Общее.
   CSS генерируется динамически плагином pervocvet-custom (AdminModule::output_catalog_css). */


/* ═══════════════════════════════════════════════════════════════
   СТРАНИЦА КАТЕГОРИИ: карусель подкатегорий
   ═══════════════════════════════════════════════════════════════

   Рендер: insteria-child/inc/subcategory-carousel.php
   Вкл/выкл: IG → Общее → Товары → «Карусель подкатегорий»

   Идея: горизонтальный скролл через scroll-snap, без JS-библиотек.
   На мобиле карточки фиксированной ширины, последняя — наполовину
   видна (padding-right на треке), чтобы показать, что есть скролл.
*/

.pv-subcats {
    margin: 0 0 28px;
    position: relative;
}

.pv-subcats__track {
    display: flex;
    gap: 16px;
    padding: 4px 0 12px;
}

/* Режим «карусель» — горизонтальный скролл со scroll-snap. */
.pv-subcats--carousel .pv-subcats__track {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    /* Тонкая полоска скролла как на прототипе */
    scrollbar-width: thin;
}

/* Режим «сетка» — все карточки в несколько рядов, без скролла. */
.pv-subcats--grid .pv-subcats__track {
    flex-wrap: wrap;
    row-gap: 24px;
}

.pv-subcats__track::-webkit-scrollbar {
    height: 6px;
}
.pv-subcats__track::-webkit-scrollbar-track {
    background: #eee;
    border-radius: 3px;
}
.pv-subcats__track::-webkit-scrollbar-thumb {
    background: #c9c9c9;
    border-radius: 3px;
}

.pv-subcats__card {
    flex: 0 0 auto;
    width: calc((100% - 16px * 5) / 6); /* 6 карточек на ПК, 5 гэпов */
    max-width: 170px;
    min-width: 130px;
    scroll-snap-align: start;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .18s ease;
}
.pv-subcats__card:hover {
    transform: translateY(-2px);
    text-decoration: none;
}

.pv-subcats__thumb {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 10px;
    overflow: hidden;
    background: #f3f3f3;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
}
.pv-subcats__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pv-subcats__thumb-placeholder {
    color: #9a9a9a;
    font-size: 12px;
}

.pv-subcats__name {
    margin-top: 10px;
    font-size: 14px;
    line-height: 1.25;
    text-align: center;
    color: #333;
    word-break: break-word;
}

/* Планшет: 4 карточки в ряд */
@media (max-width: 1199.98px) {
    .pv-subcats__card {
        width: calc((100% - 16px * 3) / 4);
    }
}

/* Маленький планшет: 3 карточки */
@media (max-width: 767.98px) {
    .pv-subcats__card {
        width: calc((100% - 16px * 2) / 3);
    }
}

/* Мобила: фиксированная ширина карточки + peek последней карточки
   только в режиме «карусель». В режиме «сетка» карточки идут в 2 колонки. */
@media (max-width: 575.98px) {
    .pv-subcats--carousel .pv-subcats__track {
        padding-right: 35%;
        gap: 10px;
    }
    .pv-subcats--carousel .pv-subcats__card {
        width: 33vw;
        min-width: 110px;
        max-width: 140px;
    }
    .pv-subcats--grid .pv-subcats__track {
        gap: 12px;
        row-gap: 18px;
    }
    .pv-subcats--grid .pv-subcats__card {
        width: calc((100% - 12px) / 2); /* 2 колонки */
        max-width: none;
    }
    .pv-subcats__name {
        font-size: 13px;
        margin-top: 8px;
    }
}

/* ─── Видео товара (на карточке товара, поверх главного изображения) ───── */

/*
 * Родительская тема рендерит галерею как .product-gallery со swiper'ом.
 * Главный слайд — .swiper-slide внутри первого swiper'а. Вешаем класс
 * has-pv-video на саму .product-gallery и позиционируем кнопку абсолютно
 * внутри неё. На single product блок галереи занимает левую колонку.
 */
.product-gallery.has-pv-video,
figure.thumbnail.has-pv-video {
    position: relative;
}
/* В карточках контактов figure — обёртка изображения; overflow: hidden
   нужен чтобы оверлей с видео не вылезал за скругления, если они есть. */
figure.thumbnail.has-pv-video {
    overflow: hidden;
}

/*
 * Круглая белая кнопка play в левом верхнем углу галереи.
 *
 * Архитектура анимаций:
 * - .pv-video-play — базовый круг без анимаций.
 * - ::before — треугольник play (внутренняя иконка).
 * - ::after — зарезервирован под декоративное кольцо/волны в
 *   модификаторах.
 * - .pv-video-play--<style> — модификатор, включающий конкретную
 *   анимацию. Стиль берётся из data-атрибута `data-pv-play-style`
 *   на data-блоке [data-pv-product-video] (задаётся плагином из
 *   настройки IG → Общее → Товары → «Кнопка видео товара»).
 *
 * Важно: те же стили продублированы в AdminModule::page_general()
 * для живого превью в админке. При правке этих блоков — синхронизируй
 * с админ-CSS (ищи в AdminModule секцию "pv-play-preview").
 */
.pv-video-play {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 10;
    width: 54px;  /* 64 → 54 (−15%) */
    height: 54px;
    border-radius: 50%;
    background: #ffffff;
    border: none;
    padding: 0;
    cursor: pointer;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.pv-video-play:hover,
.pv-video-play:focus {
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    transform: scale(1.12);
    outline: none;
}
/*
 * Треугольник play через CSS-border. Для вариантов кроме dashed-ring
 * — чёрный цвет. В варианте dashed-ring треугольник заменяется
 * градиентным (border стирается, а сам треугольник рисуется через
 * background + clip-path — см. ниже).
 */
.pv-video-play::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    margin-left: 3px; /* оптическая коррекция */
    border-style: solid;
    border-width: 10px 0 10px 15px;
    border-color: transparent transparent transparent #222;
    transform-origin: 40% 50%;
}

/*
 * ── Вариант 1: dashed-ring — кружащийся белый пунктир вокруг +
 *    треугольник внутри с анимированным зелёным градиентом.
 *
 * Градиент реализован так: ::before превращается в прямоугольный блок
 * с linear-gradient из оттенков зелёного, а затем обрезается в форму
 * треугольника через clip-path: polygon. Анимация двигает
 * background-position, создавая эффект «перетекания» цветов.
 * «Дыхание» (pulse-scale) убрано по запросу.
 */
.pv-video-play--dashed-ring::after {
    content: '';
    position: absolute;
    top: -9px;
    right: -9px;
    bottom: -9px;
    left: -9px;
    border: 2px dashed #ffffff;
    border-radius: 50%;
    pointer-events: none;
    animation: pv-play-spin 6s linear infinite;
}
.pv-video-play--dashed-ring::before {
    /* Больше не треугольник через border, а div с фоном+clip-path */
    width: 17px;
    height: 20px;
    border: none;
    margin-left: 3px;
    background: linear-gradient(
        135deg,
        #c5e1a5 0%,
        #8bc34a 20%,
        #4caf50 40%,
        #2e7d32 60%,
        #4caf50 80%,
        #8bc34a 100%
    );
    background-size: 300% 300%;
    -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    animation: pv-play-gradient 3s ease-in-out infinite;
}

/* ── Вариант 2: pulse-waves — расходящиеся волны через box-shadow ── */
.pv-video-play--pulse-waves {
    animation: pv-play-waves 2.2s ease-out infinite;
}

/* ── Вариант 3: bounce — кнопка подпрыгивает ── */
.pv-video-play--bounce {
    animation: pv-play-bounce 1.6s ease-in-out infinite;
}

/* ── Вариант 4: glow — пульсирующее белое свечение ── */
.pv-video-play--glow {
    animation: pv-play-glow 2s ease-in-out infinite;
}

/* ── Вариант 5: static — без анимации (ничего не добавляем) ── */

@keyframes pv-play-spin {
    to { transform: rotate(360deg); }
}
@keyframes pv-play-pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.18); }
}
@keyframes pv-play-gradient {
    0%   { background-position:   0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position:   0% 50%; }
}
@keyframes pv-play-waves {
    0% {
        box-shadow:
            0 2px 10px rgba(0,0,0,.18),
            0 0 0 0   rgba(255,255,255,.85),
            0 0 0 0   rgba(255,255,255,.55);
    }
    70% {
        box-shadow:
            0 2px 10px rgba(0,0,0,.18),
            0 0 0 18px rgba(255,255,255,0),
            0 0 0 34px rgba(255,255,255,0);
    }
    100% {
        box-shadow:
            0 2px 10px rgba(0,0,0,.18),
            0 0 0 18px rgba(255,255,255,0),
            0 0 0 34px rgba(255,255,255,0);
    }
}
@keyframes pv-play-bounce {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-8px); }
}
@keyframes pv-play-glow {
    0%, 100% {
        box-shadow:
            0 2px 10px rgba(0,0,0,.18),
            0 0 0 0 rgba(255,255,255,.7);
    }
    50% {
        box-shadow:
            0 2px 10px rgba(0,0,0,.18),
            0 0 26px 10px rgba(255,255,255,.55);
    }
}

@media (prefers-reduced-motion: reduce) {
    .pv-video-play,
    .pv-video-play::before,
    .pv-video-play::after {
        animation: none !important;
    }
}

/* ─── Описание категории (iframe с noindex) ──────────────────────────── */

/*
 * Блок-обёртка вокруг iframe. Стартовая высота минимальная — JS подставит
 * реальную после получения postMessage от iframe-документа. Пока высота
 * не пришла, блок почти невидим — чтобы не прыгал layout.
 */
.pv-cat-desc {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 24px 0 0;
}
.pv-cat-desc__frame {
    display: block;
    width: 100% !important;
    max-width: 100%;
    min-height: 40px;
    border: 0;
    background: transparent;
    overflow: hidden;
}

/*
 * Родительская тема рендерит вкладки товара внутри .product-detail-tabs
 * (nav + content). Tab-pane по умолчанию может не иметь явной ширины —
 * форсируем 100% чтобы iframe внутри вкладки «Подробнее» занял всю
 * колонку.
 */
.product-detail-tabs .tab-content,
.product-detail-tabs-content,
.product-detail-tabs .tab-pane {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Блок внизу страницы категории */
.pv-cat-desc--archive {
    margin: 40px 0 20px;
    padding: 20px 22px;
    background: #f6f8f6;
    border: 1px solid #e1e7e1;
    border-radius: 6px;
}
.pv-cat-desc--archive .pv-cat-desc__frame {
    min-height: 60px;
}

/* Блок внутри вкладки «Подробнее» в товаре */
.pv-cat-desc--tab {
    margin: 0;
}

/*
 * Inline-режим на странице категории: описание выводится обычным HTML
 * (для индексации), без iframe. Типографика подогнана под остальной
 * контент темы — чтобы не выбивалось из общей ширины и стиля.
 */
.pv-cat-desc--inline .pv-cat-desc__inner {
    color: #333;
    font-size: 15px;
    line-height: 1.55;
}
.pv-cat-desc--inline .pv-cat-desc__inner > *:first-child { margin-top: 0; }
.pv-cat-desc--inline .pv-cat-desc__inner > *:last-child  { margin-bottom: 0; }
.pv-cat-desc--inline .pv-cat-desc__inner h1,
.pv-cat-desc--inline .pv-cat-desc__inner h2,
.pv-cat-desc--inline .pv-cat-desc__inner h3,
.pv-cat-desc--inline .pv-cat-desc__inner h4 {
    color: #222;
    line-height: 1.25;
    margin: 1.2em 0 .5em;
}
.pv-cat-desc--inline .pv-cat-desc__inner h2 { font-size: 1.35em; }
.pv-cat-desc--inline .pv-cat-desc__inner h3 { font-size: 1.15em; }
.pv-cat-desc--inline .pv-cat-desc__inner p  { margin: 0 0 .9em; }
.pv-cat-desc--inline .pv-cat-desc__inner ul,
.pv-cat-desc--inline .pv-cat-desc__inner ol { margin: 0 0 .9em; padding-left: 1.4em; }
.pv-cat-desc--inline .pv-cat-desc__inner img,
.pv-cat-desc--inline .pv-cat-desc__inner video,
.pv-cat-desc--inline .pv-cat-desc__inner iframe { max-width: 100%; height: auto; }
.pv-cat-desc--inline .pv-cat-desc__inner a { color: #2e7d32; text-decoration: underline; }
.pv-cat-desc--inline .pv-cat-desc__inner a:hover { text-decoration: none; }

/* Вставленный <video> занимает всё место изображения */
.pv-video-player {
    display: block;
    width: 100%;
    height: auto;
    max-height: 100%;
    background: #000;
}

/* Когда видео играет — прячем кнопку play */
.product-gallery.pv-video-active .pv-video-play,
figure.thumbnail.pv-video-active .pv-video-play {
    display: none;
}
/* Оверлей с видео поверх слайда */
.pv-video-overlay {
    position: absolute;
    inset: 0;
    z-index: 9;
    background: #000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pv-video-overlay video {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: #000;
}

/* Popup-режим: модальное окно поверх всей страницы.
   Активируется опцией «Открывать в попапе» в IG → Общее → Товары.
   Оверлей прикрепляется к <body>, а не к контейнеру товара/карточки,
   поэтому overflow:hidden у предков не обрезает его. */
.pv-video-overlay--popup {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0, 0, 0, 0.88);
    padding: 4vh 4vw;
    box-sizing: border-box;
    animation: pv-video-popup-in 0.18s ease-out;
}
/* Stage — обёртка вокруг видео: даёт якорь для крестика у угла видео,
   а не у края вьюпорта. Сам stage шринкается под реальный размер видео
   благодаря inline-flex + max-width/height. */
.pv-video-overlay--popup .pv-video-popup-stage {
    position: relative;
    display: inline-flex;
    max-width: 100%;
    max-height: 100%;
    line-height: 0;
}
.pv-video-overlay--popup video {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    background: #000;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.55);
    display: block;
}
.pv-video-overlay--popup .pv-video-close {
    top: 10px;
    right: 10px;
    width: 38px;
    height: 38px;
    z-index: 12;
}
@keyframes pv-video-popup-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
body.pv-video-popup-open {
    overflow: hidden;
}

/* Кнопка «крестик» — закрыть видео и вернуться к галерее */
.pv-video-close {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 11;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.92);
    border: none;
    padding: 0;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease, transform 0.15s ease;
}
.pv-video-close:hover,
.pv-video-close:focus {
    background: #ffffff;
    transform: scale(1.08);
    outline: none;
}
.pv-video-close::before,
.pv-video-close::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 2px;
    background: #222;
    border-radius: 1px;
}
.pv-video-close::before { transform: rotate(45deg); }
.pv-video-close::after  { transform: rotate(-45deg); }

@media (max-width: 575px) {
    .pv-video-play {
        width: 44px;  /* 52 → 44 (−15%) */
        height: 44px;
        /* Отступ от краёв 14px — чтобы пунктирное кольцо (::after, −9px по
           всем сторонам) не заходило за края картинки/карточки магазина. */
        top: 14px;
        left: 14px;
    }
    .pv-video-play::before {
        border-width: 8px 0 8px 13px;
    }
    .pv-video-play--dashed-ring::before {
        width: 14px;
        height: 16px;
        border: none;
    }
}

/* ═══════════════════════════════════════════════════════════════
   Блок «Новости» на главной (inc/news-block.php)
   ═══════════════════════════════════════════════════════════════ */
.pv-news-section .pv-news-card__thumb {
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    background: #f3f3f3;
    aspect-ratio: 16 / 10;
}
.pv-news-section .pv-news-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.pv-news-section .pv-news-card__thumb:hover img {
    transform: scale(1.03);
}
.pv-news-section .pv-news-card__thumb-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #aaa;
    font-size: 14px;
}
.pv-news-section .pv-news-card__title {
    margin: 0;
    line-height: 1.3;
}
.pv-news-section .pv-news-card__title a {
    text-decoration: none;
}
.pv-news-section .pv-news-card__title a:hover {
    color: #4caf50;
}

/* ═══════════════════════════════════════════════════════════════
   Рендер block-editor контента (lms-block-*) на одиночной новости
   Классы совпадают с теми, что генерирует admin/assets/block-editor.js
   в плагине pervocvet-custom (скопирован из pervocvet-lms).
   ═══════════════════════════════════════════════════════════════ */
.single-news .lms-block-text,
.single-news .lms-block-grid__cell {
    line-height: 1.75;
}
.single-news .lms-block-image {
    text-align: center;
    margin: 16px 0;
}
.single-news .lms-block-image img {
    max-width: 100%;
    height: auto;
    border-radius: 10px;
}
.single-news .lms-block-grid {
    display: grid;
    gap: 24px;
    align-items: start;
    margin: 16px 0;
}
.single-news .lms-block-grid--2 { grid-template-columns: 1fr 1fr; }
.single-news .lms-block-grid--3 { grid-template-columns: 1fr 1fr 1fr; }
.single-news .lms-block-grid__cell img {
    width: 100%;
    border-radius: 10px;
}
.single-news .lms-block-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px;
    margin: 16px 0;
}
.single-news .lms-block-gallery img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    border-radius: 8px;
    transition: transform .2s, box-shadow .2s;
}
.single-news .lms-block-gallery img:hover {
    transform: scale(1.03);
    box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.single-news hr.lms-block-divider {
    border: none;
    border-top: 2px solid #e3e3e3;
    margin: 24px 0;
}
@media (max-width: 600px) {
    .single-news .lms-block-grid--2,
    .single-news .lms-block-grid--3 { grid-template-columns: 1fr; }
    .single-news .lms-block-gallery { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); }
    .single-news .lms-block-gallery img { height: 100px; }
}

/* ─── Непокупаемый товар в Typesense-карточке ────────────────────────────── */
/* JS заменяет кнопку «Купить» на активную «Связаться», открывающую попап
   темы (тот же, что у «Купить в 1 клик»). Заявка с попапа уходит через
   CF7-форму, адрес менеджера задан в настройках формы CF7.
   См. child-main.js, блок «Подмена кнопки "Купить" в Typesense-карточках». */

/* Активная кнопка-ссылка «Связаться с менеджером» (заменяет старую
   серую заглушку «Нет онлайн-продажи»). Применяется и в Typesense-
   подмене (replaceChild у штатной кнопки), и в десктопном стабе. */
.product-add-to-cart-btn.pv-purchase-contact {
    /* Наследует .btn .btn-primary от темы — зелёная заливка как у «Купить». */
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 40px;
    text-align: center;
    text-decoration: none;
    white-space: normal;
    line-height: 1.15;
    padding: 8px 6px;
    /* Длинное слово «менеджером» не должно ломаться посередине: переносим
       по пробелам, при необходимости переносим целое слово на новую
       строку, но без дефисов внутри слова. */
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: manual;
    font-size: 0.85rem;
}

.product-add-to-cart-btn.pv-purchase-contact:hover,
.product-add-to-cart-btn.pv-purchase-contact:focus {
    text-decoration: none;
    color: #fff;
}

/* Внутренний span — наследует centering от родителя. */
.product-add-to-cart-btn.pv-purchase-contact > span {
    display: inline-block;
    width: 100%;
    text-align: center;
    line-height: 1.15;
}

/* Мобила (< 576px): кнопка в карточке узкая (~140px), текст
   «Связаться с менеджером» в две строки. Уменьшаем шрифт и
   снимаем uppercase, чтобы строки помещались по ширине. */
@media (max-width: 575.98px) {
    .product-add-to-cart-btn.pv-purchase-contact {
        font-size: 0.72rem;
        padding: 6px 4px;
        min-height: 44px;
        text-transform: none;
        letter-spacing: 0;
    }
}

/* Десктоп: вставленная JS-кнопка на месте отсутствующей «В корзину».
   На ПК шаблон product-add-to-cart-simple при disable_buy=1 вообще не
   рендерит блок с кнопкой, поэтому JS вставляет свою «Связаться». */
.product-add-to-cart-btn.pv-purchase-contact--stub {
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 4px;
    margin-top: 8px;
}

/* В disable_buy-карточках Typesense штатная ссылка «Купить в 1 клик»
   (`.product-one-click`) рендерится как белая outline-кнопка под нашей
   зелёной «Связаться с менеджером» и визуально дублирует её — обе
   открывают один и тот же попап. Скрываем родную, чтобы кнопка была
   одна. На обычных (покупаемых) товарах ссылка остаётся на месте.

   ВАЖНО — ограничение скоупом карточки. Селектор `[data-ui-component="product"]`
   стоит и на карточках каталога, и на `<article>` single-product
   страницы (см. content-single-product.php parent-темы). PvPurchaseControl
   ставит `data-pv-purchase-disabled="1"` на любой такой элемент, и без
   ограничения здесь правило скрывало штатную `.product-one-click`
   на single-странице тоже — а это единственная кнопка на карточке
   товара (после переименования она и есть «Связаться с менеджером»),
   и у пользователя «кнопка появлялась → переименовывалась → исчезала».
   Привязываемся к `.product-item-vertical-*` — это контейнер именно
   карточек каталога, на single его нет. */
[data-pv-purchase-disabled="1"].product-item-vertical-v1 .product-one-click,
[data-pv-purchase-disabled="1"].product-item-vertical-v2 .product-one-click {
    display: none !important;
}

/* Анти-мерцание текста кнопки на single-disabled.
   Без этого: HTML приходит со словами «Купить в 1 клик», JS-блок rename
   на DOMContentLoaded переписывает на «Связаться с менеджером» — между
   первой отрисовкой и срабатыванием JS пользователь видит исходный
   текст (заметно на медленном мобильном).
   Body-class `pv-purchase-disabled-single` ставится PHP синхронно
   (см. ProductPurchaseControl::add_body_class), поэтому правило
   применяется до первой отрисовки.
   Подход: пока на ссылке нет `data-pv-renamed="1"` — делаем её
   `visibility: hidden` (место занято, layout стабилен, текст не виден).
   JS rename переписывает текст и ставит атрибут — ссылка проявляется
   уже с правильным «Связаться с менеджером». Без layout shift.
   `:not([data-pv-renamed="1"])` важен: после JS-переименования
   правило перестаёт действовать. */
body.pv-purchase-disabled-single .product-one-click:not([data-pv-renamed="1"]) {
    visibility: hidden !important;
}

/* На single товара с флагом `_pv_disable_buy` или disable_buy-категорией
   штатная `.product-one-click` остаётся на странице — её JS-блок rename
   переименовывает в «Связаться с менеджером». Скрываем только WC-плашку
   «Этот товар не может быть продан» (woocommerce-error /
   wc-block-components-notice), чтобы она не пугала пользователя. */
body.pv-purchase-disabled-single .single-product .woocommerce-error,
body.pv-purchase-disabled-single .single-product .woocommerce-info,
body.pv-purchase-disabled-single .single-product .woocommerce-message,
body.pv-purchase-disabled-single .wc-block-components-notice-banner.is-error {
    display: none !important;
}

/* Товар «нет в наличии» на single: прячем кнопку «Купить в 1 клик».
   Шаблон темы product-one-click/index.php рисует кнопку по
   is_purchasable() и не смотрит на наличие — outofstock-товар при прямом
   заходе по ссылке (из каталога он уже скрыт штатной WC-опцией
   «Скрывать товары не в наличии») показывал кнопку покупки.
   Body-class `pv-oos-single` ставит PHP синхронно
   (ProductPurchaseControl::add_body_class). Серверную is_purchasable() не
   трогаем — остаётся честный блок «Этого товара нет в наличии».
   `display:none` (не visibility) — кнопка не нужна вовсе, место под неё
   резервировать незачем. */
body.pv-oos-single .product-one-click {
    display: none !important;
}

/* Резерв места под кнопку «Связаться с менеджером» на страницах
   disable_buy-категорий. JS вставляет кнопку асинхронно (после AJAX-
   проверки), и без резерва высота карточек растёт уже во время скролла
   пользователя — получаем layout shift и «дёргающийся» скролл на мобиле.
   Флаг `data-pv-category-disabled` выставляется на <body> синхронно
   (см. child-main.js, PvPurchaseControl.isCurrentCategoryDisabled),
   поэтому высота резервируется до первой отрисовки карточек.

   Значение min-height совпадает с фактической высотой вставленной
   кнопки (.pv-purchase-contact на мобиле: min-height 44px + mt-1/2_5
   отступы у соседней ссылки «Купить в 1 клик»). */
[data-pv-category-disabled="1"] .product-item-vertical-v2 .d-lg-none.d-flex.flex-column.align-items-start,
[data-pv-category-disabled="1"] .product-item-vertical-v1 .d-md-none.d-flex.flex-column.align-items-start {
    min-height: 44px;
}

/* ═══════════════════════════════════════════════════════════════
   Валидация телефона на чекауте — красная рамка + сообщение под полем.
   JS в child-main.js вешает .pv-phone-invalid на сам input и
   .pv-phone-row-invalid + .woocommerce-invalid на .form-row / контейнер.
   ═══════════════════════════════════════════════════════════════ */

.pv-phone-invalid {
    border-color: #e74c3c !important;
    box-shadow: 0 0 0 2px rgba( 231, 76, 60, 0.15 ) !important;
}

.pv-phone-row-invalid input[type="tel"],
.pv-phone-row-invalid .form-control,
.pv-phone-row-invalid .woocommerce-input-wrapper input {
    border-color: #e74c3c !important;
    box-shadow: 0 0 0 2px rgba( 231, 76, 60, 0.15 ) !important;
}

.pv-phone-row-invalid label,
.pv-phone-row-invalid .float-label-text {
    color: #e74c3c !important;
}

.pv-phone-error {
    color: #e74c3c;
    font-size: 13px;
    line-height: 1.35;
    margin-top: 6px;
    display: block;
}

/* ═══════════════════════════════════════════════════════════════
   Боковая корзина (drawer) — Woodmart-style.
   Открывается при добавлении товара в корзину. Включается опцией
   pervocvet_side_cart_enabled (плагин pervocvet-custom).

   Структура (рендерится в SideCart::render_drawer):
   #pv-side-cart                       — корневой контейнер, position: fixed
     .pv-side-cart__overlay            — затемнение (клик закрывает)
     .pv-side-cart__panel              — выезжающая панель справа
       .pv-side-cart__header           — шапка с заголовком + крестик
       .pv-side-cart__body             — список товаров
         ul.pv-side-cart__list > li.pv-side-cart__item
       .pv-side-cart__footer           — подытог + кнопка оформления

   Открытие: на корне добавляется класс .pv-side-cart--open.
   ═══════════════════════════════════════════════════════════════ */

.pv-side-cart {
    position: fixed;
    inset: 0;
    z-index: 99998;
    visibility: hidden;
    pointer-events: none;
    /* visibility — со ступенькой: 0s при открытии (сразу видим),
       0.32s при закрытии (после окончания transition панели). */
    transition: visibility 0s linear 0.32s;
}
.pv-side-cart.pv-side-cart--open,
.pv-side-cart.pv-side-cart--closing {
    visibility: visible;
    pointer-events: auto;
}
.pv-side-cart.pv-side-cart--open {
    transition: visibility 0s linear 0s;
}

.pv-side-cart__overlay {
    position: absolute;
    inset: 0;
    background: rgba( 30, 30, 30, 0.55 );
    opacity: 0;
    transition: opacity 0.32s cubic-bezier( 0.22, 0.61, 0.36, 1 );
    cursor: pointer;
}
.pv-side-cart--open .pv-side-cart__overlay { opacity: 1; }

.pv-side-cart__panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: 460px;
    background: #fff;
    box-shadow: -8px 0 30px rgba( 0, 0, 0, 0.18 );
    transform: translateX( 100% );
    transition: transform 0.32s cubic-bezier( 0.22, 0.61, 0.36, 1 );
    display: flex;
    flex-direction: column;
    will-change: transform;
}
.pv-side-cart--open .pv-side-cart__panel { transform: translateX( 0 ); }

/* На мобиле ширина задаётся плагином через инлайн-CSS (опция в админке).
   Здесь только дефолт-фоллбек на случай, если опция не пришла. */
@media ( max-width: 575.98px ) {
    .pv-side-cart__panel { max-width: 80vw; width: 80vw; }
}

/* ── Header ── */
.pv-side-cart__header {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid #eee;
}
.pv-side-cart__title {
    margin: 0;
    font-size: 22px;
    font-weight: 700;
    color: #1d2327;
    line-height: 1.2;
}
.pv-side-cart__close {
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 6px 10px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #444;
    font-size: 15px;
    transition: color 0.2s;
}
.pv-side-cart__close:hover { color: #13a538; }
.pv-side-cart__close-icon {
    font-size: 22px;
    line-height: 1;
    font-weight: 400;
}

/* ── Body ── */
.pv-side-cart__body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 14px 18px;
    -webkit-overflow-scrolling: touch;
}
.pv-side-cart__empty {
    text-align: center;
    color: #888;
    padding: 60px 20px;
    font-size: 15px;
}

.pv-side-cart__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.pv-side-cart__item {
    display: flex;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid #f1f1f1;
}
.pv-side-cart__item:last-child { border-bottom: 0; }

.pv-side-cart__item-thumb {
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    border-radius: 6px;
    overflow: hidden;
    background: #f7f7f7;
}
.pv-side-cart__item-thumb img,
.pv-side-cart__item-thumb a {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pv-side-cart__item-main {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 8px;
}
.pv-side-cart__item-row-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}
.pv-side-cart__item-title {
    margin: 0;
    font-size: 14px;
    line-height: 1.35;
    font-weight: 500;
    color: #1d2327;
    word-break: break-word;
}
.pv-side-cart__item-title a {
    color: inherit;
    text-decoration: none;
}
.pv-side-cart__item-title a:hover { color: #13a538; }
.pv-side-cart__gift-badge {
    margin-left: 4px;
    font-size: 14px;
    vertical-align: middle;
}

.pv-side-cart__remove {
    flex: 0 0 auto;
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 4px;
    color: #999;
    line-height: 1;
    transition: color 0.2s, transform 0.15s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.pv-side-cart__remove svg {
    width: 18px;
    height: 18px;
    display: block;
}
.pv-side-cart__remove:hover {
    color: #e74c3c;
    transform: scale( 1.08 );
}

/* Pending-row (skeleton): пока летит AJAX add_to_cart — слегка пульсирует. */
.pv-side-cart__item--pending {
    animation: pv-pending-pulse 1.2s ease-in-out infinite;
}
@keyframes pv-pending-pulse {
    0%,100% { opacity: 1; }
    50%     { opacity: 0.55; }
}
.pv-side-cart__item--pending .pv-side-cart__item-thumb {
    background: linear-gradient( 90deg, #efefef 0%, #f7f7f7 50%, #efefef 100% );
    background-size: 200% 100%;
    animation: pv-skeleton-shine 1.4s linear infinite;
}
@keyframes pv-skeleton-shine {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.pv-side-cart__item-row-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

/* ── Quantity ± controls ── */
.pv-side-cart__qty {
    display: inline-flex;
    align-items: stretch;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    background: #fff;
    overflow: hidden;
    height: 28px;
}
.pv-side-cart__qty-btn {
    background: transparent;
    border: 0;
    cursor: pointer;
    width: 26px;
    font-size: 16px;
    color: #444;
    line-height: 1;
    transition: background 0.2s;
}
.pv-side-cart__qty-btn:hover {
    background: #f3f3f3;
    color: #13a538;
}
.pv-side-cart__qty-input {
    width: 36px;
    border: 0;
    border-left: 1px solid #e0e0e0;
    border-right: 1px solid #e0e0e0;
    text-align: center;
    font-size: 14px;
    color: #1d2327;
    background: #fff;
    -moz-appearance: textfield;
    padding: 0;
}
.pv-side-cart__qty-input::-webkit-outer-spin-button,
.pv-side-cart__qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.pv-side-cart__qty-input:focus { outline: 0; }

.pv-side-cart__qty--locked {
    border-color: transparent;
    background: transparent;
    padding: 0 4px;
    color: #888;
    font-size: 13px;
}
.pv-side-cart__qty-static {
    display: inline-block;
    line-height: 28px;
}

.pv-side-cart__item-price {
    font-size: 14px;
    font-weight: 600;
    color: #13a538;
    white-space: nowrap;
}
.pv-side-cart__item-qty-x {
    color: #888;
    font-weight: 400;
    margin-right: 2px;
}
.pv-side-cart__item--gift .pv-side-cart__item-price {
    color: #13a538;
    font-style: italic;
}
.pv-side-cart__item-free {
    color: #13a538;
    font-style: italic;
}

/* ── Footer ── */
.pv-side-cart__footer {
    flex: 0 0 auto;
    border-top: 1px solid #eee;
    padding: 18px 22px;
    background: #fff;
    position: relative; /* якорь для absolute-кнопки «Свернуть» — над чертой */
}
.pv-side-cart__subtotal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    font-size: 15px;
    gap: 10px;
}
.pv-side-cart__subtotal-label {
    color: #444;
    font-weight: 500;
}
.pv-side-cart__subtotal-value {
    color: #13a538;
    font-weight: 700;
    font-size: 20px;
}

/* Кнопка «Свернуть» — visualно ВЫШЕ разделительной черты footer'а.
   Footer-блок имеет border-top, и нам нужно «приподнять» кнопку над ним
   на её собственную высоту + небольшой отступ. position:absolute по
   правому краю, bottom:100% (от верха footer'а), чуть-чуть отрицательный
   transform — и кнопка сидит вплотную над чертой. */
.pv-side-cart__collapse-row {
    position: absolute;
    right: 22px;
    bottom: 100%;
    margin-bottom: 10px;
    z-index: 2;
    pointer-events: none; /* чтобы клики мимо кнопки шли в body */
}
.pv-side-cart__collapse-row .pv-side-cart__collapse {
    pointer-events: auto;
}
.pv-side-cart__collapse {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 40px;
    padding: 0 16px;
    background: #f3f5f7;
    color: #444;
    border: 0;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: background .15s, color .15s, transform .1s;
}
.pv-side-cart__collapse:hover {
    background: #e6ebef;
    color: #13a538;
}
.pv-side-cart__collapse:active { transform: scale( 0.97 ); }
.pv-side-cart__collapse-text {
    display: inline-block;
}
.pv-side-cart__collapse svg {
    width: 18px;
    height: 18px;
    display: block;
    flex: 0 0 auto;
}

.pv-side-cart__checkout-btn {
    display: block;
    width: 100%;
    text-align: center;
    background: #8bc34a;
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    padding: 14px 20px;
    border-radius: 6px;
    border: 0;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s;
}
.pv-side-cart__checkout-btn:hover {
    background: #13a538;
    color: #fff;
}
.pv-side-cart__checkout-btn:active { transform: scale( 0.99 ); }
.pv-side-cart__checkout-btn--disabled {
    background: #d0d0d0 !important;
    pointer-events: none;
    cursor: not-allowed;
}

/* ── Loading state на body во время AJAX ── */
.pv-side-cart__body.pv-side-cart__body--loading {
    opacity: 0.5;
    pointer-events: none;
}

/* На время первого открытия — слегка спрятать pre-баг отрисовки */
html.pv-side-cart-locked,
html.pv-side-cart-locked body {
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════
   Чекаут — иконка способа оплаты в одну строку с названием.
   Шаблон parent-темы payment-method.php кладёт `.products-payments-list-item-title`
   и `.products-payments-list-item-icon` рядом внутри
   `.products-payments-list-item-header`. По дефолту обе — inline-`<span>`,
   и крупная иконка YooKassa уезжает на вторую строку.
   Ставим контейнеру inline-flex с центрированием и ограничиваем высоту
   иконки строкой, чтобы она шла справа от названия как на втором скрине.
   ═══════════════════════════════════════════════════════════════ */

.products-payments-list-item-header {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.products-payments-list-item-icon {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}
.products-payments-list-item-icon img,
.products-payments-list-item-icon svg {
    max-height: 22px;
    width: auto;
    vertical-align: middle;
    display: inline-block;
}

/* ═══════════════════════════════════════════════════════════════
   CheckoutCart — qty +/− и иконка удаления на странице оформления
   заказа. Рендерится модулем pervocvet-custom\Frontend\CheckoutCart
   плюс JS-декоратор в child-main.js. Стилизуем для:
   - левой колонки .checkout-product-item (parent-tema markup)
   - правой колонки .pv-checkout-cart-list (наш markup в review-order)
   ═══════════════════════════════════════════════════════════════ */

/* ── Левая колонка: контролы qty/remove поверх parent-tema markup ──
   Layout правого блока (.ml-lg-2_5):
     [строка 1]  цена  •  🗑
     [строка 2]  − N +
   Достигается заменой содержимого .ml-lg-2_5 на два контейнера
   (.pv-co-price-row + .pv-co-qty-row) в JS-декораторе. */

.pv-co-price-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-bottom: 8px;
}
.pv-co-price-wrap {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}
.pv-co-qty-row {
    display: flex;
    justify-content: flex-end;
}

/* Степпер qty (− N +) */
.pv-co-qty {
    display: inline-flex;
    align-items: center;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    overflow: hidden;
    background: #fff;
    user-select: none;
}
.pv-co-qty-btn {
    width: 32px;
    height: 32px;
    border: 0;
    background: transparent;
    color: #444;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    transition: background .12s, color .12s;
}
.pv-co-qty-btn:hover { background: #f3f5f7; color: #13a538; }
.pv-co-qty-btn:active { transform: scale( 0.94 ); }
.pv-co-qty-value {
    min-width: 30px;
    text-align: center;
    font-size: 14px;
    font-weight: 600;
    color: #222;
    padding: 0 6px;
}

/* Иконка-корзина (удалить) — компактная, прямо за ценой */
.pv-co-remove {
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid #e8e8e8;
    border-radius: 6px;
    background: #fff;
    color: #888;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    transition: color .12s, background .12s, border-color .12s, transform .1s;
}
.pv-co-remove:hover {
    color: #e74c3c;
    background: rgba( 231, 76, 60, 0.06 );
    border-color: rgba( 231, 76, 60, 0.3 );
    transform: scale( 1.04 );
}
.pv-co-remove svg { width: 17px; height: 17px; display: block; }
.pv-co-gift-badge { display: inline-block; margin-left: 4px; }

/* Фоллбек — если по какой-то причине .ml-lg-2_5 не нашёлся в строке */
.checkout-product-item .pv-co-controls {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    margin-top: 8px;
}

/* Перестройка правой части .checkout-product-item:
   parent-tema даёт .d-flex.justify-content-lg-between с двумя детьми —
   слева заголовок, справа блок цены (.ml-lg-2_5).
   Нам нужно чтобы блок цены не сжимался и расположение цена/qty/корзина
   шло в две строки по правому краю. */
.checkout-product-item.pv-checkout-item-decorated > .d-flex.justify-content-lg-between {
    align-items: flex-start;
    flex-wrap: nowrap;
}
.checkout-product-item.pv-checkout-item-decorated .ml-lg-2_5 {
    margin-left: auto !important;
    text-align: right;
    flex-shrink: 0;
}
/* На мобиле (где parent ставит flex-column) — держим контролы справа,
   не давая им уехать под текст. */
@media ( max-width: 991.98px ) {
    .checkout-product-item.pv-checkout-item-decorated > .d-flex.justify-content-lg-between {
        flex-direction: row !important;
    }
    .checkout-product-item.pv-checkout-item-decorated .ml-lg-2_5 {
        margin-left: 8px !important;
    }
}

/* Сжатый layout на мобиле — иначе цена + 🗑 + степпер не влезают в правую
   колонку и иконки заходят за край контейнера parent-tema (см. скриншот
   с опрыскивателями). Уменьшаем размеры контролов и шрифт цены. */
@media ( max-width: 575.98px ) {
    /* Цена parent-темы в .ml-lg-2_5 — поджимаем чуть-чуть */
    .checkout-product-item.pv-checkout-item-decorated .ml-lg-2_5 .font-weight-medium {
        font-size: 13px;
    }
    .pv-co-price-row {
        gap: 6px;
        margin-bottom: 6px;
    }
    .pv-co-remove {
        width: 28px;
        height: 28px;
    }
    .pv-co-remove svg { width: 15px; height: 15px; }

    .pv-co-qty-btn {
        width: 28px;
        height: 28px;
        font-size: 16px;
    }
    .pv-co-qty-value {
        min-width: 24px;
        font-size: 13px;
        padding: 0 4px;
    }
}

/* Loading-state — пока летит AJAX */
.pv-co-loading {
    opacity: 0.55;
    pointer-events: none;
    transition: opacity .15s;
}

/* ── Правая колонка: read-only «состав заказа» в review-order ──
   Никаких qty/remove — это просто сводка для подтверждения. Управление
   количеством — слева, в order-split. */
.pv-checkout-cart-row > td.pv-checkout-cart-row__td {
    padding: 0 0 12px 0 !important;
    border: 0;
}
.pv-checkout-cart-list {
    list-style: none;
    margin: 0 0 6px 0;
    padding: 0;
}
.pv-checkout-cart-list__item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 0;
    border-bottom: 1px dashed #ececec;
}
.pv-checkout-cart-list__item:last-child { border-bottom: 0; }
.pv-checkout-cart-list__title {
    flex: 1 1 auto;
    font-size: 14px;
    color: #222;
    line-height: 1.35;
    font-weight: 500;
}
.pv-checkout-cart-list__meta {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    text-align: right;
    min-width: 72px;
}
.pv-checkout-cart-list__qty-label {
    font-size: 12px;
    color: #888;
}
.pv-checkout-cart-list__price {
    font-size: 14px;
    font-weight: 600;
    color: #222;
    white-space: nowrap;
}
.pv-checkout-cart-list__free {
    color: #13a538;
    font-weight: 600;
    font-size: 13px;
}
.pv-checkout-cart-list__gift-badge { margin-left: 4px; }
.pv-checkout-cart-list__item--gift .pv-checkout-cart-list__price { color: #13a538; font-weight: 600; }

/* ═══════════════════════════════════════════════════════════════
   Login popup — модалка «У вас уже есть аккаунт» на checkout.
   Показывается, когда юзер не залогинен и ввёл email,
   принадлежащий существующему пользователю.
   ═══════════════════════════════════════════════════════════════ */

.pv-login-modal {
    position: fixed;
    inset: 0;
    z-index: 100100;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.pv-login-modal.pv-login-modal--open { display: flex; }
.pv-login-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba( 30, 36, 44, 0.55 );
    backdrop-filter: blur( 2px );
}
.pv-login-modal__panel {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: 12px;
    padding: 28px 24px 24px;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 18px 50px -12px rgba( 0, 0, 0, 0.35 );
    animation: pv-login-modal-in .2s ease-out;
}
@keyframes pv-login-modal-in {
    from { opacity: 0; transform: translateY( 12px ) scale( 0.98 ); }
    to   { opacity: 1; transform: translateY( 0 )   scale( 1 ); }
}
.pv-login-modal__close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 36px;
    height: 36px;
    border: 0;
    background: transparent;
    color: #888;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    border-radius: 50%;
    transition: background .12s, color .12s;
}
.pv-login-modal__close:hover { background: #f3f5f7; color: #222; }
.pv-login-modal__title {
    font-size: 19px;
    font-weight: 700;
    color: #222;
    margin: 0 0 8px;
}
.pv-login-modal__text {
    font-size: 14px;
    color: #555;
    margin: 0 0 16px;
    line-height: 1.45;
}
.pv-login-modal__email {
    font-weight: 600;
    color: #13a538;
    word-break: break-all;
}
.pv-login-modal__field {
    display: block;
    margin-bottom: 12px;
}
.pv-login-modal__label {
    display: block;
    font-size: 13px;
    color: #555;
    margin-bottom: 6px;
}
.pv-login-modal__input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid #d8d8d8;
    border-radius: 8px;
    font-size: 15px;
    color: #222;
    background: #fff;
    transition: border-color .12s, box-shadow .12s;
}
.pv-login-modal__input:focus {
    outline: 0;
    border-color: #13a538;
    box-shadow: 0 0 0 3px rgba( 19, 165, 56, 0.15 );
}
.pv-login-modal__error {
    display: none;
    margin: -4px 0 12px;
    padding: 8px 12px;
    background: rgba( 231, 76, 60, 0.08 );
    color: #c0392b;
    border-radius: 6px;
    font-size: 13px;
}
.pv-login-modal__error.pv-login-modal__error--visible { display: block; }
.pv-login-modal__submit {
    width: 100%;
    padding: 14px 16px;
    background: #13a538;
    color: #fff;
    border: 0;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .12s, transform .1s;
    margin-bottom: 8px;
}
.pv-login-modal__submit:hover { background: #0e8a2e; }
.pv-login-modal__submit:active { transform: scale( 0.99 ); }
.pv-login-modal__submit:disabled { background: #aac9b3; cursor: not-allowed; }
.pv-login-modal__guest-btn {
    width: 100%;
    padding: 12px 16px;
    background: #fff;
    color: #444;
    border: 1px solid #d0d6db;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background .12s, border-color .12s, color .12s;
    margin-top: 4px;
    margin-bottom: 6px;
}
.pv-login-modal__guest-btn:hover {
    background: #f3f5f7;
    border-color: #b8c0c7;
    color: #222;
}
.pv-login-modal__links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}
.pv-login-modal__link {
    font-size: 13px;
    color: #555;
    text-decoration: none;
    border-bottom: 1px dashed #aaa;
    background: transparent;
    border-top: 0;
    border-left: 0;
    border-right: 0;
    padding: 0;
    cursor: pointer;
    transition: color .12s, border-color .12s;
}
.pv-login-modal__link:hover { color: #13a538; border-color: #13a538; }
html.pv-login-modal-locked,
html.pv-login-modal-locked body { overflow: hidden; }

/* Перебиваем правило parent-темы insteria, скрывающее строку доставки
   в таблице review-order. Без этого `tr.shipping` (Доставка по Кирову — 400 ₽)
   не показывается на странице оформления заказа. */
.woocommerce-checkout-review-order-table tr.shipping {
    display: table-row !important;
}

/* ═══════════════════════════════════════════════════════════════
   CHECKOUT: sticky сайдбар с итогами на десктопе
   ═══════════════════════════════════════════════════════════════
   Правая колонка (карточка «Ваш заказ» + Итого) прилипает к верху
   при скролле, чтобы клиент видел сумму и стоимость доставки, пока
   заполняет адрес. Mobile (sm/md) — стандартный поток, sticky отключён.
*/
@media (min-width: 992px) {
    form.checkout > #customer_details > .col-xxl-4.col-xl-5.col-lg-6 {
        position: sticky;
        top: 100px;
        align-self: flex-start;
        z-index: 1;
    }
}


/* ─────────────────────────────────────────────────────────────────
   Yandex Pay: возврат штатной кнопки «Оформить заказ»
   ─────────────────────────────────────────────────────────────────
   Плагин yandex-pay-and-split.css прячет #place_order через
   `.yandex-pay-and-split_button_container ~ button[name=...]`, и
   SDK не снимает этот класс при unmount() виджета. Когда выбран
   НЕ-Yandex способ оплаты (cod / yookassa / любой другой) — body
   НЕ имеет класса .pv-payment-yandex-active, и мы перекрываем
   правило плагина с !important. Селектор по name + #place_order —
   жёстче исходного, плюс !important для гарантии.
   Body-класс ставится в child-main.js (секция Yandex Pay button
   container fix). */
/* ── Yandex Pay container HIDE-BY-DEFAULT (без скоупа на body
   .woocommerce-checkout — иногда этот класс не выставлен,
   а нам важно чтобы контейнер был скрыт всегда по умолчанию) ── */
#yandex-pay-and-split-button-container {
    display: none !important;
}

/* Показываем YPay-контейнер только когда выбран Yandex-метод. */
body.pv-payment-yandex-active #yandex-pay-and-split-button-container {
    display: block !important;
}

/* Когда Yandex-метод НЕ выбран — force-показываем штатную кнопку.
   Без этого плагинский CSS .yandex-pay-and-split_button_container ~
   button[name=...] продолжает её прятать (SDK навешивает класс на
   контейнер при init и не снимает после unmount). */
body:not(.pv-payment-yandex-active) #place_order,
body:not(.pv-payment-yandex-active)
    button[type='submit'][name='woocommerce_checkout_place_order'] {
    display: inline-block !important;
}

/* Когда Yandex-метод ВЫБРАН — прячем штатную зелёную кнопку.
   Плагинский CSS делает это сам через `.woocommerce .yandex-pay-and-
   split_button_container ~ button[name=...]`, но требует ancestor
   `.woocommerce`. В V2-шаблоне такого ancestor НЕТ (форма имеет
   `.woocommerce-checkout`, но не `.woocommerce`), поэтому плагинское
   правило не срабатывает и обе кнопки рендерятся одновременно. */
body.pv-payment-yandex-active #place_order,
body.pv-payment-yandex-active
    button[type='submit'][name='woocommerce_checkout_place_order'] {
    display: none !important;
}

/* ─── Кастомный Plus-бейдж в каталоге/single (YandexPayBadges) ─── */

/* Wrap бейджей в каталоге/single — column-flex, чтобы Сплит-бейдж и наш
 * Plus-бейдж шли отдельными строками друг под другом (как на референсе
 * pay.yandex.ru/demo). Конкретное значение gap приходит из админки
 * через inline-style (badgesGap), здесь fallback. */
.pv-ypay-badges {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

/* Plus-плашка — компактная инлайн-строчка с оригинальной Yandex Plus иконкой
 * и текстом «N баллов Плюса». Self-rendered, не зависит от Yandex SDK.
 * font-family — стек как у Yandex SDK (для визуального совпадения шрифта
 * с соседним Сплит-бейджем, который рендерится через web-component внутри
 * Shadow DOM с YS Text/system-ui). */
.pv-ypay-plus-custom {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    line-height: 1.2;
    color: #1f1f1f;
    white-space: nowrap;
    font-family: -apple-system, BlinkMacSystemFont, 'YS Text', 'Segoe UI',
                 system-ui, Helvetica, Arial, sans-serif;
    font-weight: 400;
}

/* Размер иконки задаётся inline через style="width:Npx;height:Npx" из админки. */
.pv-ypay-plus-custom__icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.pv-ypay-plus-custom__icon svg {
    display: block;
    width: 100%;
    height: 100%;
}

.pv-ypay-plus-custom__text {
    font-weight: 500;
}

/* api_yandex — чистый <img> с эндпоинта /api/v2/badge?type=ultimate.
 * Yandex отдаёт горизонтальную композицию (иконка + цифра + текст) как SVG. */
.pv-ypay-plus-custom--api_yandex {
    padding: 0;
}

.pv-ypay-plus-custom__api-img {
    display: block;
    height: auto;
    width: auto;
    max-width: 100%;
}

/* pill-стиль (как на cvety.ru): розовая обводка с числом, потом текст рядом. */
.pv-ypay-plus-custom__pill {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 1px 7px;
    border: 1.5px solid #EB469F;
    border-radius: 999px;
    color: #EB469F;
    font-weight: 700;
    line-height: 1.2;
}

.pv-ypay-plus-custom__pill-plus {
    font-weight: 700;
    margin-right: 1px;
}

.pv-ypay-plus-custom__pill-num {
    font-weight: 700;
}

/* На single — крупнее, чтобы соответствовать BNPL-бейджу size=m. */
.pv-ypay-badges--single .pv-ypay-plus-custom {
    gap: 8px;
}

/* ============================================================================
   Прелоадер: индикатор загрузки страниц (полоска прогресса вверху)
   Управляется тумблером IG → Кэширование → «Индикатор загрузки страниц»
   (window.PvPreloader.enabled). Появляется при клике по внутренней ссылке,
   исчезает вместе со страницей при загрузке следующей. Чистый CSS-анимация,
   без библиотек. См. блок Preloader в child-main.js.
   ============================================================================ */
#pv-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    z-index: 2147483647;        /* поверх всего, включая попапы темы */
    background: #13a538;        /* фирменный зелёный (COLOR_GREEN) */
    box-shadow: 0 0 8px rgba( 19, 165, 56, .6 );
    opacity: 0;
    pointer-events: none;
    transition: width .25s ease-out, opacity .3s ease;
    will-change: width, opacity;
}
#pv-progress-bar.pv-progress-active {
    opacity: 1;
}
@media ( prefers-reduced-motion: reduce ) {
    #pv-progress-bar { transition: opacity .2s ease; }
}

