/* ─── Переменные ────────────────────────────────────────────────────────────── */

:root {
    --gpp-gold:    #8a6f3e;
    --gpp-gold-l:  #a8884f;
    --gpp-dark:    #1a1412;
    --gpp-mid:     #6b5c4e;
    --gpp-border:  #e0d5c8;
    --gpp-bg:      #faf8f5;
    --gpp-serif:   'Cormorant Garamond', 'Georgia', serif;
    --gpp-sans:    'Jost', 'Inter', sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500&display=swap');

/* ─── Product layout: 2 колонки ─────────────────────────────────────────────── */
/* Тема Avanam: #wrap-summary содержит .product-images + .summary в строку.
   Меняем любой flex/block на grid с нужными пропорциями. */

.single-product #wrap-summary,
.single-product .wrap-summary {
    display: grid !important;
    grid-template-columns: 55fr 45fr !important;
    gap: 0 56px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Gallery — левая колонка */
.single-product .base-product-image-wrap.product-images,
.single-product .product-images {
    grid-column: 1 !important;
    grid-row: 1 !important;
    position: sticky !important;
    top: 90px;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
}

/* Summary — правая колонка */
.single-product .summary.entry-summary {
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    padding: 0 !important;
}

/* Сброс inline max-width на галерее от темы */
.single-product .product_image {
    max-width: 100% !important;
    width: 100% !important;
}

/* ─── Gallery (наш рендер вместо темовой Splide) ─────────────────────────── */

.gpp-gallery {
    width: 100%;
    max-width: 600px;
}

.gpp-gallery__main {
    position: relative;
    background: var(--gpp-bg);
    aspect-ratio: 1 / 1;
    overflow: hidden;
    margin-bottom: 12px;
    cursor: zoom-in;
    border: 1px solid var(--gpp-border);
}

.gpp-gallery__main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    transition: transform .4s ease;
}

.gpp-gallery__main:hover .gpp-gallery__main-img {
    transform: scale(1.05);
}

.gpp-gallery__thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.gpp-gallery__thumb {
    width: 72px;
    height: 72px;
    background: var(--gpp-bg);
    border: 2px solid transparent;
    padding: 0;
    cursor: pointer;
    overflow: hidden;
    flex-shrink: 0;
    transition: border-color .15s;
}

.gpp-gallery__thumb.is-active {
    border-color: var(--gpp-gold);
}

.gpp-gallery__thumb:hover:not(.is-active) {
    border-color: var(--gpp-border);
}

.gpp-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

/* Гасим всю исходную тёмовую разметку галереи (если не успели отключить). */
.single-product .base-product-image-wrap .ksk-gallery,
.single-product .zoomContainer,
.single-product .zoomLens,
.single-product .zoomWindow {
    display: none !important;
}

/* ─── Lightbox ────────────────────────────────────────────────────────────── */

.gpp-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.92);
    z-index: 99999;
    display: none;
    align-items: center;
    justify-content: center;
}

.gpp-lightbox.is-open {
    display: flex;
}

.gpp-lightbox__img {
    max-width: 92vw;
    max-height: 92vh;
    object-fit: contain;
    user-select: none;
    -webkit-user-drag: none;
}

.gpp-lightbox__close,
.gpp-lightbox__nav {
    position: absolute;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: #fff;
    cursor: pointer;
    font-family: inherit;
    line-height: 1;
    transition: background 0.15s;
}

.gpp-lightbox__close:hover,
.gpp-lightbox__nav:hover {
    background: rgba(255, 255, 255, 0.2);
}

.gpp-lightbox__close {
    top: 20px;
    right: 20px;
    width: 44px;
    height: 44px;
    font-size: 28px;
    border-radius: 50%;
}

.gpp-lightbox__nav {
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    font-size: 36px;
    border-radius: 50%;
}

.gpp-lightbox__nav--prev { left: 20px; }
.gpp-lightbox__nav--next { right: 20px; }

.gpp-lightbox.is-single .gpp-lightbox__nav,
.gpp-lightbox.is-single .gpp-lightbox__counter {
    display: none;
}

.gpp-lightbox__counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
    background: rgba(0, 0, 0, 0.5);
    padding: 6px 14px;
    border-radius: 999px;
}

/* ─── Collection лейбл ───────────────────────────────────────────────────────── */

