/* ───────────────────────────────────────────────────────────
   Configurator β-2 — xcore-скин поверх webprostor.configurator.onepage.
   Высокая специфика через #webprostor_configurator / #assembly / #modalProducts.
   ─────────────────────────────────────────────────────────── */

/* ───────────────────────────────────────────────────────────
   Header (breadcrumbs/title/subtitle) — над гридом
   ─────────────────────────────────────────────────────────── */

.xf-cfg-header {
  max-width: var(--container);
  margin: 18px auto 0;
  padding: 0 var(--container-pad) 22px;
  border-bottom: 1px solid var(--line-soft);
}

.xf-cfg-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-3);
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.xf-cfg-breadcrumbs a { color: var(--text-3); }
@media (hover: hover) {
  .xf-cfg-breadcrumbs a:hover { color: var(--text); }
}
.xf-cfg-breadcrumbs__sep { opacity: 0.5; }

.xf-cfg-header__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: end;
}

.xf-cfg-title {
  margin: 0;
  font-size: clamp(34px, 3.4vw, 48px);
  font-weight: 600;
  letter-spacing: -1.6px;
  line-height: 1.04;
  color: var(--text);
}
.xf-cfg-title__accent {
  display: block;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.xf-cfg-subtitle {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
  max-width: 460px;
}

@media (max-width: 900px) {
  .xf-cfg-header__grid { grid-template-columns: 1fr; gap: 16px; align-items: start; }
  .xf-cfg-title { font-size: 30px; letter-spacing: -0.8px; }
}

/* ───────────────────────────────────────────────────────────
   Grid (main + sticky sidebar)
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator {
  max-width: var(--container);
  margin: 20px auto 60px;
  padding: 0 var(--container-pad);
  color: var(--text);
  font-family: var(--font-sans);
}

/* Внутри — Onest, но FA-иконки оставляем со своим font-family */
#webprostor_configurator .xf-cfg-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 28px;
  align-items: start;
}
#webprostor_configurator .xf-cfg-grid--full { grid-template-columns: 1fr; }
#webprostor_configurator .xf-cfg-main { min-width: 0; }
#webprostor_configurator .xf-cfg-aside { min-width: 0; }
#webprostor_configurator .xf-cfg-aside__sticky,
#webprostor_configurator .sticky-top.xf-cfg-aside__sticky {
  position: sticky;
  top: 200px;
  z-index: 5; /* ниже site-header (z-index: 50), чтобы хедер перекрывал */
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-right: 0;
  /* никаких max-height/overflow — не обрезаем, пусть sticky уезжает с прокруткой */
}

@media (max-width: 1100px) {
  #webprostor_configurator .xf-cfg-grid { grid-template-columns: 1fr; gap: 20px; }
  #webprostor_configurator .xf-cfg-aside__sticky { position: static; max-height: none; overflow: visible; }
}

/* FA иконки — держим родной font-family (bootstrap FA 4.3) */
#webprostor_configurator .fa,
#webprostor_configurator [class^="fa-"],
#webprostor_configurator [class*=" fa-"] {
  font-family: FontAwesome !important;
  font-weight: normal;
  font-style: normal;
}

/* ───────────────────────────────────────────────────────────
   Карточка шага (steps/list-group-item) — iconbox + title + action
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator .list-group,
#webprostor_configurator .list-group-item {
  background: transparent;
  border: none;
}

/* Группа (Системный блок / Периферия / ...) — прозрачный контейнер */
#webprostor_configurator .list-group-item.parent {
  background: transparent;
  border: none;
  border-radius: 0;
  margin-bottom: 24px;
  padding: 0;
}
#webprostor_configurator .list-group-item.parent > h3 {
  margin: 0 0 10px;
  padding: 0 4px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-3);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
}
#webprostor_configurator .list-group-item.parent > h3 svg,
#webprostor_configurator .list-group-item.parent > h3 img {
  max-height: 16px;
  opacity: 0.55;
}
#webprostor_configurator .list-group-item.parent > h3 .steps-group-name {
  color: var(--text-3);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  flex: 1;
  cursor: pointer;
}
#webprostor_configurator .list-group-item.parent > h3 .steps-group-name::after {
  content: "";
  display: inline-block;
  width: 8px; height: 8px;
  margin-left: 10px;
  border-right: 2px solid var(--accent-2);
  border-bottom: 2px solid var(--accent-2);
  transform: rotate(45deg) translateY(-2px);
  opacity: 1;
  transition: transform .2s;
}
#webprostor_configurator .list-group-item.parent > h3 .steps-group-name.collapsed::after {
  transform: rotate(-45deg) translateY(-2px);
}

