/* ============================================================
   BAU TEAM · Configurator engine styles  (namespace: .cx-)
   Shared by all *-konfigurator.html pages. Rendered by
   assets/configurator.js from a per-page CX_CONFIG object.
   Reuses CSS variables from bau.css (--ink, --accent, --mono …).
   ============================================================ */

.cx{border:1px solid var(--ink);background:#fff}

/* Step bar */
.cx-bar{display:flex;border-bottom:1px solid var(--ink)}
.cx-bar .st{flex:1;padding:14px 16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);border-right:1px solid var(--line-2);display:flex;gap:9px;align-items:center}
.cx-bar .st:last-child{border-right:0}
.cx-bar .st .n{display:grid;place-items:center;width:22px;height:22px;border:1px solid var(--ink);border-radius:50%;font-size:11px;color:var(--ink);flex:0 0 auto}
.cx-bar .st.on{color:var(--ink)}
.cx-bar .st.on .n{background:var(--accent);border-color:var(--accent);color:#000}
.cx-bar .st.done .n{background:#000;border-color:#000;color:#fff}

/* Panels */
.cx-panel{padding:32px 28px}
.cx-panel h2{font-size:clamp(22px,2.6vw,32px);margin:0 0 6px;letter-spacing:-.01em}
.cx-panel .sub{color:var(--ink-2);font-size:15px;margin:0 0 24px;max-width:62ch}

/* Card options (single-select) */
.cx-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.cx-cards.cols3{grid-template-columns:repeat(3,1fr)}
.cx-cards.cols4{grid-template-columns:repeat(4,1fr)}
.cx-opt{border:1px solid var(--ink);background:#fff;color:#000;padding:18px;text-align:left;cursor:pointer;border-radius:0;transition:background .2s,color .2s;display:flex;flex-direction:column;gap:5px;min-width:0}
.cx-opt:hover{background:var(--mute-2)}
.cx-opt.on{background:#000;color:#fff}
.cx-opt strong{font-size:16px;letter-spacing:-.01em;overflow-wrap:break-word}
.cx-opt small{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--mute)}
.cx-opt.on small{color:#aaa}

/* Chips (multi-select) */
.cx-chips{display:flex;flex-wrap:wrap;gap:10px}
.cx-chip{border:1px solid var(--ink);background:#fff;color:#000;padding:11px 18px;font-family:var(--mono);font-size:13px;letter-spacing:.03em;cursor:pointer;border-radius:999px;transition:background .2s,color .2s;display:inline-flex;gap:8px;align-items:center}
.cx-chip:hover{background:var(--mute-2)}
.cx-chip.on{background:#000;color:#fff}
.cx-chip .px{font-size:11px;color:var(--mute)}
.cx-chip.on .px{color:#aaa}

/* Number / text fields */
.cx-field{margin-top:22px;max-width:320px}
.cx-field label{display:block;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);margin-bottom:8px}
.cx-field .inp{position:relative;display:flex;align-items:center}
.cx-field input{width:100%;border:1px solid var(--ink);padding:12px 13px;font-size:16px;box-sizing:border-box;border-radius:0;background:#fff;color:#000}
.cx-field input:focus{outline:2px solid var(--accent);outline-offset:-2px}
.cx-field .u{position:absolute;right:13px;font-family:var(--mono);font-size:13px;color:var(--mute);pointer-events:none}
.cx-sublabel{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);margin:24px 0 10px}

/* Nav */
.cx-nav{display:flex;justify-content:space-between;gap:12px;padding:22px 28px;border-top:1px solid var(--ink);background:var(--mute-2)}
.cx-nav button{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:13px 22px;border-radius:999px;cursor:pointer;border:1px solid #000}
.cx-nav .ghost{background:#fff;color:#000}
.cx-nav .ghost[disabled]{opacity:.35;cursor:default}
.cx-nav .primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}
.cx-nav .primary:hover{background:#000;border-color:#000;color:#fff}
.cx-nav .primary[disabled]{opacity:.45;cursor:default}

/* Summary rows */
.cx-sum{border:1px solid var(--line-2)}
.cx-sum div{display:flex;justify-content:space-between;gap:16px;padding:13px 16px;border-bottom:1px solid var(--line-2);font-size:14px}
.cx-sum div:last-child{border-bottom:0}
.cx-sum span{color:var(--mute);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.cx-sum strong{text-align:right}

/* Result / price panel */
.cx-result{border:1px solid var(--ink);margin-top:4px}
.cx-result .rhead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;padding:24px 24px 20px;background:#0b0b0b;color:#fff}
.cx-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#bbb;border:1px solid rgba(255,255,255,.22);padding:6px 12px;border-radius:999px}
.cx-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.cx-price{font-family:var(--display,inherit);font-size:clamp(30px,5vw,52px);line-height:1;letter-spacing:-.02em;margin:14px 0 4px}
.cx-price .to{opacity:.5;margin:0 .15em}
.cx-price-unit{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:#aaa}
.cx-result .rbody{padding:22px 24px}

/* Legal disclaimer block (single source, always shown) */
.cx-legal{border-left:3px solid var(--accent);background:var(--mute-2);padding:16px 18px;margin-top:18px}
.cx-legal p{margin:0;font-size:12.5px;line-height:1.6;color:#444}
.cx-legal p+p{margin-top:8px}
.cx-legal strong{color:var(--ink)}
.cx-legal .stand{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--mute);text-transform:uppercase;display:block;margin-top:10px}

@media(max-width:640px){
  .cx-bar .st .lbl{display:none}
  .cx-bar .st{justify-content:center;padding:14px 8px}
  .cx-panel{padding:26px 18px}
  .cx-nav{padding:18px}
  .cx-cards,.cx-cards.cols4,.cx-cards.cols3{grid-template-columns:1fr 1fr}
}
@media(max-width:460px){
  .cx-cards,.cx-cards.cols4,.cx-cards.cols3{grid-template-columns:1fr}
  .cx-field{max-width:none}
}