.gpp-collection {
    margin-bottom: 8px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 11px;
    font-family: var(--gpp-sans);
}

.gpp-collection a {
    color: var(--gpp-gold);
    text-decoration: none;
}

.gpp-collection a:hover {
    text-decoration: underline;
}

/* ─── Заголовок и цена ───────────────────────────────────────────────────────── */

.single-product .product_title.entry-title {
    font-family: var(--gpp-serif) !important;
    font-size: 32px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    color: var(--gpp-dark) !important;
    margin-bottom: 12px !important;
}

.single-product .wrap_price_rating .price,
.single-product .price {
    font-family: var(--gpp-serif) !important;
    font-size: 26px !important;
    font-weight: 400 !important;
    color: var(--gpp-dark) !important;
    letter-spacing: 0.02em;
}

.single-product .price del {
    color: var(--gpp-mid) !important;
    font-size: 18px !important;
    margin-right: 8px;
}

/* Короткое описание */
.woocommerce-product-details__short-description {
    font-family: var(--gpp-sans);
    font-size: 14px;
    color: var(--gpp-mid);
    line-height: 1.7;
    margin-bottom: 20px;
}

/* ─── Cart: qty + Add to Cart в строку, Customize аккордеон ниже ────────────── */

.single-product form.cart {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    gap: 10px !important;
    margin-bottom: 0 !important;
}

/* Скрываем totals внутри form.cart */
.single-product form.cart > .tc-totals-form,
.single-product form.cart .tc-epo-totals {
    display: none !important;
}

/* tc-extra-product-options и все обёртки — display:contents, чтобы h2 и тело
   аккордеона стали прямыми flex-детьми form.cart */
.single-product form.cart > .tc-extra-product-options,
.single-product form.cart .tc-extra-product-options > ul,
.single-product form.cart .tc-extra-product-options > ul > li,
.single-product form.cart .tc-extra-product-options .cpf-section,
.single-product form.cart .tc-extra-product-options .tc-section-inner-wrap,
.single-product form.cart .tc-extra-product-options .tc-row.tm-collapse {
    display: contents !important;
}

/* Сброс фоновых стилей на промежуточных обёртках на всякий случай */
.single-product form.cart .tc-extra-product-options *:not(input):not(select):not(textarea):not(button):not(.tm-collapse-wrap):not(h2):not(.tm-arrow):not(label):not(.tc-section-label-text) {
    background: transparent;
}

/* Количество */
.single-product form.cart .quantity {
    order: -1;
    flex: 0 0 auto;
    display: flex;
    align-items: center;
}

.single-product form.cart .quantity input.qty {
    width: 58px !important;
    height: 50px !important;
    text-align: center;
    border: 1px solid var(--gpp-border) !important;
    border-radius: 2px !important;
    font-family: var(--gpp-sans);
    font-size: 15px;
    background: #fff;
}