/* Collapse-анимация ровная только при padding=0 на самом .panel-body.
   (BS3 анимирует height; если padding на body — natural_h = content+padding,
   scrollHeight = content+padding, но при transition-end height:auto SNAP'ится на 30px).
   Фикс: padding переносим на первых потомков panel-body. */
#webprostor_configurator .panel-body.collapse,
#webprostor_configurator .panel-body.collapsing,
#webprostor_configurator .panel-body.collapse.in {
  padding: 0 !important;
  box-sizing: content-box;
}
#webprostor_configurator .panel-body.collapse > *,
#webprostor_configurator .panel-body.collapsing > *,
#webprostor_configurator .panel-body.collapse.in > * {
  padding-left: 18px;
  padding-right: 18px;
}
#webprostor_configurator .panel-body.collapse > *:first-child,
#webprostor_configurator .panel-body.collapsing > *:first-child,
#webprostor_configurator .panel-body.collapse.in > *:first-child {
  padding-top: 14px;
}
#webprostor_configurator .panel-body.collapse > *:last-child,
#webprostor_configurator .panel-body.collapsing > *:last-child,
#webprostor_configurator .panel-body.collapse.in > *:last-child {
  padding-bottom: 16px;
}

/* Шаг — карточка селектора ~72px (xf-step __row — flex на номер/иконку/контент/actions) */
#webprostor_configurator .list-group.steps > .list-group-item.xf-step {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  margin-bottom: 6px !important;
  padding: 12px 16px !important;
  color: var(--text);
  transition: border-color .15s, background .15s;
  float: none !important;
  cursor: pointer;
}
@media (hover: hover) {
  #webprostor_configurator .list-group.steps > .list-group-item.xf-step:hover {
  border-color: var(--accent-line);
  background: oklch(from var(--surface) calc(l + 0.015) c h);
}
}

/* Flex-строка: номер 32 + иконка 52 + main (1fr) + actions auto */
#webprostor_configurator .xf-step__row {
  display: flex !important;
  align-items: center;
  gap: 14px;
  margin: 0 !important;
  width: 100%;
}
#webprostor_configurator .xf-step__num {
  flex: 0 0 auto;
  width: 30px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-3);
  letter-spacing: 0.6px;
  text-align: left;
  line-height: 1;
}
#webprostor_configurator .xf-step__icon {
  flex: 0 0 auto;
  width: 48px !important;
  height: 48px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  background: oklch(from var(--accent) l c h / 0.08);
  border: 1px solid var(--accent-line);
  border-radius: 10px;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
}
#webprostor_configurator .xf-step__icon.hidden { display: none; }
#webprostor_configurator .xf-step__icon img,
#webprostor_configurator .xf-step__icon svg {
  max-width: 26px !important;
  max-height: 26px !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  filter: drop-shadow(0 0 6px oklch(0.7 0.18 285 / 0.4));
  opacity: 0.85;
}
#webprostor_configurator .xf-step__main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
#webprostor_configurator .xf-step__title {
  margin: 0 !important;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.25;
  color: var(--text);
  letter-spacing: -0.1px;
}
#webprostor_configurator .xf-step__title .step-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}
#webprostor_configurator .xf-step__title .step-name .fa-lock {
  font-size: 11px;
  color: var(--text-3);
  margin-left: 4px;
}
#webprostor_configurator .xf-step__help {
  color: var(--text-3);
  font-size: 12px;
  display: inline-flex;
  align-items: center;
}
@media (hover: hover) {
  #webprostor_configurator .xf-step__help:hover { color: var(--accent-2); }
}
#webprostor_configurator .xf-step__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  background: oklch(0.72 0.2 25 / 0.14);
  color: oklch(0.84 0.14 25);
  border: 1px solid oklch(0.72 0.2 25 / 0.35);
  line-height: 1.3;
}
#webprostor_configurator .xf-step__badge .fa-exclamation-triangle { display: none; }
#webprostor_configurator .xf-step__meta {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-3);
  letter-spacing: 0.2px;
  line-height: 1.4;
}
#webprostor_configurator .xf-step__actions {
  flex: 0 0 auto;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}

/* Non-compact fallback (старый DOM) — только базовая кладка */
#webprostor_configurator .steps .list-group-item:not(.xf-step) > h4 { margin: 0 0 10px; }
#webprostor_configurator .steps .list-group-item:not(.xf-step) > .row {
  display: grid;
  grid-template-columns: 48px minmax(0,1fr);
  gap: 14px;
  align-items: center;
  margin: 0;
}

