/* Piemont — конструктор ціни будинку. Преміум-стиль: paper, gold #C9A96E, bronze CTA #ad7d41. */
.pm-cfg {
    --cfg-ink: #1b1b1e;
    --cfg-mut: #6b6b66;
    --cfg-gold: #C9A96E;
    --cfg-line: #e7e3da;
    --cfg-bronze: #ad7d41;
    max-width: 1320px;   /* як на головній (per UX 2026-05-31) */
    margin: 0 auto;
    padding: 56px 24px;
    font-family: var(--pm-ff-body, "Involve", sans-serif);   /* наш шрифт (per UX 2026-05-31) */
    color: var(--cfg-ink);
}
.pm-cfg__head { text-align: center; margin-bottom: 32px; }
.pm-cfg__overline { display: block; color: var(--cfg-gold); letter-spacing: 0.22em; text-transform: uppercase; font-size: 12px; font-weight: 600; }
.pm-cfg__title { font-family: var(--pm-ff-heading, "Bounded", Georgia, serif); font-weight: 400; font-size: clamp(26px, 3vw, 38px); margin: 10px 0 8px; }
.pm-cfg__lede { color: var(--cfg-mut); margin: 0; }

/* Текст шапки секції — білий (фон секції буде темним; scope щоб перебити .piemont-theme h2/p — per UX 2026-06-01) */
.pm-cfg .pm-cfg__title,
.pm-cfg .pm-cfg__lede,
.pm-cfg .pm-cfg__plot-label { color: #fff; }

.pm-cfg__grid { display: grid; grid-template-columns: 1fr 340px; gap: 28px; align-items: start; }

/* ── Пакети ── */
.pm-cfg__packages { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 26px; }
.pm-cfg__pkg {
    display: flex; flex-direction: column; gap: 4px; text-align: left;
    padding: 16px 18px; border: 1.5px solid var(--cfg-line); border-radius: 14px; background: #fff;
    cursor: pointer; transition: border-color .15s ease, box-shadow .15s ease;
}
.pm-cfg__pkg:hover { border-color: var(--cfg-gold); }
.pm-cfg__pkg.is-active { border-color: var(--cfg-bronze); box-shadow: 0 0 0 2px rgba(173,125,65,.18); }
.pm-cfg__pkg-name { font-weight: 600; font-size: 16px; }
.pm-cfg__pkg-desc { font-size: 12.5px; color: var(--cfg-mut); line-height: 1.35; }

/* ── Опції ── */
.pm-cfg__options-title { font-size: 14px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cfg-mut); margin: 0 0 12px; font-weight: 600; }
.pm-cfg__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pm-cfg__opt label { display: flex; align-items: center; gap: 14px; padding: 12px 16px; border: 1px solid var(--cfg-line); border-radius: 12px; cursor: pointer; background: #fff; transition: border-color .15s ease, background .15s ease; }
.pm-cfg__opt label:hover { border-color: var(--cfg-gold); }
.pm-cfg__opt-input { position: absolute; opacity: 0; width: 0; height: 0; }
.pm-cfg__opt-box { flex: 0 0 auto; width: 22px; height: 22px; border: 1.5px solid #cfcabd; border-radius: 6px; position: relative; transition: background .15s ease, border-color .15s ease; }
.pm-cfg__opt-input:checked + .pm-cfg__opt-box { background: var(--cfg-bronze); border-color: var(--cfg-bronze); }
.pm-cfg__opt-input:checked + .pm-cfg__opt-box::after { content: ""; position: absolute; left: 7px; top: 3px; width: 5px; height: 10px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.pm-cfg__opt-input:focus-visible + .pm-cfg__opt-box { outline: 2px solid var(--cfg-bronze); outline-offset: 2px; }
.pm-cfg__opt-text { display: flex; flex-direction: column; gap: 2px; flex: 1 1 auto; }
.pm-cfg__opt-name { font-size: 15px; font-weight: 500; }
.pm-cfg__opt-note { color: var(--cfg-mut); font-weight: 400; }
.pm-cfg__opt-price { font-size: 13px; color: var(--cfg-mut); }
.pm-cfg__opt-price small { color: var(--cfg-bronze); }

/* ── Підсумок ── */
.pm-cfg__summary { position: sticky; top: 90px; }
.pm-cfg__summary-inner { border: 1px solid var(--cfg-line); border-radius: 16px; padding: 22px; background: #fafaf7; box-shadow: 0 18px 48px rgba(27,27,30,.08); }
.pm-cfg__sum-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cfg-mut); }
.pm-cfg__sum-base { display: block; font-size: 22px; font-weight: 600; margin: 2px 0 14px; }
.pm-cfg__sum-list { list-style: none; margin: 0 0 14px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pm-cfg__sum-list:empty { display: none; }
.pm-cfg__sum-list li { display: flex; justify-content: space-between; gap: 12px; font-size: 13.5px; color: var(--cfg-mut); border-bottom: 1px dashed var(--cfg-line); padding-bottom: 8px; }
.pm-cfg__sum-list li span:last-child { color: var(--cfg-ink); font-weight: 500; white-space: nowrap; }
.pm-cfg__sum-total-row { display: flex; justify-content: space-between; align-items: baseline; padding-top: 12px; border-top: 2px solid var(--cfg-ink); margin-bottom: 18px; }
.pm-cfg__sum-total-row > span:first-child { font-size: 14px; text-transform: uppercase; letter-spacing: 0.08em; }
.pm-cfg__sum-total { font-size: 28px; font-weight: 700; color: var(--cfg-ink); }
.pm-cfg__cta { display: flex; justify-content: center; width: 100%; }
.pm-cfg__note { font-size: 11.5px; color: var(--cfg-mut); text-align: center; margin: 12px 0 0; }

@media (max-width: 900px) {
    .pm-cfg { padding: 40px 0; }
    .pm-cfg__grid { grid-template-columns: 1fr; gap: 22px; }
    .pm-cfg__summary { position: static; }
    .pm-cfg__packages { grid-template-columns: 1fr; }
}

/* ───────────── Калькулятор оплати ───────────── */
.pm-pay {
    --cfg-ink: #1b1b1e; --cfg-mut: #6b6b66; --cfg-gold: #C9A96E; --cfg-line: #e7e3da; --cfg-bronze: #ad7d41;
    position: relative;
    max-width: 760px; margin: 0 auto; padding: 32px 0 56px; font-family: var(--pm-ff-body, "Involve", sans-serif); color: var(--cfg-ink);   /* +20px відступ зверху перед оплатою (UX 2026-06-01) */
}
.pm-pay__head { text-align: center; margin-bottom: 22px; }
.pm-pay__overline { display: block; color: var(--cfg-gold); letter-spacing: 0.22em; text-transform: uppercase; font-size: 12px; font-weight: 600; }
.pm-pay__title { font-family: var(--pm-ff-heading, "Bounded", Georgia, serif); font-weight: 400; font-size: clamp(24px, 2.6vw, 32px); margin: 10px 0 6px; }
.pm-pay__lede { color: var(--cfg-mut); margin: 0; }
/* На темному/фото-фоні блоку — світліший лід (UX 2026-06-01) */
.pm-cot-block--on-dark .pm-pay__lede { color: rgba(255,255,255,0.8); }
.pm-cot-block--on-dark .pm-pay__lede .pm-pay__lede-price { color: #fff; }
/* «Вартість для розрахунку» — тонка лінія-рядок (label … ціна), без важкого бокса (UX 2026-05-31) */
.pm-pay__price-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 4px 4px 19px; background: transparent; border: 0; border-bottom: 1px solid var(--cfg-line); border-radius: 0; margin-bottom: 18px; }  /* +5px відступ до лінії (UX 2026-06-01) */
.pm-pay__price-row > span:first-child { color: var(--cfg-mut); font-size: 14px; }
.pm-pay__price { font-size: 22px; font-weight: 700; white-space: nowrap; }
.pm-pay__tabs { display: flex; gap: 10px; margin-bottom: 18px; }
/* Назва табу — основний шрифт (Involve), нормальний міжсимвольний інтервал (Bounded давав широкий трекінг — UX 2026-06-01) */
.pm-pay__tab { flex: 1 1 0; display: flex; flex-direction: column; gap: 2px; align-items: center; padding: 12px 10px; border: 1.5px solid var(--cfg-line); border-radius: 12px; background: #fff; cursor: pointer; color: #1b1b1e; font-family: var(--pm-ff-body, "Involve", sans-serif); font-size: 15px; font-weight: 600; letter-spacing: normal; transition: border-color .15s ease, box-shadow .15s ease; }
/* підзаголовок табу (напр. «0% · до етапів будівництва») — body-шрифт як у «Перший внесок», читабельніше */
.pm-pay__tab small { font-family: var(--pm-ff-body, "Involve", sans-serif); }
.pm-pay__tab small { font-weight: 400; font-size: 12px; color: var(--cfg-mut); line-height: 1.35; }
/* При наведенні — золотіє НАЗВА табу (головний рядок), не підзаголовок (UX 2026-06-01) */
.pm-pay__tab:hover { border-color: var(--cfg-gold); color: #946834; }   /* темніший бронзовий текст (UX 2026-06-01) */
/* Активний таб — 2px золота обводка + темно-бронзова назва (читабельніше) + ледь золотистий фон (UX 2026-06-01) */
.pm-pay__tab.is-active { border: 2px solid var(--cfg-gold); color: #946834; background: #fefcf8; box-shadow: 0 0 0 3px rgba(201,169,110,.10); }
.pm-pay__tab.is-active small { color: #946834; }
/* більше простору всередині + 30px відступ над панеллю (UX 2026-05-31) */
.pm-pay__panel { border: 1px solid var(--cfg-line); border-radius: 16px; padding: 30px 32px; background: #fff; margin-top: 30px; }
.pm-pay__controls { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; margin-bottom: 26px; }
.pm-pay__field { display: flex; flex-direction: column; gap: 8px; }
.pm-pay__field-label { font-size: 14px; }
.pm-pay__field-label b { color: var(--cfg-bronze); }
.pm-pay__field-sub { font-size: 12px; color: var(--cfg-mut); }
.pm-pay__field input[type=range] { width: 100%; accent-color: var(--cfg-bronze); }
/* result-рядок: сума зліва, CTA праворуч на тому ж рівні (per UX 2026-05-31) */
.pm-pay__result { display: flex; align-items: center; justify-content: space-between; gap: 24px; text-align: left; padding-top: 26px; border-top: 1px solid rgba(27,27,30,0.16); }   /* менш темна лінія (UX 2026-06-01) */
.pm-pay__result-main { flex: 1 1 auto; min-width: 0; }
.pm-pay__result-label { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cfg-mut); }
.pm-pay__result-value { display: block; font-size: 30px; font-weight: 700; margin: 4px 0; }
.pm-pay__result-sub { display: block; font-size: 13px; color: var(--cfg-mut); }
.pm-pay__cta { flex: 0 0 auto; margin: 0; white-space: nowrap; }
@media (max-width: 700px) { .pm-pay__result { flex-direction: column; align-items: stretch; text-align: center; gap: 16px; } .pm-pay__cta { margin: 0 auto; } }
@media (max-width: 700px) {
    .pm-pay__controls { grid-template-columns: 1fr; gap: 18px; }
    .pm-pay__tab { font-size: 13.5px; }
}

/* ═══════════════ Конструктор як таблиця-порівняння комплектацій ═══════════════ */
/* Біла картка-таблиця на темному фоні блоку + менше закруглення (UX 2026-06-01) */
/* Вужче, не на всю ширину. Обмежуємо ВНУТРІШНЮ картку (div), бо section{max-width:none!important}
   у functions.php перебив би max-width самої секції (UX 2026-06-01). */
.pm-cfg--compare .pm-cfg__scroll { max-width: 1040px; margin-inline: auto; overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--cfg-line); border-radius: 18px; background: #fff; }
/* Кутові комірки заокруглюємо під картку, щоб білий кут не випирав за радіус (UX 2026-06-01) */
.pm-cfg--compare .pm-cfg__corner { border-top-left-radius: 18px; }
.pm-cfg--compare thead th:last-child { border-top-right-radius: 18px; }
.pm-cfg--compare .pm-cfg__row--total .pm-cfg__rowhead { border-bottom-left-radius: 18px; }
.pm-cfg--compare .pm-cfg__row--total td:last-child { border-bottom-right-radius: 18px; }
.pm-cfg__table { width: 100%; border-collapse: collapse; min-width: 760px; table-layout: fixed; }
.pm-cfg__corner { text-align: left; padding: 21px 20px 21px 40px; font-size: 12px; color: var(--cfg-mut); text-transform: uppercase; letter-spacing: .08em; position: sticky; left: 0; background: #fff; z-index: 2; width: 32%; min-width: 230px; }
.pm-cfg__col { padding: 21px 18px; text-align: center; vertical-align: top; border-left: 1px solid var(--cfg-line); transition: background .2s ease; }
.pm-cfg__col.is-active { background: rgba(173,125,65,.07); }
.pm-cfg__col--custom { background: #faf7f1; }
.pm-cfg__col--custom.is-active { background: rgba(173,125,65,.12); }
.pm-cfg__col-name { display: block; font-weight: 600; font-size: 15px; color: var(--cfg-ink); }
.pm-cfg__col-price { display: block; font-family: var(--pm-ff-heading, "Bounded", serif); font-size: 20px; color: var(--cfg-ink); margin: 6px 0 10px; }
.pm-cfg__col-btn { border: 1.5px solid #bdb7ac; background: #fff; border-radius: 999px; padding: 7px 18px; font-size: 13px; font-weight: 600; cursor: pointer; transition: background .15s ease, color .15s ease, border-color .15s ease; font-family: inherit; color: #1b1b1e; -webkit-appearance: none; appearance: none; }
.pm-cfg__col-btn:hover { background: var(--cfg-ink); color: #fff; }
.pm-cfg__col-hint { display: block; font-size: 11px; color: var(--cfg-bronze); }
.pm-cfg__row { border-top: 1px solid var(--cfg-line); }
.pm-cfg__rowhead { text-align: left; padding: 18px 16px 18px 40px; font-weight: 400; position: sticky; left: 0; background: #fff; z-index: 1; }
.pm-cfg__rh-name { display: block; font-size: 14.5px; font-weight: 500; color: var(--cfg-ink); }
.pm-cfg__rh-name small { color: var(--cfg-mut); font-weight: 400; }
.pm-cfg__rh-price { display: block; font-size: 12.5px; color: var(--cfg-mut); }
.pm-cfg__rh-price small { color: var(--cfg-bronze); }
.pm-cfg__cell { text-align: center; padding: 16px 18px; border-left: 1px solid var(--cfg-line); vertical-align: middle; }
.pm-cfg__cell--custom { background: #faf7f1; }
.pm-cfg__yes { color: #2a8854; font-weight: 700; font-size: 17px; }
.pm-cfg__dash { color: #cfc9bb; }
.pm-cfg__row--included .pm-cfg__rowhead { color: var(--cfg-mut); }
.pm-cfg__row--included .pm-cfg__rowhead small { font-size: 11px; }
.pm-cfg__row--total { border-top: 2px solid var(--cfg-ink); }
/* Підсумковий рядок — трохи темніший фон, щоб виділявся (UX 2026-06-01) */
.pm-cfg__row--total .pm-cfg__rowhead,
.pm-cfg__row--total .pm-cfg__cell { background: #f3eee3; }
.pm-cfg__row--total .pm-cfg__cell--custom { background: #efe8d8; }
.pm-cfg__row--total .pm-cfg__rowhead { font-weight: 600; text-transform: uppercase; font-size: 12.5px; letter-spacing: .06em; }
/* Примітка про орієнтовну ціну — під «Разом», усередині білої картки (UX 2026-06-01) */
.pm-cfg__note-inline { display: block; margin-top: 8px; max-width: 240px; font-size: 11.5px; font-weight: 400; text-transform: none; letter-spacing: normal; line-height: 1.4; color: var(--cfg-mut); }

/* Контекст розрахунку у модалці-заявці (підставляється з калькулятора оплати) */
.pm-form__context { display: flex; flex-direction: column; gap: 5px; margin: 0 0 20px; padding: 14px 16px; border-radius: 12px; background: rgba(201,169,110,.10); border: 1px solid rgba(201,169,110,.35); font-size: 13.5px; }
.pm-form__context[hidden] { display: none !important; }   /* hero-форма (заявка): порожній жовтий бокс ховаємо; показуємо лише з калькулятора */
.pm-form__context span { line-height: 1.45; }
.pm-form__context i { font-style: normal; font-weight: 400; color: #6b6b66; }   /* лейбл — звичайний */
.pm-form__context b { font-weight: 600; color: #1b1b1e; }                        /* значення — жирне */
.pm-form__context-sub { font-size: 12.5px; color: #8a8478; margin-top: 1px; }
.pm-cfg__cell--total { font-family: var(--pm-ff-heading, "Bounded", serif); font-size: 17px; color: var(--cfg-ink); }
.pm-cfg__check { display: inline-flex; cursor: pointer; }
.pm-cfg__check input { position: absolute; opacity: 0; width: 0; height: 0; }
.pm-cfg__check-box { width: 24px; height: 24px; border: 1.5px solid #cfcabd; border-radius: 7px; position: relative; transition: background .15s ease, border-color .15s ease; background: #fff; }
.pm-cfg__check input:checked + .pm-cfg__check-box { background: var(--cfg-bronze); border-color: var(--cfg-bronze); }
.pm-cfg__check input:checked + .pm-cfg__check-box::after { content: ""; position: absolute; left: 8px; top: 3px; width: 6px; height: 12px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.pm-cfg__check input:focus-visible + .pm-cfg__check-box { outline: 2px solid var(--cfg-bronze); outline-offset: 2px; }
.pm-cfg__actions { text-align: center; margin-top: 24px; }
.pm-cfg__actions .pm-cfg__cta { display: inline-flex; }
@media (max-width: 700px) {
    .pm-cfg__corner { min-width: 150px; }
    .pm-cfg__rowhead .pm-cfg__rh-name { font-size: 13.5px; }
}
/* ── Мобільний UX таблиці-конфігуратора (UX 2026-06-01) ──
   Ховаємо колонки-пресети, лишаємо «назва + ціна + галочка Своя» — зручний чек-ліст. */
@media (max-width: 700px) {
    .pm-cfg__head { margin-bottom: 18px; }   /* менший відступ заголовок→таблиця на моб */
    .pm-cfg--compare .pm-cfg__col:not(.pm-cfg__col--custom),
    .pm-cfg--compare .pm-cfg__cell:not(.pm-cfg__cell--custom) { display: none; }
    .pm-cfg--compare .pm-cfg__table { min-width: 0; table-layout: fixed; }
    .pm-cfg--compare .pm-cfg__scroll { overflow-x: hidden; }
    .pm-cfg--compare .pm-cfg__corner,
    .pm-cfg--compare .pm-cfg__rowhead { position: static; padding: 13px 12px; min-width: 0; width: auto; }
    .pm-cfg--compare .pm-cfg__col--custom,
    .pm-cfg--compare .pm-cfg__cell--custom { width: 120px; padding-left: 8px; padding-right: 8px; }
    .pm-cfg--compare .pm-cfg__col--custom .pm-cfg__col-name { font-size: 13px; }
    .pm-cfg--compare .pm-cfg__col--custom .pm-cfg__col-hint { font-size: 10px; }
    .pm-cfg--compare .pm-cfg__col-btn { padding: 7px 12px; font-size: 12.5px; }
    /* ціна підсумку — менший шрифт, щоб «від $338 000» вмістилось в рядок */
    .pm-cfg--compare .pm-cfg__cell--total { font-size: 14px; }
    .pm-cfg--compare .pm-cfg__total-price { font-size: 14px; white-space: nowrap; }
    .pm-cfg--compare .pm-cfg__total-price b { font-size: 15px; }
    /* «від» на 1-му рядку, ціна — на 2-му (моб) per UX 2026-06-02 */
    .pm-cfg--compare .pm-cfg__total-price .pm-cfg__from { display: block; font-size: 11px; margin-right: 0; line-height: 1.2; }
    /* Бічні відступи блоку конфігуратора = як у «Планування» (18px). Блок-обгортка 16px + .pm-cfg 24px = 40px → зводимо до 18px (UX 2026-06-01). */
    .pm-cot-block--has-bg:has(.pm-cfg) { padding-inline: 18px; }
    .pm-cot-block--has-bg .pm-cfg { padding-left: 0; padding-right: 0; }
}

/* ───────── Калькулятор: 4 таби + трейд-ін + плот-селектор ───────── */
/* Контент калькулятора тримаємо читабельним всередині широкої (1320) секції */
.pm-pay__head, .pm-pay__price-row, .pm-pay__tabs, .pm-pay__panel { max-width: 860px; margin-left: auto; margin-right: auto; }
.pm-pay__tabs { flex-wrap: wrap; }
.pm-pay__tab { flex: 1 1 160px; }
.pm-pay__field--full { grid-column: 1 / -1; }
.pm-pay__field input[type=number] { width: 100%; padding: 12px 14px; border: 1.5px solid var(--cfg-line); border-radius: 12px; font-size: 16px; font-family: inherit; color: var(--cfg-ink); }
.pm-pay__field input[type=number]:focus { outline: none; border-color: var(--cfg-bronze); }

/* Плот-селектор над таблицею комплектацій */
.pm-cfg__plot { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center; margin-bottom: 18px; }
.pm-cfg__plot-label { font-size: 14px; color: var(--cfg-mut); }
/* appearance:none + кастомна стрілка з відступом справа (per UX 2026-05-31) */
.pm-cfg__plot select { -webkit-appearance: none; -moz-appearance: none; appearance: none; padding: 10px 42px 10px 18px; border: 1.5px solid var(--cfg-line); border-radius: 999px; background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231d1d1b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 16px center; font-size: 14.5px; font-weight: 600; color: var(--cfg-ink); font-family: inherit; cursor: pointer; }
.pm-cfg__plot select:focus { outline: none; border-color: var(--cfg-bronze); }
/* Темна плашка під підказкою — контраст на фото-фоні (UX 2026-06-01) */
.pm-cfg__plot-hint { font-size: 12.5px; color: #e3c489; background: rgba(20,20,22,0.78); padding: 4px 14px; border-radius: 999px; display: inline-block; }
/* Нижній рядок «Разом»: ціна + кнопка «Обрати» (перенесено з шапки) */
.pm-cfg__cell--total { text-align: center; vertical-align: top; padding-top: 18px; padding-bottom: 32px; }   /* більше місця під кнопками «Обрати» до краю картки (UX 2026-06-01) */
.pm-cfg__row--total .pm-cfg__rowhead { padding-bottom: 32px; }
.pm-cfg__total-price { display: block; margin: 0 0 10px; }
/* «від» — приглушений малий префікс (як ціни в рядках), число — велике (UX 2026-06-01) */
.pm-cfg__total-price .pm-cfg__from { font-size: 12.5px; font-weight: 400; color: var(--cfg-mut); margin-right: 3px; }
.pm-cfg__total-price b { font-size: 18px; font-weight: 700; color: var(--cfg-ink); }
.pm-cfg__cell--total .pm-cfg__col-btn { font-size: 13px; }

/* «Обрати» активна (після кліку) — слабкий сірий фон (per UX 2026-05-31) */
.pm-cfg__col-btn.is-active { background: var(--cfg-ink); border-color: var(--cfg-ink); color: #fff; }   /* «Обрано» — темна кнопка + білий текст (UX 2026-06-01) */