/* Кнопка Add to Cart */
.single-product .single_add_to_cart_button.button,
.single-product button.single_add_to_cart_button {
    flex: 1 !important;
    height: 50px !important;
    background: var(--gpp-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 2px !important;
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    padding: 0 20px !important;
    white-space: nowrap;
    box-shadow: none !important;
}

.single-product .single_add_to_cart_button.button:hover,
.single-product button.single_add_to_cart_button:hover {
    background: var(--gpp-gold-l) !important;
}

/* ─── TM EPO Accordion: Customize ───────────────────────────────────────────── */

/* Заголовок-кнопка: "Customize" с шевроном — рядом с Add to Cart */
.single-product form.cart h2.tm-section-label,
.single-product form.cart .tm-section-label.tm-toggle {
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 50px !important;
    margin: 0 !important;
    padding: 0 18px !important;
    border: 1px solid var(--gpp-gold) !important;
    border-radius: 2px !important;
    background: transparent !important;
    color: var(--gpp-gold) !important;
    font-family: var(--gpp-sans) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: background 0.2s, color 0.2s !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
    order: 2 !important;
}

.single-product form.cart h2.tm-section-label:hover,
.single-product form.cart .tm-section-label.tm-toggle:hover {
    background: var(--gpp-gold) !important;
    color: #fff !important;
}

/* Текст внутри h2 */
.single-product .tc-extra-product-options .tc-section-label-text {
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    letter-spacing: inherit !important;
    text-transform: inherit !important;
    color: inherit !important;
}

/* Стрелка-шеврон */
.single-product .tc-extra-product-options .tm-arrow {
    transition: transform 0.25s ease !important;
    font-size: 14px !important;
}

.single-product .tc-extra-product-options h2[aria-expanded="true"] .tm-arrow {
    transform: rotate(180deg) !important;
}

/* Контейнер тела аккордеона — отдельной строкой во flex-row form.cart */
.single-product form.cart .tc-section-fields {
    flex: 0 0 100% !important;
    width: 100% !important;
    order: 99 !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
}

/* Когда аккордеон закрыт — скрываем весь слот, чтобы не было пустого ряда */
.single-product form.cart .tc-section-fields:has(.tm-collapse-wrap.closed) {
    display: none !important;
}

/* Закрытое состояние */
.single-product .tc-extra-product-options .tm-collapse-wrap.closed {
    display: none !important;
}

/* Открытое состояние */
.single-product .tc-extra-product-options .tm-collapse-wrap {
    width: 100% !important;
    margin-top: 6px !important;
    padding: 18px 20px !important;
    background: var(--gpp-bg) !important;
    border: 1px solid var(--gpp-border) !important;
    border-radius: 2px !important;
    box-sizing: border-box !important;
}

/* Поля формы внутри аккордеона */
.single-product .tc-extra-product-options .tm-epo-element-label,
.single-product .tc-extra-product-options .tc-epo-element-label-text,
.single-product .tc-extra-product-options .tc-label-wrap {
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--gpp-mid) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
}

.single-product .tc-extra-product-options input.tmcp-textfield,
.single-product .tc-extra-product-options input[type="text"].tmcp-field,
.single-product .tc-extra-product-options select.tmcp-field,
.single-product .tc-extra-product-options textarea.tmcp-field {
    width: 100% !important;
    height: 40px !important;
    padding: 8px 12px !important;
    border: 1px solid var(--gpp-border) !important;
    border-radius: 2px !important;
    background: #fff !important;
    font-family: var(--gpp-sans) !important;
    font-size: 14px !important;
    color: var(--gpp-dark) !important;
    box-sizing: border-box !important;
}

.single-product .tc-extra-product-options textarea.tmcp-field {
    height: auto !important;
    min-height: 80px !important;
}

/* ─── Font preview блок ─────────────────────────────────────────────────────── */

.gpp-font-preview {
    margin-top: 0;
    padding: 8px 12px;
    background: #fff;
    border: 1px dashed var(--gpp-gold);
    border-radius: 2px;
    width: 100%;
    box-sizing: border-box;
}

.gpp-font-preview__label {
    font-family: var(--gpp-sans);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--gpp-mid);
    margin-bottom: 6px;
}

.gpp-font-preview__text {
    font-size: 28px;
    line-height: 1.2;
    color: var(--gpp-dark);
    word-break: break-word;
    min-height: 1.2em;
}

/* Чекбоксы / радио — горизонтальная раскладка */
.single-product .tc-extra-product-options .tmcp-ul-wrap.tm-extra-product-options-checkbox,
.single-product .tc-extra-product-options .tmcp-ul-wrap.tm-extra-product-options-radio {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Отступы между полями */
.single-product .tc-extra-product-options .cpf-element {
    margin-bottom: 14px !important;
}

.single-product .tc-extra-product-options .cpf-element:last-child {
    margin-bottom: 0 !important;
}

/* ─── Social row ─────────────────────────────────────────────────────────────── */

.gpp-social {
    display: flex;
    border: 1px solid var(--gpp-border);
    border-radius: 2px;
    margin: 16px 0;
    overflow: hidden;
}

.gpp-soc {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 11px 8px;
    font-family: var(--gpp-sans);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--gpp-mid);
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
    border-right: 1px solid var(--gpp-border);
}

.gpp-soc:last-child {
    border-right: none;
}

.gpp-soc:hover {
    background: var(--gpp-bg);
    color: var(--gpp-gold);
}

/* ─── Secure Payment (sp-secure) ─────────────────────────────────────────────── */

.sp-secure {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 0;
    border-top: 1px solid #e8e8e8;
    border-bottom: 1px solid #e8e8e8;
    margin: 16px 0;
    flex-direction: column;
}