/* Пустой .products (до выбора товара) — не занимает место */
#webprostor_configurator .steps .products:empty { display: none; margin: 0; }
#webprostor_configurator .steps .products {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--line-soft);
}

/* Карточка выбранного товара внутри .products */
#webprostor_configurator .steps .products > .row {
  display: grid;
  grid-template-columns: 48px minmax(0,1fr) auto;
  gap: 14px;
  align-items: center;
  margin: 0;
  padding: 0;
}
#webprostor_configurator .steps .products > .row > [class*="col-"] {
  padding: 0 !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  flex: none !important;
  float: none !important;
}
#webprostor_configurator .steps .products .picture {
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
}
#webprostor_configurator .steps .products .picture img {
  max-width: 42px !important;
  max-height: 42px !important;
}
#webprostor_configurator .steps .products h5,
#webprostor_configurator .steps .products h5.name {
  margin: 0 0 3px !important;
  font-size: 13.5px !important;
  font-weight: 500;
  color: var(--text);
  line-height: 1.25;
}
#webprostor_configurator .steps .products h5 a { color: var(--text); }
@media (hover: hover) {
  #webprostor_configurator .steps .products h5 a:hover { color: var(--accent-2); }
}

/* Описание / мета */
#webprostor_configurator .steps .description,
#webprostor_configurator .steps .properties {
  color: var(--text-3) !important;
  font-size: 13px;
  line-height: 1.45;
}
#webprostor_configurator .text-muted,
#webprostor_configurator small:not(.label) { color: var(--text-3) !important; }

/* Цена внутри шага */
#webprostor_configurator .steps .price,
#webprostor_configurator .steps h3.price {
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--font-mono) !important;
  letter-spacing: -0.2px;
}
#webprostor_configurator .steps .old-price,
#webprostor_configurator .steps .price .old {
  color: var(--text-3);
  text-decoration: line-through;
}

/* Обязательный шаг / бейджи — xcore-chip */
#webprostor_configurator .label,
#webprostor_configurator .badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 10px;
  font-family: var(--font-mono) !important;
  font-weight: 500;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  line-height: 1.4;
}
#webprostor_configurator .label-default,
#webprostor_configurator .badge-default {
  background: oklch(0.72 0.2 60 / 0.14);
  color: oklch(0.88 0.14 75);
  border: 1px solid oklch(0.72 0.2 60 / 0.32);
}
/* «Обязательный шаг» — danger-red, а не ordinary orange */
#webprostor_configurator .label.required,
#webprostor_configurator small.label.required {
  background: oklch(0.72 0.2 25 / 0.14);
  color: oklch(0.84 0.14 25);
  border: 1px solid oklch(0.72 0.2 25 / 0.35);
}
#webprostor_configurator .label-warning,
#webprostor_configurator .badge-warning,
#webprostor_configurator .label-danger,
#webprostor_configurator .badge-danger {
  background: oklch(0.72 0.2 25 / 0.14);
  color: oklch(0.84 0.14 25);
  border: 1px solid oklch(0.72 0.2 25 / 0.35);
}
#webprostor_configurator .label-success,
#webprostor_configurator .badge-success {
  background: oklch(0.76 0.16 155 / 0.14);
  color: oklch(0.84 0.14 155);
  border: 1px solid oklch(0.76 0.16 155 / 0.35);
}
#webprostor_configurator .label-info,
#webprostor_configurator .badge-info {
  background: var(--accent-dim);
  color: var(--accent-2);
  border: 1px solid var(--accent-line);
}

