/* KSANET — Configurador v2 (selección de vivienda + acabados)
   Inspirado en configuradores premium tipo automoción:
   stepper top, escenario central inmersivo, panel lateral persistente,
   resumen pegajoso al pie con precio total. */

.cfgx {
  background: var(--bg);
  color: var(--ink);
  min-height: 100vh;
  display: flex; flex-direction: column;
}

/* ───── Top bar ───── */
.cfgx-top {
  background: #fbf8f2;
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 40;
}
.cfgx-top-row {
  max-width: 1480px; margin: 0 auto;
  padding: 14px 32px;
  display: flex; align-items: center; gap: 28px;
}
.cfgx-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--muted);
  padding: 8px 0;
}
.cfgx-back:hover { color: var(--brand); }
.cfgx-brand-mark {
  font-family: var(--tight); font-weight: 500; font-size: 18px;
  letter-spacing: -0.02em;
  padding-left: 28px; border-left: 1px solid var(--line);
}
.cfgx-brand-mark span {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted); margin-left: 8px;
}
.cfgx-top-actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 18px;
}
.cfgx-icon-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  background: none; border: 0; cursor: pointer;
  padding: 8px 0;
}
.cfgx-icon-btn:hover { color: var(--brand); }

/* ───── Stepper ───── */
.cfgx-steps {
  border-top: 1px solid var(--line);
  background: var(--paper);
}
.cfgx-steps-row {
  max-width: 1480px; margin: 0 auto;
  padding: 0 32px;
  display: grid; grid-template-columns: repeat(4, 1fr);
}
.cfgx-step {
  position: relative;
  padding: 18px 0;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  cursor: pointer;
  transition: color .18s;
}
.cfgx-step + .cfgx-step::before {
  content: ''; position: absolute; left: 0; top: 50%;
  width: 24px; height: 1px; background: var(--line);
  transform: translate(-50%, -50%);
}
.cfgx-step:hover { color: var(--ink); }
.cfgx-step .num {
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  font-family: var(--tight); font-size: 13px; letter-spacing: 0;
  color: var(--muted);
  text-transform: none;
  transition: all .18s;
}
.cfgx-step.done .num {
  background: var(--ink); color: #f3e8da; border-color: var(--ink);
}
.cfgx-step.active {
  color: var(--ink);
}
.cfgx-step.active .num {
  background: var(--brand); color: #f3e8da; border-color: var(--brand);
  font-weight: 500;
}
.cfgx-step .label { line-height: 1; }
.cfgx-step .label strong {
  display: block; font-family: var(--tight); font-size: 14px;
  letter-spacing: -0.01em; text-transform: none; color: var(--ink);
  font-weight: 500; margin-top: 3px;
}
.cfgx-step.disabled { opacity: 0.45; cursor: not-allowed; }

/* ───── Workspace layout (Stage + Inspector) ───── */
.cfgx-work {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 420px;
  min-height: 0;
}
.cfgx-stage {
  position: relative;
  background: var(--paper);
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
  min-height: calc(100vh - 196px - 86px); /* top + steps + summary */
}
.cfgx-side {
  background: #fbf8f2;
  display: flex; flex-direction: column;
  overflow-y: auto;
  max-height: calc(100vh - 196px - 86px);
}

@media (max-width: 1180px) {
  .cfgx-work { grid-template-columns: 1fr; }
  .cfgx-side {
    max-height: none;
    border-top: 1px solid var(--line);
  }
  .cfgx-stage { border-right: 0; min-height: 60vh; }
}

/* ───── Stage controls (sub-tabs in Step 1) ───── */
.cfgx-stage-bar {
  display: flex; align-items: center; gap: 24px;
  padding: 16px 28px;
  border-bottom: 1px solid var(--line);
  background: rgba(251, 248, 242, 0.8);
}
.cfgx-stage-title {
  font-family: var(--tight); font-weight: 400;
  font-size: 22px; letter-spacing: -0.02em;
}
.cfgx-stage-title em {
  font-family: var(--serif); font-style: italic; color: var(--brand);
}
.cfgx-stage-tabs {
  margin-left: auto;
  display: flex; gap: 4px;
  background: var(--paper-2);
  padding: 4px;
}
.cfgx-stage-tab {
  padding: 8px 16px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase;
  background: none; border: 0; cursor: pointer;
  color: var(--muted);
  transition: all .15s;
}
.cfgx-stage-tab:hover { color: var(--ink); }
.cfgx-stage-tab.active {
  background: var(--paper); color: var(--ink);
  box-shadow: 0 1px 3px rgba(15,13,12,0.06);
}

/* ───── Block / floor / building selectors ───── */
.cfgx-stage-controls {
  display: flex; gap: 8px; flex-wrap: wrap;
  padding: 16px 28px;
  border-bottom: 1px solid var(--line);
  background: var(--paper);
  align-items: center;
}
.cfgx-control-label {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  margin-right: 8px;
}
.cfgx-block-pill {
  padding: 9px 16px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid var(--line); background: #fbf8f2;
  color: var(--ink-2); cursor: pointer;
  transition: all .15s;
  display: inline-flex; align-items: center; gap: 8px;
}
.cfgx-block-pill:hover { border-color: var(--ink); }
.cfgx-block-pill.active {
  background: var(--ink); color: #f3e8da; border-color: var(--ink);
}
.cfgx-block-pill .count {
  font-size: 9px; opacity: 0.6; letter-spacing: 0.1em;
}
.cfgx-block-pill.active .count { opacity: 0.7; }