.sp-secure__title {
    font-size: 14px;
    font-weight: 700;
    color: #111;
    margin-bottom: 1px;
}

.sp-secure__sub {
    font-size: 12px;
    color: #999;
}

.sp-secure__icons {
    display: flex;
    gap: 6px;
    align-items: center;
}

.sp-secure__icon {
    height: auto;
    border: 0;
    border-radius: 4px;
    padding: 3px 6px;
    background: #fff;
    display: flex;
    align-items: center;
    width: 48px;
}

.sp-secure__icon svg {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 600px) {
    .sp-secure__icons {
        width: 100%;
        gap: 4px;
    }
    .sp-secure__icon {
        flex: 1;
        padding: 2px;
    }
    .sp-secure__icon svg {
        width: 100%;
        height: auto;
    }
}

/* ─── About This Piece + Specifications ─────────────────────────────────────── */

.gpp-desc-section {
    padding: 48px 0 32px;
    border-top: 1px solid var(--gpp-border);
    margin-top: 48px;
    clear: both;
}

.gpp-desc-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 56px;
    align-items: start;
}

.gpp-desc-full {
    grid-template-columns: 1fr;
}

.gpp-section-heading {
    font-family: var(--gpp-serif) !important;
    font-size: 26px !important;
    font-weight: 400 !important;
    color: var(--gpp-dark) !important;
    margin-bottom: 18px !important;
    letter-spacing: 0.02em;
}

.gpp-desc-text {
    font-family: var(--gpp-sans);
    font-size: 15px;
    color: var(--gpp-mid);
    line-height: 1.8;
}

.gpp-desc-text p {
    margin-bottom: 14px;
}

/* ─── Specs ──────────────────────────────────────────────────────────────────── */

.gpp-specs-right {
    background: var(--gpp-bg);
    border: 1px solid var(--gpp-border);
    border-radius: 2px;
    padding: 24px 20px;
}

.gpp-spec-table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--gpp-sans);
    font-size: 13px;
}

.gpp-spec-table tr {
    border-bottom: 1px solid var(--gpp-border);
}

.gpp-spec-table tr:last-child {
    border-bottom: none;
}

.gpp-spec-table td {
    padding: 11px 0;
    line-height: 1.4;
    vertical-align: top;
}

.gpp-spec-table td:first-child {
    color: var(--gpp-mid);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 11px;
    width: 42%;
    padding-right: 12px;
}

.gpp-spec-table td:last-child {
    color: var(--gpp-dark);
    font-weight: 500;
}

/* ─── Скрываем стандартные WC tabs ──────────────────────────────────────────── */

.single-product .woocommerce-tabs {
    display: none !important;
}

/* ─── Related products — 4 колонки ──────────────────────────────────────────── */

.related.products {
    padding-top: 40px;
    border-top: 1px solid var(--gpp-border);
    margin-top: 32px;
    clear: both;
}

.related.products > h2 {
    font-family: var(--gpp-serif) !important;
    font-size: 26px !important;
    font-weight: 400 !important;
    color: var(--gpp-dark) !important;
    margin-bottom: 24px !important;
}

.related.products ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
}

.related.products ul.products li.product .woocommerce-LoopProduct-link img,
.related.products ul.products li.product a img {
    aspect-ratio: 4 / 5;
    object-fit: cover;
    width: 100%;
    border: 1px solid var(--gpp-border);
    border-radius: 2px;
}

.related.products ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--gpp-serif) !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--gpp-dark) !important;
    margin-top: 10px !important;
}

.related.products ul.products li.product .price {
    font-size: 14px !important;
    color: var(--gpp-gold) !important;
}

/* ─── Каталог: квадратные превью 1:1 ────────────────────────────────────────── */
/* Архив магазина / категории / метки. Не трогает .related.products
   на странице товара — там другой body-класс и своё соотношение 4/5. */

.post-type-archive-product ul.products li.product img,
.tax-product_cat ul.products li.product img,
.tax-product_tag ul.products li.product img,
.woocommerce.archive ul.products li.product img {
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    border: 1px solid var(--gpp-border);
    border-radius: 2px;
}

/* ─── Скрываем блоки темы которые дублируют наши ────────────────────────────── */