/* ───────────────────────────────────────────────────────────
   Кнопки (Bootstrap → xcore)
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font-sans);
  border: 1px solid transparent;
  transition: transform .15s, box-shadow .15s, background .15s, border-color .15s, color .15s;
  line-height: 1.2;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  box-shadow: none;
  white-space: nowrap;
}
@media (hover: hover) {
  #webprostor_configurator .btn:hover { transform: translateY(-1px); }
}

#webprostor_configurator .btn-primary,
#webprostor_configurator .btn-success {
  background: var(--accent);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 6px 18px -8px var(--accent);
}
@media (hover: hover) {
  #webprostor_configurator .btn-primary:hover,
#webprostor_configurator .btn-success:hover {
  background: var(--accent-2);
  color: #fff;
}
}

#webprostor_configurator .btn-default,
#webprostor_configurator .btn-secondary {
  background: var(--surface-2);
  color: var(--text);
  border-color: var(--line-soft);
}
@media (hover: hover) {
  #webprostor_configurator .btn-default:hover {
  background: var(--surface-3);
  border-color: var(--line);
}
}

#webprostor_configurator .btn-info {
  background: var(--accent-dim);
  color: var(--accent-2);
  border-color: var(--accent-line);
}

#webprostor_configurator .btn-danger {
  background: oklch(0.35 0.12 25 / 0.18);
  color: oklch(0.82 0.14 25);
  border-color: oklch(0.45 0.14 25 / 0.4);
}
@media (hover: hover) {
  #webprostor_configurator .btn-danger:hover {
  background: oklch(0.42 0.18 25 / 0.28);
  color: #fff;
}
}

#webprostor_configurator .btn-link {
  background: transparent;
  color: var(--text-3);
  padding: 6px 0;
  border: none;
}
@media (hover: hover) {
  #webprostor_configurator .btn-link:hover {
  color: var(--text);
  text-decoration: none;
  transform: none;
}
}
#webprostor_configurator .btn-link.disabled,
#webprostor_configurator .btn-link[disabled] {
  opacity: 0.4;
}

#webprostor_configurator .btn-lg { padding: 12px 20px; font-size: 14px; border-radius: 12px; }
#webprostor_configurator .btn-sm { padding: 7px 12px; font-size: 12.5px; border-radius: 8px; }

/* Квадратная «+» в карточке шага — 40×40, единый accent-dim стиль.
   font-size:0 схлопывает whitespace-текстовые ноды между <i> и пустым <span>,
   иначе они становятся анонимными flex-items и сдвигают глиф влево на 3-4px. */
#webprostor_configurator .steps .btn-ajax,
#webprostor_configurator .steps .btn-add,
#webprostor_configurator .steps .btn-delete {
  width: 40px !important;
  height: 40px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 10px !important;
  font-size: 0 !important;
  line-height: 0 !important;
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
/* Пустой <span data-original="..."> внутри кнопки приходит от кора модуля
   даже в compact-режиме — гасим, чтобы не участвовал в flex-центрировании. */
#webprostor_configurator .steps .btn-ajax > span,
#webprostor_configurator .steps .btn-add > span,
#webprostor_configurator .steps .btn-delete > span {
  display: none !important;
}
/* FA у иконок разный side-bearing. Зажимаем глиф в фиксированный 14px-бокс
   с text-align:center, чтобы fa-plus/fa-exchange/fa-trash визуально стояли
   одинаково. font-size возвращаем именно на иконку — на кнопке он 0. */
#webprostor_configurator .steps .btn-ajax > i.fa,
#webprostor_configurator .steps .btn-add > i.fa,
#webprostor_configurator .steps .btn-delete > i.fa {
  display: inline-block;
  width: 14px;
  text-align: center;
  line-height: 1;
  font-size: 13px !important;
}
/* .hidden (bootstrap) должен перебивать мой display */
#webprostor_configurator .steps .btn-ajax.hidden,
#webprostor_configurator .steps .btn-add.hidden,
#webprostor_configurator .steps .btn-delete.hidden { display: none !important; }
#webprostor_configurator .steps .btn-ajax,
#webprostor_configurator .steps .btn-add {
  background: var(--accent-dim) !important;
  color: var(--accent-2) !important;
  border: 1px solid var(--accent-line) !important;
  box-shadow: none !important;
}
@media (hover: hover) {
  #webprostor_configurator .steps .btn-ajax:hover,
#webprostor_configurator .steps .btn-add:hover {
  background: var(--accent) !important;
  color: #fff !important;
  border-color: var(--accent) !important;
  transform: none;
}
}
#webprostor_configurator .steps .btn-delete {
  background: oklch(0.35 0.12 25 / 0.18) !important;
  color: oklch(0.82 0.14 25) !important;
  border: 1px solid oklch(0.45 0.14 25 / 0.4) !important;
}

/* ───────────────────────────────────────────────────────────
   Sidebar — #assembly и его блоки
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator #assembly {
  color: var(--text);
}
#webprostor_configurator #assembly .panel,
#webprostor_configurator #assembly .card {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  margin-bottom: 0;
  overflow: hidden;
  color: var(--text);
  box-shadow: none;
}

/* Заголовки блоков sidebar */
#webprostor_configurator #assembly .panel-heading,
#webprostor_configurator #assembly .card-header,
#webprostor_configurator #assembly .panel-title {
  background: transparent !important;
  color: var(--text-3) !important;
  border-bottom: 1px solid var(--line-soft);
  padding: 14px 18px 12px;
  margin: 0;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 1.8px;
  text-transform: uppercase;
}
/* !important перебивает aspro/theme.css rule `.panel-heading.slim { padding: 0 !important }` —
   без него heading схлопывается в 0, текст липнет к рамке panel. */