/* ───── Building / Site SVG canvas ───── */
.cfgx-canvas {
  flex: 1;
  position: relative;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(251,248,242,1) 0%, rgba(236,230,216,1) 100%);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  min-height: 480px;
}
.cfgx-canvas::before {
  /* paper grid */
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(15,13,12,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,13,12,0.025) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}

.cfgx-zoombar {
  position: absolute; bottom: 18px; left: 18px;
  display: flex; gap: 4px;
  background: #fbf8f2;
  border: 1px solid var(--line);
  padding: 4px;
  z-index: 4;
}
.cfgx-zoombar button {
  width: 32px; height: 32px;
  background: none; border: 0; cursor: pointer;
  font-family: var(--mono); font-size: 14px;
  color: var(--ink-2);
}
.cfgx-zoombar button:hover { background: var(--paper-2); }

/* Compass + scale */
.cfgx-compass {
  position: absolute; top: 18px; right: 18px;
  width: 56px; height: 56px;
  background: #fbf8f2;
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  z-index: 4;
}
.cfgx-compass svg { width: 38px; height: 38px; }

.cfgx-legend-floating {
  position: absolute; bottom: 18px; right: 18px;
  background: #fbf8f2;
  border: 1px solid var(--line);
  padding: 10px 14px;
  display: flex; gap: 14px; flex-wrap: wrap;
  max-width: 520px;
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  z-index: 4;
}
.cfgx-legend-floating span {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--muted);
}
.cfgx-legend-floating i {
  width: 10px; height: 10px; display: inline-block;
}
.cfgx-legend-floating i.av { background: rgba(74,90,58,.7); }
.cfgx-legend-floating i.rs { background: rgba(181,138,58,.7); }
.cfgx-legend-floating i.so { background: rgba(138,58,61,.7); }

/* SVG building 3D-ish exploded view */
.cfgx-svg {
  width: 100%; height: 100%;
  position: relative; z-index: 1;
}

/* Site view (4 buildings on plot) */
.cfgx-svg .plot-outline {
  fill: rgba(74, 90, 58, 0.06);
  stroke: rgba(74, 90, 58, 0.4);
  stroke-width: 0.15;
  stroke-dasharray: 0.8 0.5;
}
.cfgx-svg .road {
  fill: rgba(15,13,12,0.04);
  stroke: rgba(15,13,12,0.2);
  stroke-width: 0.1;
}
.cfgx-svg .pool {
  fill: rgba(74,114,160,0.18);
  stroke: rgba(74,114,160,0.5);
  stroke-width: 0.12;
}
.cfgx-svg .garden {
  fill: rgba(74,90,58,0.1);
  stroke: rgba(74,90,58,0.3);
  stroke-width: 0.1;
  stroke-dasharray: 0.4 0.25;
}
.cfgx-svg .tree {
  fill: rgba(74,90,58,0.5);
}
.cfgx-svg .label-mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.4px; letter-spacing: 0.15em;
  fill: var(--muted); text-transform: uppercase;
}
.cfgx-svg .label-tight {
  font-family: 'Inter Tight', sans-serif;
  font-size: 2.2px; letter-spacing: -0.02em;
  fill: var(--ink); font-weight: 500;
}

/* Building blocks on site view */
.cfgx-svg .block {
  cursor: pointer;
  transition: opacity .2s;
}
.cfgx-svg .block .block-fill {
  fill: var(--paper);
  stroke: var(--ink);
  stroke-width: 0.2;
  transition: fill .15s;
}
.cfgx-svg .block .block-shadow {
  fill: rgba(15,13,12,0.12);
}
.cfgx-svg .block:hover .block-fill { fill: rgba(91,20,24,0.14); stroke: var(--brand); }
.cfgx-svg .block.active .block-fill { fill: var(--brand); stroke: var(--brand); }
.cfgx-svg .block.active text { fill: #f3e8da; }
.cfgx-svg .block .block-label {
  font-family: 'Inter Tight', sans-serif;
  font-size: 3.6px; letter-spacing: -0.05em; font-weight: 500;
  text-anchor: middle; dominant-baseline: middle;
  fill: var(--ink);
}
.cfgx-svg .block .block-units {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.4px; letter-spacing: 0.18em;
  text-anchor: middle; fill: var(--muted);
}
.cfgx-svg .block.active .block-units { fill: rgba(243,232,218,0.7); }

/* Exploded building (3D-ish stacked floors) */
.cfgx-svg .floor-card {
  cursor: pointer;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), opacity .2s;
}
.cfgx-svg .floor-card .slab {
  fill: #fbf8f2; stroke: var(--ink); stroke-width: 0.2;
  filter: drop-shadow(0 1.2px 1.4px rgba(15,13,12,0.06));
}
.cfgx-svg .floor-card.dim { opacity: 0.45; }
.cfgx-svg .floor-card.active .slab { stroke: var(--brand); stroke-width: 0.4; }

.cfgx-svg .unit {
  cursor: pointer;
  transition: opacity .2s;
}
.cfgx-svg .unit .u-fill {
  stroke: rgba(15,13,12,0.5);
  stroke-width: 0.18;
  transition: all .15s;
}
.cfgx-svg .unit.available .u-fill { fill: rgba(74,90,58,0.32); }
.cfgx-svg .unit.reserved  .u-fill { fill: rgba(181,138,58,0.32); }
.cfgx-svg .unit.sold      .u-fill { fill: rgba(138,58,61,0.42); }
.cfgx-svg .unit:hover .u-fill { fill-opacity: 0.62; stroke: var(--ink); stroke-width: 0.32; }
.cfgx-svg .unit.selected .u-fill { stroke: var(--ink); stroke-width: 0.5; fill-opacity: 0.86; }
.cfgx-svg .unit.dim { opacity: 0.22; }
.cfgx-svg .unit text {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.7px; letter-spacing: 0.05em;
  fill: var(--ink); pointer-events: none;
  text-anchor: middle; dominant-baseline: middle;
}