/* Тема: Wishlist / Ask Us / Share */
.single-product .wrap_after_button {
    display: none !important;
}

/* Тема: viewers counter (отдельный блок) */
.single-product #tmcore-live-viewing-visitors,
.single-product .tmcore-live-viewing-visitors {
    display: none !important;
}

/* Тема: urgency (sold in last N hours, in cart) */
.single-product .tmcore-scroll,
.single-product .check-incart-sold {
    display: none !important;
}

/* Тема: payment icons fieldset */
.single-product fieldset.single-product-payments {
    display: none !important;
}

/* WooCommerce: View Basket после Add to Cart */
.single-product a.added_to_cart,
.single-product a.added_to_cart.wc-forward,
.single-product .summary a.added_to_cart,
.single-product form.cart a.added_to_cart {
    display: none !important;
}

/* ─── Mobile ─────────────────────────────────────────────────────────────────── */

@media (max-width: 960px) {

    .single-product #wrap-summary,
    .single-product .wrap-summary {
        grid-template-columns: 1fr !important;
        gap: 24px 0 !important;
    }

    .single-product .base-product-image-wrap.product-images,
    .single-product .product-images {
        grid-column: 1 !important;
        grid-row: 1 !important;
        position: static !important;
    }

    .single-product .summary.entry-summary {
        grid-column: 1 !important;
        grid-row: 2 !important;
    }

    .gpp-desc-grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .related.products ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .single-product form.cart {
        flex-wrap: wrap !important;
    }

    .single-product button.tm-section-link,
    .single-product .button.tm-section-link {
        flex: 1 1 calc(50% - 5px) !important;
    }

    .single-product form.cart .single_add_to_cart_button.button,
    .single-product form.cart h2.tm-section-label,
    .single-product form.cart .tm-section-label.tm-toggle {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
}

@media (max-width: 480px) {

    .single-product .product_title.entry-title {
        font-size: 24px !important;
    }

    .single-product button.tm-section-link,
    .single-product .button.tm-section-link,
    .single-product .single_add_to_cart_button.button {
        flex: 1 1 100% !important;
    }
}

/* ─── Customize: вкладки + блоки + блокировка (gpp.js) ──────────────────────── */
/* Фон у наших div переопределяем !important — выше есть общее правило,
   делающее прозрачными все .tc-extra-product-options *. */

.single-product .gpp-cz-tabs {
    display: flex !important;
    gap: 0 !important;
    margin: 4px 0 18px !important;
    border-bottom: 1px solid var(--gpp-border) !important;
}

.single-product .gpp-cz-tab {
    flex: 1 1 auto;
    background: transparent !important;
    border: none !important;
    border-bottom: 2px solid transparent !important;
    margin: 0 0 -1px 0 !important;
    padding: 12px 14px !important;
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: var(--gpp-mid) !important;
    cursor: pointer !important;
    box-shadow: none !important;
    transition: color 0.2s, border-color 0.2s !important;
}

.single-product .gpp-cz-tab:hover { color: var(--gpp-dark) !important; }

.single-product .gpp-cz-tab.is-active {
    color: var(--gpp-gold) !important;
    border-bottom-color: var(--gpp-gold) !important;
}


/* TM EPO аккордеон ставит фиксированную высоту (JS-анимация) и не растёт
   под контент → UPLOAD/SAVE вылезали за пределы блока. Открытый аккордеон
   всегда по контенту. */
.single-product .tc-extra-product-options .tm-collapse-wrap:not(.closed) {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}
/* Вкладка "Your own design" — минимальная высота блока */
.single-product .tc-extra-product-options.gpp-mode-own .tm-collapse-wrap:not(.closed) {
    min-height: 400px !important;
}

/* Блок без рамки. Заголовок на всю ширину; ниже: картинка слева | поля справа.
   Чекбокс — отдельной строкой на всю ширину. */
.single-product .gpp-cz-block {
    display: grid !important;
    grid-template-columns: 20% 75% !important;
    column-gap: 24px !important;
    row-gap: 0 !important;
    align-items: start !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 22px 0 !important;
    margin: 0 !important;
}
.single-product .gpp-cz-block + .gpp-cz-block {
    border-top: 1px solid var(--gpp-border) !important;
}

.single-product .gpp-cz-thumb {
    grid-column: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    background: #fff !important;
    border: 1px solid var(--gpp-border) !important;
    border-radius: 2px !important;
    padding: 6px !important;
    margin: 0 !important;
}

.single-product .gpp-cz-thumb img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 160 / 110;
    object-fit: contain;
}