#webprostor_configurator #assembly .panel-heading.slim,
#webprostor_configurator #assembly .panel-heading {
  padding: 12px 18px !important;
  border-bottom: 0;
}
/* Линию-призрак рисовал h3.panel-title (наследовал от rule-группы выше —
   .panel-heading,.card-header,.panel-title получали общий стайлинг с
   border-bottom:1px и padding 14/12). Heading обнулён отдельно, но title
   внутри heading оставался с border и padding — ВОТ эта горизонталь и была
   видна. Ресетим title: убираем его собственную рамку и padding (heading
   уже даёт нужный наружный padding 12×18). */
#webprostor_configurator #assembly .panel-heading .panel-title {
  padding: 0;
  border-bottom: 0;
  margin: 0;
}
/* overflow: hidden — aspro theme ставит `overflow: hidden auto` на .panel-body.
   Во время collapse-анимации контент выше body → оверфлоу-Y показывает скроллбар,
   который съедает ~10px ширины. Div.xf-cfg-empty внутри сжимается на эти 10px
   и text-align:center смещает текст влево; в конце анимации (body h=content h)
   скроллбар уходит → текст «прыгает» вправо. Фикс: Y-оверфлоу hidden. */
#webprostor_configurator #assembly .panel-body {
  border-top: 0;
  overflow-y: hidden;
}
/* background-image: none — aspro theme.css вешает sprite-стрелку через
   background на anchor в `.panel-heading.slim h3 a` (и вариант для .collapsed).
   Визуально это рисовало ВТОРОЙ шеврон рядом с моим ::after — отсюда "двойной".
   !important на всякий: ломать придётся и collapsed, и expanded вариант. */
#webprostor_configurator #assembly .panel-heading a,
#webprostor_configurator #assembly .panel-heading a.collapsed,
#webprostor_configurator #assembly .panel-title a,
#webprostor_configurator #assembly .panel-title a.collapsed {
  color: var(--text-3) !important;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  position: relative;
  padding-right: 4px;
  background-image: none !important;
  background: none !important;
}
@media (hover: hover) {
  #webprostor_configurator #assembly .panel-heading a:hover,
#webprostor_configurator #assembly .panel-title a:hover {
  color: var(--text) !important;
}
}
#webprostor_configurator #assembly .panel-title {
  font-size: 10.5px;
  font-weight: 500;
}
/* Шеврон в sidebar-заголовках — Unicode glyph. После двух попыток (border+
   rotate, потом SVG через background и mask) user всё равно видел «шеврон на
   шевроне» на своём display (DPR artefact). Unicode `⌄` (U+2304) — один
   цельный character, любая плотность пикселей не делит его на две линии.
   Для collapsed используем `›` (U+203A) — один right-single-angle. */
#webprostor_configurator #assembly .panel-heading a::after,
#webprostor_configurator #assembly .panel-title a::after {
  content: "⌄";
  display: inline-block;
  font-family: -apple-system, "system-ui", "Segoe UI", sans-serif;
  font-size: 18px;
  line-height: 1;
  width: 14px; height: 14px;
  text-align: center;
  color: var(--accent-2);
  margin-left: auto;
  transition: opacity .15s;
  flex-shrink: 0;
  opacity: 0.9;
  border: 0;
  background: none;
  -webkit-mask: none;
          mask: none;
  /* -2px — глиф `⌄` имеет визуальный вес ниже baseline; flex align-items:center
     центрирует бокс, но оптически кажется, что шеврон «просел». Сдвигаем вверх. */
  transform: translateY(-2px);
}
#webprostor_configurator #assembly .panel-heading a.collapsed::after,
#webprostor_configurator #assembly .panel-title a.collapsed::after {
  content: "›";
  opacity: 0.7;
}

/* Содержимое блоков sidebar */
#webprostor_configurator #assembly .panel-body,
#webprostor_configurator #assembly .card-body {
  padding: 14px 18px 16px;
  color: var(--text);
  background: transparent;
  font-size: 13px;
  line-height: 1.5;
}

/* Комплектация: text-node «Товары отсутствуют» оборачивается в .xf-cfg-empty
   через JS в configurator.onepage/script.js. text-align: center ставим на
   САМ body (#equipment_info_collapse), а не на wrapper — иначе во время
   collapse-анимации текст «телепортируется» (центрирование перескакивает
   между body-width и empty-width, разными из-за padding'ов). */