/* Floor stripes label */
.cfgx-svg .floor-strip-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.3px; letter-spacing: 0.22em;
  fill: var(--muted); text-transform: uppercase;
}

/* Hover tooltip — anchored */
.cfgx-tooltip {
  position: absolute; pointer-events: none; z-index: 5;
  background: #0c0a09; color: #f3e8da;
  padding: 12px 16px;
  min-width: 180px;
  transform: translate(-50%, calc(-100% - 12px));
  opacity: 0; transition: opacity .12s;
  filter: drop-shadow(0 6px 18px rgba(15,13,12,0.25));
}
.cfgx-tooltip.show { opacity: 1; }
.cfgx-tooltip::after {
  content: ''; position: absolute;
  left: 50%; bottom: -6px; transform: translateX(-50%);
  border: 6px solid transparent; border-top-color: #0c0a09; border-bottom: 0;
}
.cfgx-tooltip .ttip-head {
  font-family: var(--tight); font-size: 16px; letter-spacing: -0.01em;
  font-weight: 500; margin-bottom: 4px;
}
.cfgx-tooltip .ttip-typo {
  font-family: var(--serif); font-style: italic;
  font-size: 13px; opacity: 0.7; margin-bottom: 8px;
}
.cfgx-tooltip .ttip-row {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  opacity: 0.7; margin-top: 2px;
}
.cfgx-tooltip .ttip-state {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; margin-top: 8px;
  display: inline-flex; align-items: center; gap: 6px;
}
.cfgx-tooltip .ttip-state .dot { width: 6px; height: 6px; display: inline-block; }
.cfgx-tooltip .ttip-state.available { color: #b8d49b; }
.cfgx-tooltip .ttip-state.available .dot { background: #b8d49b; }
.cfgx-tooltip .ttip-state.reserved { color: #e6c886; }
.cfgx-tooltip .ttip-state.reserved .dot { background: #e6c886; }
.cfgx-tooltip .ttip-state.sold { color: #d49495; }
.cfgx-tooltip .ttip-state.sold .dot { background: #d49495; }
.cfgx-tooltip .ttip-price {
  font-family: var(--tight); font-size: 18px; font-weight: 500;
  letter-spacing: -0.02em; margin-top: 6px;
}

/* ───── Side inspector ───── */
.cfgx-side-empty {
  padding: 64px 32px;
  display: flex; flex-direction: column; gap: 18px;
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
}
.cfgx-side-empty .ico {
  width: 48px; height: 48px;
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
}
.cfgx-side-empty h3 {
  font-family: var(--tight); font-weight: 400; font-size: 28px;
  letter-spacing: -0.025em; line-height: 1.05; margin: 0;
}
.cfgx-side-empty h3 em {
  font-family: var(--serif); font-style: italic; color: var(--brand);
}
.cfgx-side-empty p {
  font-family: var(--serif); font-style: italic;
  font-size: 16px; color: var(--ink-2); line-height: 1.5;
  max-width: 32ch; margin: 0;
}
.cfgx-side-empty .hints {
  margin-top: 16px;
  display: flex; flex-direction: column; gap: 10px;
  width: 100%;
}
.cfgx-side-empty .hint {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 0;
  border-top: 1px dashed var(--line-2);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
}
.cfgx-side-empty .hint .k {
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  font-size: 11px; letter-spacing: 0;
  color: var(--ink);
}

/* When a unit is selected */
.cfgx-side-card {
  display: flex; flex-direction: column;
}
.cfgx-side-head {
  padding: 24px 28px 20px;
  border-bottom: 1px solid var(--line);
}
.cfgx-side-head .crumbs {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  margin-bottom: 14px;
}
.cfgx-side-head .crumbs span + span::before {
  content: '·'; margin: 0 8px; color: var(--line-2);
}
.cfgx-side-head h2 {
  font-family: var(--tight); font-weight: 400;
  font-size: 36px; letter-spacing: -0.03em; line-height: 1; margin: 0;
}
.cfgx-side-head h2 em {
  font-family: var(--serif); font-style: italic; color: var(--brand);
}
.cfgx-side-head .sub {
  font-family: var(--serif); font-style: italic;
  font-size: 16px; color: var(--ink-2);
  margin-top: 8px;
}
.cfgx-side-head .state {
  margin-top: 12px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase;
}
.cfgx-side-head .state.available { background: rgba(74,90,58,0.14); color: #4a5a3a; }
.cfgx-side-head .state.reserved  { background: rgba(181,138,58,0.16); color: #8b6920; }
.cfgx-side-head .state.sold      { background: rgba(138,58,61,0.16); color: var(--brand); }
.cfgx-side-head .state .dot { width: 6px; height: 6px; }

/* Plan thumbnail */
.cfgx-side-plan {
  padding: 0 28px;
  margin-top: 20px;
}
.cfgx-side-plan-frame {
  position: relative;
  aspect-ratio: 5/4;
  background: var(--paper-2);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.cfgx-side-plan-frame::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(15,13,12,0.03) 0 6px, transparent 6px 12px);
}
.cfgx-side-plan-frame svg { width: 88%; height: 88%; position: relative; z-index: 1; }
.cfgx-side-plan-cap {
  margin-top: 8px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  display: flex; justify-content: space-between;
}

/* Plano de la vivienda dentro de la ficha lateral */
.cfgx-side-plan {
  margin: 22px 28px 0;
  padding: 16px;
  background: #fbf8f2;
  border: 1px solid var(--line);
}
.cfgx-side-plan-label {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 10px;
}
.cfgx-side-plan img {
  display: block; width: 100%; height: auto;
  background: #fff;
}

/* Spec grid */
.cfgx-side-specs {
  margin: 24px 28px 0;
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border: 1px solid var(--line);
  background: var(--line);
  gap: 1px;
}
.cfgx-spec {
  background: #fbf8f2;
  padding: 14px 14px 14px 16px;
}
.cfgx-spec .l {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
}
.cfgx-spec .v {
  font-family: var(--tight); font-size: 22px; letter-spacing: -0.02em;
  margin-top: 6px;
}
.cfgx-spec .u {
  font-family: var(--mono); font-size: 10px; color: var(--muted);
  margin-left: 4px;
}

/* Bullets */
.cfgx-side-incl {
  margin: 24px 28px 0;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.cfgx-side-incl h4 {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  margin: 0 0 14px; font-weight: 500;
}
.cfgx-side-incl ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px;
}
.cfgx-side-incl li {
  font-size: 13px; line-height: 1.4;
  display: flex; align-items: flex-start; gap: 8px;
  color: var(--ink-2);
}
.cfgx-side-incl li::before {
  content: ''; flex: 0 0 6px; height: 1px;
  background: var(--brand); margin-top: 9px;
}

/* Sticky summary footer */
.cfgx-foot {
  position: sticky; bottom: 0; z-index: 35;
  background: #0c0a09; color: #f3e8da;
  border-top: 1px solid #1a1715;
}
.cfgx-foot-row {
  max-width: 1480px; margin: 0 auto;
  padding: 18px 32px;
  display: flex; align-items: center; gap: 28px;
}
.cfgx-foot-block {
  display: flex; flex-direction: column; gap: 4px;
  padding-right: 28px;
  border-right: 1px solid rgba(243,232,218,0.12);
}
.cfgx-foot-block:last-of-type { border-right: 0; }
.cfgx-foot-block .l {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; opacity: 0.55;
}
.cfgx-foot-block .v {
  font-family: var(--tight); font-weight: 400;
  font-size: 18px; letter-spacing: -0.015em;
}
.cfgx-foot-block .v em {
  font-family: var(--serif); font-style: italic; opacity: 0.8;
  font-size: 14px; margin-left: 6px;
}
.cfgx-foot-block.price .v { font-size: 26px; font-weight: 300; letter-spacing: -0.025em; }
.cfgx-foot-block.price .iva {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em;
  opacity: 0.55; text-transform: uppercase;
}
.cfgx-foot-cta {
  margin-left: auto;
  display: flex; gap: 10px;
}
.cfgx-foot-cta .btn {
  white-space: nowrap;
}
.cfgx-foot-cta .btn-light {
  background: transparent; color: #f3e8da; border: 1px solid rgba(243,232,218,0.4);
}
.cfgx-foot-cta .btn-light:hover { background: rgba(243,232,218,0.12); }
.cfgx-foot-cta .btn-go {
  background: #f3e8da; color: #0c0a09; border: 1px solid #f3e8da;
}
.cfgx-foot-cta .btn-go:hover { background: #fff; }
.cfgx-foot-cta .btn-go.disabled {
  opacity: 0.35; pointer-events: none;
}

@media (max-width: 880px) {
  .cfgx-foot-row { flex-wrap: wrap; gap: 12px; padding: 14px 18px; }
  .cfgx-foot-block { padding-right: 14px; }
  .cfgx-foot-cta { margin-left: 0; width: 100%; }
  .cfgx-foot-cta .btn { flex: 1; justify-content: center; }
}

/* ───── STEP 2 — Personalización (acabados) ───── */

/* ─── Kitchen photo scene (room === 'cocina') ─── */
.cfgx-cocina-scene {
  position: relative;
  width: 100%;
  display: flex; flex-direction: column;
  gap: 20px;
  padding: 96px 28px 16px;
  z-index: 2;
}
.cfgx-cocina-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 1000 / 489;
  background: #ddd;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 16px 40px -22px rgba(20,15,5,0.45);
}
.cfgx-cocina-photo.cfgx-salon-photo {
  aspect-ratio: 1338 / 800;
}
.cfgx-cocina-photo img {
  display: block; width: 100%; height: 100%;
  object-fit: cover;
}
.cfgx-cocina-photo-tag {
  position: absolute;
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(15,13,12,0.88);
  color: #f3e8da;
  padding: 8px 12px 8px 8px;
  font-family: var(--mono);
  letter-spacing: 0.06em;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transform: translate(-2px, -2px);
  max-width: 240px;
}
.cfgx-cocina-photo-tag .num {
  flex: 0 0 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #d97f2c; color: #fff;
  font-size: 11px; font-weight: 600;
}
.cfgx-cocina-photo-tag .tg-l {
  font-size: 8.5px; letter-spacing: 0.22em; text-transform: uppercase;
  opacity: 0.65; margin-bottom: 3px;
}
.cfgx-cocina-photo-tag .tg-v {
  font-size: 11.5px; font-weight: 500;
  display: flex; align-items: center; gap: 7px;
}
.cfgx-cocina-photo-tag .dot {
  display: inline-block; width: 12px; height: 12px;
  border: 1px solid rgba(255,255,255,0.4);
  flex: 0 0 12px;
}

.cfgx-cocina-info {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px;
}
.cfgx-cocina-info-card {
  background: rgba(255,253,247,0.82);
  border: 1px solid var(--line);
  padding: 16px 18px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.cfgx-cocina-info-card .hd {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 12px;
}
.cfgx-cocina-info-card .hd .num {
  flex: 0 0 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #d97f2c; color: #fff;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
}
.cfgx-cocina-info-card .hd h4 {
  margin: 0; font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--ink);
}
.cfgx-cocina-info-card ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 12px;
}
.cfgx-cocina-info-card li {
  border-left: 2px solid #e3dcc9;
  padding: 2px 0 2px 12px;
}
.cfgx-cocina-info-card .nm {
  font-size: 13px; font-weight: 500; color: var(--ink);
  letter-spacing: -0.005em;
}
.cfgx-cocina-info-card .ds {
  font-size: 11.5px; line-height: 1.45; color: var(--ink-2);
  margin-top: 3px;
}
.cfgx-cocina-info-card .rf {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--muted);
  margin-top: 4px;
}

.campana-pick {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.campana-pick .lbl {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  margin-bottom: 8px;
}
.campana-pick .opts {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.cmp-opt {
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  padding: 9px 12px;
  background: #fff;
  border: 1px solid var(--line);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: all .15s ease;
}
.cmp-opt .nm { font-size: 12px; font-weight: 500; color: var(--ink); }
.cmp-opt .pr { font-family: var(--mono); font-size: 9px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted); }
.cmp-opt:hover { border-color: var(--ink); }
.cmp-opt.on { background: #0c0a09; border-color: #0c0a09; }
.cmp-opt.on .nm { color: #f3e8da; }
.cmp-opt.on .pr { color: rgba(243,232,218,0.65); }

/* When kitchen photo scene is active, give the stage room to breathe */
.cfgx-pers-stage:has(.cfgx-cocina-scene) {
  align-items: stretch;
  justify-content: flex-start;
  padding: 0;
}
.cfgx-pers-stage:has(.cfgx-cocina-scene) .cfgx-pers-meta {
  margin-bottom: 0;
}

/* ─── End kitchen photo scene ─── */

/* Column inspector becomes wider; stage shows 3D-ish room render */
.cfgx-pers-stage {
  background: linear-gradient(160deg, #f1ece1 0%, #e1d8c4 100%);
  flex: 1;
  position: relative;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  min-height: 540px;
}
.cfgx-pers-stage::after {
  /* faint vignette */
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 60%, transparent 50%, rgba(15,13,12,0.18) 100%);
  pointer-events: none;
}
.cfgx-room {
  width: 78%; max-width: 720px;
  aspect-ratio: 16/10;
  background: #fbf8f2;
  position: relative;
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  overflow: hidden;
  filter: drop-shadow(0 30px 60px rgba(15,13,12,0.18));
}
.cfgx-room-header {
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  background: rgba(251,248,242,0.6);
  z-index: 2;
}
.cfgx-room-canvas {
  flex: 1;
  position: relative;
  overflow: hidden;
}
/* The room canvas is layered: back wall, side walls (perspective), floor */
.cfgx-room-floor {
  position: absolute; inset: 50% 0 0 0;
  transform-origin: top center;
  transform: perspective(900px) rotateX(58deg);
  background: var(--floor-color, #c8a878);
  background-image: var(--floor-pattern, repeating-linear-gradient(
    90deg,
    rgba(0,0,0,0.06) 0 1px, transparent 1px 12%,
    rgba(0,0,0,0.04) 12% 12.5%, transparent 12.5% 24%
  ));
  background-size: var(--floor-size, 80px 100%);
}
.cfgx-room-wall-back {
  position: absolute; left: 14%; right: 14%; top: 0; bottom: 50%;
  background: var(--wall-color, #ece6d8);
}
.cfgx-room-wall-left {
  position: absolute; left: 0; top: 0; bottom: 50%; width: 14%;
  background: var(--wall-color, #ece6d8);
  transform-origin: right center;
  transform: perspective(900px) rotateY(28deg);
  filter: brightness(0.92);
}
.cfgx-room-wall-right {
  position: absolute; right: 0; top: 0; bottom: 50%; width: 14%;
  background: var(--wall-color, #ece6d8);
  transform-origin: left center;
  transform: perspective(900px) rotateY(-28deg);
  filter: brightness(0.92);
}
/* Kitchen island silhouette overlay */
.cfgx-room-island {
  position: absolute; bottom: 12%; left: 50%; transform: translateX(-50%);
  width: 38%; height: 14%;
  background: var(--island-color, #2a2825);
  z-index: 2;
  border-top: 1px solid rgba(0,0,0,0.2);
}
.cfgx-room-island::after {
  content: ''; position: absolute;
  left: 0; right: 0; top: -3px; height: 6px;
  background: var(--counter-color, #d8d2c3);
}
.cfgx-room-window {
  position: absolute; top: 14%; left: 30%; width: 40%; height: 30%;
  background: linear-gradient(180deg, #d8e0d6 0%, #b8c2bc 100%);
  border: 1px solid rgba(15,13,12,0.4);
  z-index: 2;
}
.cfgx-room-window::before, .cfgx-room-window::after {
  content: ''; position: absolute;
  background: rgba(15,13,12,0.5);
}
.cfgx-room-window::before { left: 50%; top: 0; bottom: 0; width: 1px; }
.cfgx-room-window::after { top: 50%; left: 0; right: 0; height: 1px; }

.cfgx-room-tag {
  position: absolute;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  background: rgba(251,248,242,0.92);
  border: 1px solid var(--line);
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink);
  z-index: 5;
}
.cfgx-room-tag .tag-num {
  width: 16px; height: 16px;
  background: var(--brand); color: #f3e8da;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--tight); font-size: 10px; letter-spacing: 0;
}

.cfgx-pers-meta {
  position: absolute; left: 22px; top: 22px;
  z-index: 4;
  display: flex; flex-direction: column; gap: 6px;
}
.cfgx-pers-meta .kicker {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
}
.cfgx-pers-meta .title {
  font-family: var(--tight); font-weight: 400;
  font-size: 28px; letter-spacing: -0.025em; line-height: 1;
}
.cfgx-pers-meta .title em {
  font-family: var(--serif); font-style: italic; color: var(--brand);
}
.cfgx-pers-meta .room-name {
  margin-top: 6px;
  font-family: var(--serif); font-style: italic;
  font-size: 16px; color: var(--ink-2);
}

/* Room switcher */
.cfgx-room-switch {
  position: absolute; right: 22px; top: 22px;
  z-index: 4;
  display: flex; flex-direction: column; gap: 4px;
  background: #fbf8f2;
  border: 1px solid var(--line);
  padding: 4px;
}
.cfgx-room-switch button {
  padding: 8px 12px;
  background: none; border: 0; cursor: pointer;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
  text-align: left;
  display: flex; align-items: center; gap: 8px;
  min-width: 140px;
}
.cfgx-room-switch button:hover { background: var(--paper-2); color: var(--ink); }
.cfgx-room-switch button.active { background: var(--ink); color: #f3e8da; }
.cfgx-room-switch button .ico {
  width: 14px; height: 14px;
}

/* Inspector — accordion of categories */
.cfgx-pers-side {
  display: flex; flex-direction: column;
}
.cfgx-pers-cats {
  border-bottom: 1px solid var(--line);
}
.cfgx-pers-cat {
  border-bottom: 1px solid var(--line);
}
.cfgx-pers-cat:last-child { border-bottom: 0; }
.cfgx-pers-cat-head {
  width: 100%;
  padding: 18px 28px;
  background: none; border: 0; cursor: pointer;
  display: flex; align-items: center; gap: 16px;
  text-align: left;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-2);
  transition: background .15s;
}
.cfgx-pers-cat-head:hover { background: var(--paper-2); }
.cfgx-pers-cat.open .cfgx-pers-cat-head { background: var(--paper-2); color: var(--brand); }
.cfgx-pers-cat-head .num {
  font-family: var(--tight); font-size: 12px; letter-spacing: 0;
  color: var(--muted); width: 22px;
}
.cfgx-pers-cat-head .lbl {
  flex: 1;
  font-family: var(--tight); font-size: 17px; letter-spacing: -0.01em;
  font-weight: 500; text-transform: none; color: var(--ink);
}
.cfgx-pers-cat-head .pick {
  font-family: var(--serif); font-style: italic;
  font-size: 14px; color: var(--ink-2);
  text-transform: none; letter-spacing: 0;
  text-align: right; flex: 0 0 auto;
}
.cfgx-pers-cat-head .chev {
  width: 14px; height: 14px;
  transition: transform .2s;
}
.cfgx-pers-cat.open .cfgx-pers-cat-head .chev { transform: rotate(180deg); }
.cfgx-pers-cat-head .delta {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--brand); margin-left: 12px;
}

.cfgx-pers-cat-body {
  padding: 4px 28px 24px;
  display: none;
  background: var(--paper-2);
}
.cfgx-pers-cat.open .cfgx-pers-cat-body { display: block; }

/* Option card grid */
.cfgx-opts {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 10px;
}
.cfgx-opt {
  background: #fbf8f2;
  border: 1px solid var(--line);
  padding: 10px;
  cursor: pointer;
  transition: border-color .15s, transform .15s;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
  text-align: left;
}
.cfgx-opt:hover { border-color: var(--ink); }
.cfgx-opt.selected {
  border-color: var(--brand); border-width: 2px; padding: 9px;
}
.cfgx-opt.selected::before {
  content: '✓';
  position: absolute; top: 6px; right: 8px;
  width: 18px; height: 18px;
  background: var(--brand); color: #f3e8da;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--tight); font-size: 11px;
  z-index: 2;
}
.cfgx-opt-swatch {
  aspect-ratio: 4/3;
  background: var(--swatch, #c0a07c);
  position: relative;
  overflow: hidden;
}
.cfgx-opt-swatch.pat-wood {
  background:
    repeating-linear-gradient(90deg,
      rgba(0,0,0,0.05) 0 1px, transparent 1px 16%,
      rgba(0,0,0,0.04) 16% 16.6%, transparent 16.6% 32%),
    var(--swatch);
}
.cfgx-opt-swatch.pat-tile {
  background:
    linear-gradient(rgba(0,0,0,0.08) 1px, transparent 1px) 0 0/100% 33%,
    linear-gradient(90deg, rgba(0,0,0,0.08) 1px, transparent 1px) 0 0/33% 100%,
    var(--swatch);
}
.cfgx-opt-swatch.pat-stone {
  background:
    radial-gradient(circle at 20% 30%, rgba(0,0,0,0.06) 0 14%, transparent 14%),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,0.18) 0 10%, transparent 10%),
    radial-gradient(circle at 40% 80%, rgba(0,0,0,0.04) 0 12%, transparent 12%),
    var(--swatch);
}
.cfgx-opt-swatch.pat-flat { background: var(--swatch); }
.cfgx-opt-swatch.pat-fabric {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.06) 0 2px, transparent 2px 4px),
    var(--swatch);
}
.cfgx-opt-meta {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 6px;
}
.cfgx-opt-name {
  font-family: var(--tight); font-size: 13px; letter-spacing: -0.01em;
  font-weight: 500; line-height: 1.2;
}
.cfgx-opt-price {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  color: var(--brand);
  white-space: nowrap;
}
.cfgx-opt-price.included { color: var(--muted); }
.cfgx-opt-desc {
  font-family: var(--serif); font-style: italic;
  font-size: 12px; color: var(--muted); line-height: 1.35;
}
.cfgx-opt-tag {
  position: absolute; top: 6px; left: 6px;
  background: rgba(15,13,12,0.85); color: #f3e8da;
  padding: 3px 6px;
  font-family: var(--mono); font-size: 8px; letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* Toggle add-on (single switch with price) */
.cfgx-toggle-list {
  display: flex; flex-direction: column;
  margin-top: 10px;
}
.cfgx-toggle {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--line-2);
  cursor: pointer;
}
.cfgx-toggle:last-child { border-bottom: 0; }
.cfgx-toggle .tg-info {
  flex: 1;
}
.cfgx-toggle .tg-name {
  font-family: var(--tight); font-size: 15px; font-weight: 500;
  letter-spacing: -0.01em; line-height: 1.2;
}
.cfgx-toggle .tg-desc {
  font-family: var(--serif); font-style: italic;
  font-size: 13px; color: var(--muted); margin-top: 2px;
}
.cfgx-toggle .tg-price {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  color: var(--brand); white-space: nowrap;
}
.cfgx-toggle .tg-switch {
  flex: 0 0 38px; width: 38px; height: 22px;
  background: var(--paper-2);
  border: 1px solid var(--line-2);
  border-radius: 22px;
  position: relative;
  transition: all .2s;
}
.cfgx-toggle .tg-switch::after {
  content: ''; position: absolute;
  top: 2px; left: 2px; width: 16px; height: 16px;
  background: #fbf8f2; border-radius: 50%;
  border: 1px solid var(--line-2);
  transition: transform .2s;
}
.cfgx-toggle.on .tg-switch {
  background: var(--brand); border-color: var(--brand);
}
.cfgx-toggle.on .tg-switch::after {
  transform: translateX(16px); border-color: var(--brand-2);
}

/* Step 2 sticky right summary card (Tu configuración) */
.cfgx-summary-card {
  margin: 24px 28px 24px;
  padding: 20px;
  background: #0c0a09; color: #f3e8da;
}
.cfgx-summary-card h4 {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; opacity: 0.55; margin: 0 0 14px; font-weight: 500;
}
.cfgx-summary-card .row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(243,232,218,0.18);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
}
.cfgx-summary-card .row:last-of-type { border-bottom: 0; }
.cfgx-summary-card .row .l { opacity: 0.7; }
.cfgx-summary-card .row .v {
  font-family: var(--tight); font-size: 13px; letter-spacing: -0.01em;
}
.cfgx-summary-card .row .v em {
  font-family: var(--serif); font-style: italic; opacity: 0.7;
  font-size: 11px; margin-left: 6px;
}
.cfgx-summary-card .total {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid rgba(243,232,218,0.3);
  display: flex; justify-content: space-between; align-items: baseline;
}
.cfgx-summary-card .total .l {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; opacity: 0.7;
}
.cfgx-summary-card .total .v {
  font-family: var(--tight); font-weight: 300; font-size: 26px;
  letter-spacing: -0.025em;
}

/* Step 1 — site/building view selector buttons inside stage bar */
.cfgx-view-toggle {
  display: flex; gap: 4px;
  margin-left: 16px;
  background: var(--paper-2);
  padding: 3px;
}
.cfgx-view-toggle button {
  padding: 7px 12px;
  background: none; border: 0;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--muted);
  cursor: pointer;
}
.cfgx-view-toggle button.active {
  background: #fbf8f2; color: var(--ink);
}

/* Floor list (left rail inside stage) */
.cfgx-floor-rail {
  position: absolute; left: 18px; top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  display: flex; flex-direction: column;
  background: #fbf8f2;
  border: 1px solid var(--line);
}
.cfgx-floor-rail button {
  padding: 12px 16px;
  background: none; border: 0; cursor: pointer;
  border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-2);
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  min-width: 110px; text-align: left;
}
.cfgx-floor-rail button:last-child { border-bottom: 0; }
.cfgx-floor-rail button:hover { background: var(--paper-2); }
.cfgx-floor-rail button.active {
  background: var(--brand); color: #f3e8da;
}
.cfgx-floor-rail button .nm {
  font-family: var(--tight); font-size: 13px; letter-spacing: -0.01em;
  font-weight: 500; text-transform: none;
}
.cfgx-floor-rail button .av {
  font-size: 9px; opacity: 0.7;
}

/* ───── Real plan overlay ───── */
.cfgx-plan-real {
  position: relative;
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  background: #fbf8f2;
}
.cfgx-plan-real-inner {
  position: relative;
  width: 100%; max-width: 1480px;
  aspect-ratio: 2620 / 1852;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #fbf8f2;
}
.cfgx-plan-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.cfgx-plan-svg .unit-real {
  cursor: pointer;
  pointer-events: all;
  transition: opacity .15s;
}
.cfgx-plan-svg .unit-real polygon {
  stroke-width: 0.18;
  transition: all .15s;
}
.cfgx-plan-svg .unit-real.available polygon { fill: rgba(74,90,58,0.32); stroke: rgba(74,90,58,0.85); }
.cfgx-plan-svg .unit-real.reserved  polygon { fill: rgba(181,138,58,0.32); stroke: rgba(181,138,58,0.85); }
.cfgx-plan-svg .unit-real.sold      polygon { fill: rgba(138,58,61,0.42); stroke: rgba(138,58,61,0.9); }
.cfgx-plan-svg .unit-real:hover polygon { fill-opacity: 0.65; stroke-width: 0.32; }
.cfgx-plan-svg .unit-real.selected polygon {
  stroke: var(--ink); stroke-width: 0.5; fill-opacity: 0.85;
}
.cfgx-plan-svg .unit-real.dim { opacity: 0.22; }

/* ─── Viviendas marcadas en el plano general nivel 02 ─── */
/* Sobre-escriben el fill del estado para mostrar el color asignado por el cliente */
.cfgx-plan-svg .unit-real.sel-roja     polygon { fill: rgba(213, 64, 64, 0.55);  stroke: rgba(160, 32, 32, 0.95); }
.cfgx-plan-svg .unit-real.sel-amarilla polygon { fill: rgba(232, 188, 56, 0.60); stroke: rgba(160, 124, 24, 0.95); }
.cfgx-plan-svg .unit-real.sel-morada   polygon { fill: rgba(140, 88, 184, 0.55); stroke: rgba(94, 50, 138, 0.95); }
.cfgx-plan-svg .unit-real.sel-verde    polygon { fill: rgba(72, 156, 96, 0.55);  stroke: rgba(36, 108, 64, 0.95); }
.cfgx-plan-svg .unit-real[class*="sel-"]:hover polygon { fill-opacity: 0.85; stroke-width: 0.36; }
.cfgx-plan-svg .unit-real[class*="sel-"].selected polygon {
  stroke: var(--ink); stroke-width: 0.55; fill-opacity: 0.92;
}

/* Etiqueta de color sobre la vivienda destacada */
.cfgx-plan-svg .sel-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.95px; letter-spacing: 0.2em;
  text-transform: uppercase;
  fill: rgba(15,13,12,0.85);
  pointer-events: none;
  text-anchor: middle;
}
.cfgx-plan-svg .unit-real text {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.2px; letter-spacing: 0.05em;
  fill: var(--ink); pointer-events: none;
  text-anchor: middle; dominant-baseline: middle;
  font-weight: 600;
}
.cfgx-plan-svg .block-overlay {
  fill: rgba(15,13,12,0.06);
  stroke: rgba(15,13,12,0.35);
  stroke-width: 0.12;
  stroke-dasharray: 0.5 0.4;
  pointer-events: none;
}
.cfgx-plan-svg .block-overlay.pending { fill: rgba(15,13,12,0.18); }
.cfgx-plan-svg .block-overlay-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.1px; letter-spacing: 0.22em;
  fill: rgba(15,13,12,0.7);
  text-transform: uppercase;
  text-anchor: middle;
  pointer-events: none;
}
.cfgx-plan-real .level-badge {
  position: absolute; top: 14px; left: 14px;
  background: #0c0a09; color: #f3e8da;
  padding: 8px 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase;
  z-index: 4;
}
.cfgx-plan-real .level-note {
  position: absolute; bottom: 14px; left: 14px; right: 200px;
  background: rgba(251,248,242,0.95);
  border: 1px solid var(--line);
  padding: 10px 14px;
  font-family: var(--serif); font-style: italic;
  font-size: 13px; color: var(--ink-2);
  z-index: 4;
  max-width: 540px;
}

/* Section heading inside stage (Step 2) */
.cfgx-pers-cats-header {
  padding: 18px 28px;
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}
.cfgx-pers-cats-header .lbl {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--muted);
}
.cfgx-pers-cats-header h2 {
  font-family: var(--tight); font-weight: 400;
  font-size: 28px; letter-spacing: -0.025em; line-height: 1; margin: 4px 0 0;
}
.cfgx-pers-cats-header h2 em {
  font-family: var(--serif); font-style: italic; color: var(--brand);
}

/* Quick saved-presets row */
.cfgx-presets {
  display: flex; gap: 8px;
  padding: 14px 28px;
  border-bottom: 1px solid var(--line);
  background: var(--paper);
  overflow-x: auto;
}
.cfgx-preset {
  min-width: 130px;
  padding: 10px 14px;
  background: #fbf8f2;
  border: 1px solid var(--line);
  cursor: pointer;
  transition: border-color .15s;
  text-align: left;
}
.cfgx-preset:hover { border-color: var(--ink); }
.cfgx-preset.active { border-color: var(--brand); border-width: 2px; padding: 9px 13px; }
.cfgx-preset .nm {
  font-family: var(--tight); font-size: 14px; letter-spacing: -0.01em;
  font-weight: 500;
}
.cfgx-preset .dl {
  font-family: var(--serif); font-style: italic;
  font-size: 11px; color: var(--muted); margin-top: 2px;
}
.cfgx-preset .pr {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  color: var(--brand); margin-top: 6px;
}