/* Поля — правая колонка, столбиком с равными отступами (чтобы SAVE не налезал) */
.single-product .gpp-cz-block__body {
    grid-column: 2 !important;
    min-width: 0;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}
.single-product .gpp-cz-block__body > * { margin: 0 !important; }

/* Чекбокс RIGHT SIDE SAME LIKE LEFT SIDE — отдельной строкой на всю ширину */
.single-product .gpp-cz-block > .gpp-cz-fullrow {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    margin: 18px 0 0 !important;
}

/* Заголовок блока — на всю ширину сверху; все блоки одного размера */
.single-product .gpp-cz-block > .gpp-cz-head {
    grid-column: 1 / -1 !important;
    margin: 0 0 16px !important;
    padding: 0 !important;
    font-family: var(--gpp-sans) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--gpp-dark) !important;
    line-height: 1.25 !important;
}
/* Родной header-элемент прячем — заголовок рисуем сами (.gpp-cz-head) */
.single-product .gpp-cz-srchead { display: none !important; }

/* Лейбл lead-поля (его текст = заголовок блока) прячем */
.single-product .gpp-cz-block .cpf-type-textfield.gpp-cz-lead .tm-epo-element-label {
    display: none !important;
}

/* Под-группы внутри header-блока (Left / Right) */
.single-product .gpp-cz-subgroup {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}
.single-product .gpp-cz-hidden { display: none !important; }

/* TM EPO внутри блока — его flex-сетка (.tc-row = flex+wrap+order, лейбл —
   <h2> с дефолтными margin) ломала ширину и отступ. Разворачиваем в простой
   блок: лейбл и поле — на всю ширину, друг под другом, вплотную. */
.single-product .gpp-cz-block .tc-element-inner-wrap,
.single-product .gpp-cz-block .tc-row,
.single-product .gpp-cz-block .tc-element-container,
.single-product .gpp-cz-block .tmcp-ul-wrap,
.single-product .gpp-cz-block .tmcp-ul-wrap > li.tmcp-field-wrap {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

/* Лейбл поля (LEFT / SELECT FONT) — блок, вплотную над полем */
.single-product .gpp-cz-block .tm-epo-element-label,
.single-product .gpp-cz-block .tc-epo-label {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 4px !important;
    padding: 0 !important;
    text-align: left !important;
}
.single-product .gpp-cz-block .gpp-cz-subfield .tm-epo-element-label,
.single-product .gpp-cz-block .cpf-type-select .tm-epo-element-label {
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--gpp-mid) !important;
}

/* Строка инпут+цена остаётся flex: инпут тянется, $100 у правого края */
.single-product .gpp-cz-block .tmcp-field-wrap-inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
}
.single-product .gpp-cz-block .tmcp-field-wrap-inner > .tm-epo-field-label {
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}
.single-product .gpp-cz-block .tmcp-field-wrap-inner > .tc-price-wrap {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
}
.single-product .gpp-cz-block input.tmcp-textfield,
.single-product .gpp-cz-block select.tmcp-field,
.single-product .gpp-cz-block select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

.single-product .gpp-cz-actions {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    margin-top: 14px !important;
}

.single-product .gpp-cz-save,
.single-product .gpp-cz-edit {
    height: 38px !important;
    padding: 0 22px !important;
    border-radius: 2px !important;
    font-family: var(--gpp-sans) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    box-shadow: none !important;
    transition: background 0.2s, color 0.2s !important;
}

.single-product .gpp-cz-save {
    background: var(--gpp-gold) !important;
    color: #fff !important;
    border: 1px solid var(--gpp-gold) !important;
}
.single-product .gpp-cz-save:hover { background: var(--gpp-gold-l) !important; border-color: var(--gpp-gold-l) !important; }