#webprostor_configurator #assembly #equipment_info_collapse {
  text-align: center;
}
#webprostor_configurator #assembly .xf-cfg-empty {
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.5;
  font-style: italic;
  /* padding-left/right идут от .panel-body.collapse > *; padding-top/bottom
     от M10γ правил :first-child/:last-child. Свой padding не добавляем —
     double-stacking конфликтует с transition. */
}

#webprostor_configurator #assembly a {
  color: var(--text-2);
  transition: color .15s;
}
@media (hover: hover) {
  #webprostor_configurator #assembly a:hover { color: var(--text); }
}

/* Блок «Информация о сборке» — ключевой блок в sidebar (accent-tinted).
   !important чтобы перебить глобальный .panel { background: var(--surface) !important }. */
#webprostor_configurator #assembly_info {
  position: relative;
  background:
    radial-gradient(circle at 100% 0%, oklch(var(--art-glow-l) var(--art-glow-c) var(--accent-h) / var(--art-glow-a)) 0%, transparent 55%),
    linear-gradient(180deg, oklch(var(--art-l1) 0.04 var(--accent-h)) 0%, oklch(var(--art-l2) 0.025 var(--accent-h)) 100%) !important;
  border: 1px solid var(--accent-line) !important;
  overflow: visible !important;
}
#webprostor_configurator #assembly_info::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: 0 0 24px -8px var(--accent-line);
}
#webprostor_configurator #assembly_info .panel-body {
  text-align: left !important;
}
#webprostor_configurator #assembly_total {
  font-family: var(--font-mono);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
#webprostor_configurator .xf-total-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
#webprostor_configurator .xf-total-row__label {
  font-family: var(--font-mono) !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  color: var(--text-3) !important;
  display: inline !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
  padding: 0 !important;
}
#webprostor_configurator .xf-total-row__value {
  font-family: var(--font-mono) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text-2) !important;
  display: inline !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
  letter-spacing: -0.1px !important;
  padding: 0 !important;
  white-space: nowrap;
}
#webprostor_configurator .xf-total-row--main .xf-total-row__value {
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.5px !important;
  background: var(--grad) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
}
/* Старые <b>-правила — на случай старой lang-строки (устаревший fallback) */
#webprostor_configurator #assembly_total b,
#webprostor_configurator #assembly_total strong {
  font-family: var(--font-mono);
  display: inline;
}

/* Прогресс-бары — ряд «label + N/M · XX%» сверху и тонкая полоска снизу */
#webprostor_configurator #progress.xf-progress-card .xf-progress-card__title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-3);
}
#webprostor_configurator #progress .xf-progress-row {
  margin-bottom: 12px;
}
#webprostor_configurator #progress .xf-progress-row:last-child {
  margin-bottom: 0;
}
#webprostor_configurator #progress .xf-progress-row__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}
#webprostor_configurator #progress .xf-progress-row__label {
  font-size: 12.5px;
  color: var(--text-2);
}
#webprostor_configurator #progress .xf-progress-row__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  white-space: nowrap;
}
#webprostor_configurator #progress .progress {
  height: 4px;
  background: var(--surface-2);
  border-radius: 2px;
  overflow: hidden;
  box-shadow: none;
  margin: 0;
}
#webprostor_configurator #progress .progress-bar {
  background: var(--accent);
  box-shadow: none;
  font-size: 0;
  line-height: 4px;
  color: transparent;
  min-width: 0 !important;
  border-radius: 2px;
  transition: width .3s ease;
}

/* Общая сумма */
#webprostor_configurator .total-price,
#webprostor_configurator .config-total-price,
#webprostor_configurator .total,
#webprostor_configurator #assembly .price {
  color: var(--text);
  font-weight: 600;
  font-size: 20px;
  letter-spacing: -0.4px;
  font-family: var(--font-mono) !important;
}

/* ───────────────────────────────────────────────────────────
   #configurator_actions — вертикальный список действий
   (Распечатать / На почту / PDF / Ссылка-поделиться)
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator #configurator_actions,
#webprostor_configurator #configurator_actions.btn-group,
#webprostor_configurator #configurator_actions.btn-group-justified {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px;
  padding: 6px;
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  margin-bottom: 0;
  bottom: auto;
  position: static;
}
#webprostor_configurator #configurator_actions > .btn,
#webprostor_configurator #configurator_actions > a {
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  background: transparent !important;
  color: var(--text-2) !important;
  border: none !important;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  text-transform: none;
  letter-spacing: 0;
  box-shadow: none !important;
  width: 100%;
  text-align: left;
  font-weight: 500;
  transform: none;
}
@media (hover: hover) {
  #webprostor_configurator #configurator_actions > .btn:hover,
#webprostor_configurator #configurator_actions > a:hover {
  background: var(--surface-2) !important;
  color: var(--text) !important;
  transform: none;
}
}
#webprostor_configurator #configurator_actions > a.disabled,
#webprostor_configurator #configurator_actions > a[disabled] {
  opacity: 0.35 !important;
  cursor: not-allowed !important;
  pointer-events: none;
  color: var(--text-3) !important;
}
#webprostor_configurator #configurator_actions > a.disabled > .fa,
#webprostor_configurator #configurator_actions > a[disabled] > .fa {
  color: var(--text-3) !important;
}
#webprostor_configurator #configurator_actions > a > .fa,
#webprostor_configurator #configurator_actions > .btn > .fa {
  color: var(--accent-2);
  font-size: 13px;
  width: 16px;
  text-align: center;
}
#webprostor_configurator #configurator_actions > a > br,
#webprostor_configurator #configurator_actions > .btn > br { display: none; }

/* Hint под action'ами когда сборка пуста */
#webprostor_configurator .xf-actions-hint {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 14px;
  margin-top: 6px;
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--text-3);
}
#webprostor_configurator .xf-actions-hint.hidden { display: none; }
#webprostor_configurator .xf-actions-hint > .fa {
  color: var(--accent-2);
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Поддержка старого CSS 'sticky-bottom' на actions (webprostor вешает дефолтом) */
#webprostor_configurator .sticky-bottom#configurator_actions { position: static; }

/* «show_additional_links» под assembly_info (кредит/лизинг/доставка) */
#webprostor_configurator #show_additional_links {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 0 0;
  margin: 10px 0 0;
  border-top: 1px solid var(--line-soft);
}
#webprostor_configurator #show_additional_links > .list-group-item {
  background: transparent !important;
  border: none !important;
  border-radius: 8px;
  padding: 8px 10px !important;
  font-size: 12.5px;
  color: var(--text-2);
  text-align: left;
}
@media (hover: hover) {
  #webprostor_configurator #show_additional_links > .list-group-item:hover {
  background: var(--surface-2) !important;
  color: var(--text);
}
}
#webprostor_configurator #show_additional_links .fa {
  color: var(--accent-2);
  margin-right: 8px;
}

/* ───────────────────────────────────────────────────────────
   Bottom bar (sticky): «Очистить сборку» / «Перейти в корзину»
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator .list-group.steps > .list-group-item.sticky-bottom,
#webprostor_configurator .list-group > .list-group-item.sticky-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 18px !important;
  position: sticky;
  bottom: 12px;
  background: oklch(from var(--surface) l c h / 0.92);
  border: 1px solid var(--line) !important;
  border-radius: 14px;
  margin: 18px 0 0 !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 12px 32px -12px oklch(0 0 0 / 0.5);
  z-index: 20;
}
#webprostor_configurator .list-group-item.sticky-bottom .clearfix { display: none; }
#webprostor_configurator .list-group-item.sticky-bottom #quantity_notifications {
  position: static;
  width: 100%;
  margin-bottom: 6px;
}

/* «Очистить сборку» — тонкая ссылка */
#webprostor_configurator #btn_delete {
  color: var(--text-3) !important;
  font-size: 13px !important;
  padding: 8px 4px !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
@media (hover: hover) {
  #webprostor_configurator #btn_delete:hover {
  color: var(--text) !important;
  background: transparent !important;
  transform: none;
}
}
#webprostor_configurator #btn_delete.disabled,
#webprostor_configurator #btn_delete[disabled] { opacity: 0.45; }
#webprostor_configurator #btn_delete .fa { color: var(--text-3); }

/* «Перейти в корзину» — главный gradient-CTA */
#webprostor_configurator #order_wrapper {
  display: flex !important;
  align-items: center;
  gap: 10px;
  margin: 0 !important;
  float: none;
  position: static;
}
#webprostor_configurator #assembly_order {
  background: var(--grad) !important;
  color: #fff !important;
  padding: 12px 22px !important;
  font-weight: 600 !important;
  border-radius: 12px !important;
  border: none !important;
  box-shadow: 0 8px 24px -8px var(--accent) !important;
  font-size: 13.5px !important;
}
@media (hover: hover) {
  #webprostor_configurator #assembly_order:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 28px -10px var(--accent) !important;
}
}
#webprostor_configurator #assembly_order.disabled,
#webprostor_configurator #assembly_order[disabled] {
  opacity: 0.55;
  filter: grayscale(0.4);
  cursor: not-allowed;
  transform: none !important;
}
#webprostor_configurator #info_required {
  color: oklch(0.82 0.14 25);
  padding: 8px;
}
#webprostor_configurator #assembly_quantity {
  width: 64px;
  padding: 9px 10px;
  text-align: center;
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  color: var(--text);
  font-family: var(--font-mono);
}