.single-product .gpp-cz-edit {
    background: transparent !important;
    color: var(--gpp-gold) !important;
    border: 1px solid var(--gpp-gold) !important;
}
.single-product .gpp-cz-edit:hover { background: var(--gpp-gold) !important; color: #fff !important; }

.single-product .gpp-cz-save[hidden],
.single-product .gpp-cz-edit[hidden] { display: none !important; }

/* Заблокированный блок: визуально «заперт», значения остаются и уходят в заказ */
.single-product .gpp-cz-block.is-locked {
    background: #f3efe9 !important;
}
.single-product .gpp-cz-block.is-locked .gpp-cz-block__body input,
.single-product .gpp-cz-block.is-locked .gpp-cz-block__body textarea {
    background: #efe9e0 !important;
    color: var(--gpp-mid) !important;
    cursor: not-allowed !important;
}
.single-product .gpp-cz-block .gpp-lock {
    pointer-events: none !important;
    opacity: 0.65 !important;
}

/* Вкладка "Your own design": интро-текст + превью загруженного */
.single-product .gpp-cz-own-intro {
    margin: 0 0 18px !important;
}
.single-product .gpp-cz-own-intro p {
    margin: 0 0 6px !important;
    font-family: var(--gpp-serif) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    color: var(--gpp-mid) !important;
}
.single-product .gpp-cz-own-intro p:last-child { margin-bottom: 0 !important; }

/* Переключение вкладок: режим-класс на root, элементы НЕ двигаем */
.single-product .gpp-cz-root.gpp-mode-design .gpp-cz-ownel { display: none !important; }
.single-product .gpp-cz-root.gpp-mode-own   .gpp-cz-block  { display: none !important; }
.single-product .gpp-cz-own-preview.is-empty { display: none !important; }
/* "RIGHT SIDE SAME LIKE LEFT SIDE" отмечен → блок RIGHT скрыт полностью */
.single-product .gpp-cz-block.gpp-cz-hidden { display: none !important; }

/* Upload (TM EPO): "UPLOAD DESIGN" отдельной строкой-заголовком сверху,
   кнопка под ним. Внутреннюю раскладку виджета (.cpf-upload-container)
   НЕ трогаем — из-за этого элементы наезжали. */
.single-product .cpf-type-multiple_file_upload .tc-row {
    flex-direction: column !important;
    align-items: stretch !important;
}
.single-product .cpf-type-multiple_file_upload .tm-epo-element-label {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 auto !important;
    margin: 0 0 14px !important;
    text-align: left !important;
}
.single-product .cpf-type-multiple_file_upload .tc-epo-element-label-text {
    font-family: var(--gpp-sans) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    color: var(--gpp-dark) !important;
    line-height: 1.25 !important;
}
.single-product .cpf-type-multiple_file_upload .cpf-upload-text {
    font-size: 14px !important;
    line-height: 1.2 !important;
}
.single-product .cpf-type-multiple_file_upload .tc-max-file-size {
    display: block !important;
    clear: both !important;
    margin: 12px 0 0 !important;
}

.single-product .gpp-cz-own-preview {
    margin-top: 18px !important;
    padding-top: 16px !important;
    border-top: 1px solid var(--gpp-border) !important;
}

.single-product .gpp-cz-own-preview__label {
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: var(--gpp-gold) !important;
    margin-bottom: 12px !important;
}

.single-product .gpp-cz-own-preview__grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.single-product .gpp-cz-own-preview__item {
    width: 100% !important;
    background: #fff !important;
    border: 1px solid var(--gpp-border) !important;
    border-radius: 2px !important;
    padding: 6px !important;
    display: block !important;
    overflow: hidden;
}
.single-product .gpp-cz-own-preview__item img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}
.single-product .gpp-cz-own-preview__item.is-file {
    font-family: var(--gpp-sans) !important;
    font-size: 12px !important;
    color: var(--gpp-mid) !important;
    text-align: center;
    word-break: break-word;
    padding: 14px 10px !important;
}

@media (max-width: 600px) {
    /* Узкий экран: картинка сверху, поля под ней */
    .single-product .gpp-cz-block {
        grid-template-columns: 1fr !important;
    }
    .single-product .gpp-cz-thumb {
        max-width: 220px !important;
        margin: 0 0 14px !important;
    }
    .single-product .gpp-cz-block__body {
        grid-column: 1 !important;
    }
    .single-product .gpp-cz-tab {
        font-size: 11px !important;
        padding: 11px 8px !important;
    }
}