/* Сбрасываем pull-*/float */
#webprostor_configurator .list-group-item.sticky-bottom .pull-sm-left,
#webprostor_configurator .list-group-item.sticky-bottom .pull-sm-right {
  float: none !important;
  text-align: left;
}

/* ───────────────────────────────────────────────────────────
   Description (.panel.panel-info внизу) — убираем белый bg
   ─────────────────────────────────────────────────────────── */

#webprostor_configurator #configurator_description {
  margin-top: 28px;
}
#webprostor_configurator .panel,
#webprostor_configurator .panel-info,
#webprostor_configurator .panel-default,
#webprostor_configurator .panel-primary,
#webprostor_configurator .panel-success,
#webprostor_configurator .panel-warning,
#webprostor_configurator .panel-danger {
  background: var(--surface) !important;
  border: 1px solid var(--line-soft) !important;
  border-radius: 14px !important;
  color: var(--text-2);
  box-shadow: none !important;
  overflow: hidden;
}
#webprostor_configurator #configurator_description .panel-body {
  padding: 18px 22px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.6;
}

/* ───────────────────────────────────────────────────────────
   Modal / popover (выбор товара)
   ─────────────────────────────────────────────────────────── */

#modalProducts,
#modalProducts .modal-content,
.modal-content {
  background: var(--bg-2);
  color: var(--text);
  border: 1px solid var(--line-soft);
  border-radius: 16px;
}
#modalProducts .modal-header,
.modal-header {
  border-bottom: 1px solid var(--line-soft);
  color: var(--text);
}
#modalProducts .modal-footer,
.modal-footer {
  border-top: 1px solid var(--line-soft);
}
#modalProducts .modal-title,
.modal-title {
  color: var(--text);
  font-weight: 600;
}
#modalProducts .close,
.modal .close {
  color: var(--text-3);
  opacity: 0.9;
  text-shadow: none;
}

#modalProducts .item-container,
#modalProducts .item,
#modalProducts .product {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  color: var(--text);
}
#modalProducts .item h3,
#modalProducts .item h4,
#modalProducts .product .name {
  color: var(--text);
  font-size: 13.5px;
}

/* Форм-контролы */
#webprostor_configurator .form-control,
#webprostor_configurator select.form-control,
#webprostor_configurator input.form-control,
#modalProducts .form-control {
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  color: var(--text);
  border-radius: 10px;
  font-size: 13.5px;
  box-shadow: none;
}
#webprostor_configurator .form-control:focus,
#modalProducts .form-control:focus {
  border-color: var(--accent-line);
  box-shadow: 0 0 0 3px var(--accent-dim);
  background: var(--surface-2);
  color: var(--text);
}

#webprostor_configurator label {
  color: var(--text-2);
  font-weight: 400;
}

#webprostor_configurator hr,
#webprostor_configurator .divider {
  border-top: 1px solid var(--line-soft);
  margin: 14px 0;
}

#webprostor_configurator a {
  color: var(--accent-2);
}
@media (hover: hover) {
  #webprostor_configurator a:hover {
  color: var(--text);
  text-decoration: none;
}
}

/* Popover */
.popover {
  background: var(--bg-2);
  border: 1px solid var(--line-soft);
  color: var(--text);
  border-radius: 12px;
  box-shadow: 0 16px 40px -16px oklch(0 0 0 / 0.6);
}
.popover .popover-title,
.popover .popover-header {
  background: transparent;
  color: var(--text);
  border-bottom: 1px solid var(--line-soft);
  font-weight: 500;
}
.popover .popover-content,
.popover .popover-body {
  color: var(--text-2);
}
.popover.bs-popover-top .arrow::after,
.popover.bs-popover-bottom .arrow::after,
.popover.bs-popover-left .arrow::after,
.popover.bs-popover-right .arrow::after {
  border-color: var(--bg-2);
}

/* Компактный view подправки */
#webprostor_configurator.compact-view .list-group-item {
  padding: 14px 16px;
}
