/* Schweng-like UI (owned styling, no copied assets) */
.kp-schweng{ font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:#1a1a1a; }

.kp-topbar{
  height: 56px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 0 18px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  background:#fff;
}
.kp-topbar-left{ display:flex; align-items:center; gap: 14px; }
.kp-brand{ display:flex; align-items:center; gap: 10px; font-weight: 900; }
.kp-brand-mark{
  width: 20px; height: 20px;
  border-left: 4px solid #f06a00;
  border-top: 4px solid #f06a00;
  transform: skewX(-12deg);
  display:inline-block;
}
.kp-brand-text{ color:#f06a00; letter-spacing:.2px; }
.kp-product{ opacity:.8; font-size: 13px; }
.kp-topbar-right{ display:flex; gap:10px; }
.kp-topbtn{
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  border-radius: 8px;
  padding: 8px 10px;
  font-weight: 800;
  cursor:pointer;
}

.kp-shell{
  display:grid;
  grid-template-columns: 360px 1fr 340px;
  gap: 0;
  min-height: 640px;
}

.kp-leftpanel{
  border-right:1px solid rgba(0,0,0,.08);
  background:#f7f7f7;
  display:flex;
  flex-direction:column;
}

.kp-tabs{
  display:flex;
  gap: 0;
  padding: 10px 10px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  background:#fff;
}
.kp-tab{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 6px;
  padding: 10px 8px;
  border:0;
  background:transparent;
  cursor:pointer;
  font-weight: 900;
  font-size: 12px;
  opacity:.65;
}
.kp-tab .kp-ico{ width: 22px; height: 22px; color:#111; }
.kp-tab .kp-ico svg{ width:22px; height:22px; }
.kp-tab.is-active{
  opacity:1;
  color:#f06a00;
  border-bottom: 3px solid #f06a00;
}
.kp-tab.is-active .kp-ico{ color:#f06a00; }

.kp-panel{
  padding: 12px 12px 18px;
  overflow:auto;
}
.kp-section{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow:hidden;
}
.kp-section-head{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 12px 12px;
  border:0;
  background:#fff;
  cursor:pointer;
  font-weight: 950;
}
.kp-section.is-open .kp-section-head{
  border-left: 4px solid #f06a00;
  padding-left: 8px;
}
.kp-section-body{ display:none; padding: 10px 12px 12px; }
.kp-section.is-open .kp-section-body{ display:block; }
.kp-field2{ margin-bottom: 12px; }
.kp-field2-label{ font-size: 12px; font-weight: 900; opacity:.85; margin-bottom: 6px; }

.kp-row{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.kp-range{ font-size: 11px; opacity:.6; white-space:nowrap; }

.kp-stepper{
  display:grid;
  grid-template-columns: 1fr auto auto auto;
  align-items:center;
  gap: 8px;
  width: 100%;
  border:1px solid rgba(0,0,0,.14);
  border-radius: 8px;
  padding: 6px 8px;
  background:#fff;
}
.kp-stepper-input{
  border:0;
  outline:none;
  font-weight: 900;
  font-size: 14px;
  width:100%;
}
.kp-stepper-unit{
  font-size: 12px;
  font-weight: 900;
  opacity:.7;
  padding-right: 4px;
}
.kp-stepper-btn{
  width: 34px; height: 34px;
  border-radius: 8px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer;
  font-weight: 900;
  font-size: 18px;
  line-height: 0;
}

.kp-pill{
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  cursor:pointer;
  user-select:none;
  font-weight: 900;
  margin-right: 8px;
  margin-bottom: 8px;
}
.kp-pill.is-active{ background:#111; color:#fff; border-color:#111; }
.kp-field2 .kp-radio .kp-pill{ border-radius:4px; padding: 12px 20px; }
.kp-field2 .kp-radio .kp-pill.is-active{ background:#e8f6ef; color:#1aa06a; border-color:#1aa06a; }
.kp-radio{ display:flex; flex-wrap:wrap; }

/* Drainage-Optionen (Screen-1 Look: weiße Buttons mit grünem Rahmen bei aktiv) */
.kp-radio.kp-radio--drain{ gap: 8px; }
.kp-pill.kp-pill--drain{
  border-radius: 4px;
  padding: 8px 12px;
  margin-right: 0;
  margin-bottom: 0;
  border: 1px solid rgba(0,0,0,.18);
  background: #fff;
  color: #1b1b1b;
}
.kp-pill.kp-pill--drain.is-active{
  background: #fff;
  color: #1aa06a;
  border-color: #1aa06a;
  box-shadow: 0 0 0 1px rgba(26,160,106,.25) inset;
}

.kp-tiles{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.kp-tile{
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  border-radius: 10px;
  padding: 10px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap: 8px;
  align-items:center;
  text-align:center;
}
.kp-tile.is-active{ border-color:#1aa06a; box-shadow: 0 0 0 2px rgba(26,160,106,.20) inset; }
.kp-tile-swatch{
  width: 52px; height: 36px;
  border-radius: 8px;
  border:1px solid rgba(0,0,0,.14);
}
.kp-tile-label{ font-weight: 900; font-size: 12px; opacity:.82; }

.kp-computed{
  border:1px dashed rgba(0,0,0,.18);
  border-radius: 8px;
  padding: 10px 12px;
  background: rgba(0,0,0,.02);
}
.kp-computed-value{ font-weight: 950; }

.kp-field2--standalone{ margin-bottom: 18px; }

 .kp-accessory{
  position:relative;
  border:1px solid rgba(26,160,106,.18);
  border-radius:32px;
  background:#fbfbfb;
  padding:26px 28px;
  display:grid;
  grid-template-columns:144px minmax(0,1fr);
  gap:26px;
  align-items:center;
  margin-top:10px;
  overflow:hidden;
}
.kp-accessory.is-active{
  box-shadow:0 0 0 1px rgba(26,160,106,.08) inset;
}
.kp-accessory.is-idle{
  border-color:rgba(0,0,0,.08);
}
.kp-accessory.is-idle .kp-accessory-state{
  display:none;
}
.kp-accessory-visual{
  width:132px;
  height:132px;
  border-radius:26px;
  background:#f2f2f2;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#404b53;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.kp-accessory-visual svg{ width:76px; height:52px; }
.kp-accessory-content{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  padding-right:78px;
}
.kp-accessory-kicker{
  color:#f06a00;
  font-size:15px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
  line-height:1.1;
}
.kp-accessory-title{
  font-size:22px;
  line-height:1.1;
  font-weight:500;
  color:#1aa06a;
  margin-bottom:10px;
  word-break:break-word;
}
.kp-accessory-subtitle{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  background:#ececec;
  color:#4a4a4a;
  font-size:14px;
  font-weight:800;
  line-height:1.1;
  margin-bottom:16px;
}
.kp-accessory-add-wrap{
  display:flex;
  width:100%;
}
.kp-accessory-state{
  position:absolute;
  top:18px;
  right:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.kp-accessory-close{
  width:46px;
  height:46px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:#fff;
  color:#21ad6e;
  cursor:pointer;
  padding:10px;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}
.kp-accessory-close svg{ width:100%; height:100%; }
.kp-accessory-add,
.kp-accessory-remove{
  min-height:52px;
  padding:0 22px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.10);
  background:#f1f1f1;
  color:#444;
  font-weight:800;
  font-size:16px;
  cursor:pointer;
  transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease;
}
.kp-accessory-add:hover,
.kp-accessory-remove:hover{
  background:#ebebeb;
  border-color:rgba(0,0,0,.14);
}
.kp-accessory-add{
  min-width:0;
}
.kp-accessory-remove-wrap{
  grid-column:1 / -1;
  padding-top:20px;
  margin-top:2px;
}
.kp-accessory-remove{
  width:100%;
  justify-content:center;
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:#f3f3f3;
  color:#4a4a4a;
}
.kp-accessory-remove span{ font-size:26px; line-height:1; margin-left:0; }
.kp-viewer2{
  position:relative;
  background: linear-gradient(#efefef,#dedede);
  overflow:hidden;
}
.kp-viewer2-canvas{
  position:absolute;
  inset: 0;
  cursor: grab;
}
.kp-viewer2-canvas:active{ cursor: grabbing; }
.kp-viewer2-tools{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}
.kp-toolbtn{
  border:1px solid rgba(0,0,0,.14);
  background:#f2f2f2;
  border-radius: 8px;
  padding: 10px 12px;
  font-weight: 900;
  cursor:pointer;
}
.kp-toolbtn-dark{ background:#2b2b2b; color:#fff; border-color:#2b2b2b; }

.kp-pricecard{
  background:#fff;
  border-left:1px solid rgba(0,0,0,.08);
  padding: 18px;
}
.kp-price-brand{ display:flex; flex-direction:column; gap: 10px; }
.kp-price-logo{ display:flex; align-items:center; gap: 10px; }
.kp-price-logo-text{ font-weight: 950; letter-spacing:.2px; color:#f06a00; }

.kp-montage-toggle{ display:flex; gap: 10px; }
.kp-mbtn{
  flex:1;
  padding: 10px 12px;
  border-radius: 8px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  cursor:pointer;
  font-weight: 950;
}
.kp-mbtn.is-active{ border-color:#1aa06a; color:#1aa06a; box-shadow: 0 0 0 2px rgba(26,160,106,.14) inset; }

.kp-oldprice{
  margin-top: 10px;
  color:#f06a00;
  text-decoration: line-through;
  font-weight: 950;
}
.kp-price-row{ display:flex; align-items:center; gap: 10px; margin-top: 6px; }
.kp-price{
  font-size: 44px;
  font-weight: 950;
  color:#1aa06a;
  letter-spacing:-.5px;
}
.kp-badge{
  background:#1aa06a;
  color:#fff;
  border-radius: 999px;
  padding: 8px 10px;
  font-weight: 950;
  font-size: 12px;
  white-space:nowrap;
}
.kp-vat{ margin-top: 6px; opacity:.75; font-weight: 700; }
.kp-cta{
  width:100%;
  margin-top: 12px;
  padding: 14px 12px;
  border-radius: 8px;
  border:1px solid rgba(0,0,0,.12);
  background:#f2f2f2;
  cursor:pointer;
  font-weight: 950;
  font-size: 16px;
}
.kp-cta-primary{
  background:#f06a00;
  color:#fff;
  border-color:#f06a00;
}
.kp-note{
  margin-top: 10px;
  color:#f06a00;
  font-weight: 900;
  font-size: 12px;
}


.kp-field--led_count .kp-stepper{
  grid-template-columns:1fr 0 auto auto;
  gap:0;
  padding:0;
  border:2px solid #f06a00;
  border-radius:4px;
  overflow:hidden;
  background:#fff;
}
.kp-field--led_count .kp-stepper-input{
  min-height:78px;
  padding:0 18px;
  font-size:24px;
  font-weight:500;
}
.kp-field--led_count .kp-stepper-unit{ width:0; padding:0; overflow:hidden; }
.kp-field--led_count .kp-stepper-btn{
  width:78px;
  height:78px;
  border:0;
  border-left:1px solid rgba(0,0,0,.12);
  border-radius:0;
  font-size:28px;
  color:#4a4a4a;
}
.kp-field--led_count .kp-stepper-btn:last-child{ color:#bdbdbd; }
.kp-field--led_count .kp-row{ display:block; }
.kp-field--led_control .kp-radio{ gap:10px; }
.kp-field--led_control .kp-pill{
  min-width:150px;
  min-height:60px;
  margin:0;
  border-radius:4px;
  padding:0 18px;
  border:2px solid #d4d4d4;
  background:#fff;
  color:#4a4a4a;
  font-size:18px;
  font-weight:700;
}
.kp-field--led_control .kp-pill.is-active{
  background:#fff;
  color:#1aa06a;
  border-color:#1aa06a;
  box-shadow:0 0 0 1px rgba(26,160,106,.12) inset;
}

/* reuse old error box if present */
.kp-error { padding: 12px; border-radius: 12px; border:1px solid rgba(200,0,0,.30); background: rgba(200,0,0,.06); }

@media (max-width: 1200px){
  .kp-shell{ grid-template-columns: 360px 1fr; }
  .kp-pricecard{ border-left:0; border-top:1px solid rgba(0,0,0,.08); }
}
@media (max-width: 900px){
  .kp-shell{ grid-template-columns: 1fr; }
  .kp-leftpanel{ border-right:0; border-bottom:1px solid rgba(0,0,0,.08); }
  .kp-viewer2{ min-height: 420px; }
}





.kp-felder-box{margin:18px 0 8px;padding:0;}
.kp-felder-title{font-size:24px;font-weight:800;color:#e46f1e;margin:0 0 8px;display:inline-block;border-bottom:4px solid #e46f1e;padding-bottom:4px;}
.kp-felder-text{font-size:14px;line-height:1.45;color:#2d2d2d;margin:10px 0 18px;max-width:560px;}
.kp-felder-item{margin:0 0 24px;}
.kp-felder-head{display:flex;justify-content:space-between;align-items:center;font-weight:800;font-size:16px;color:#4a4a4a;margin-bottom:8px;}
.kp-felder-head span:last-child{font-size:12px;font-weight:800;opacity:.7;}
.kp-felder-row{align-items:center;}
.kp-felder-row .kp-range{display:none;}
.kp-felder-dist{display:flex;align-items:center;justify-content:center;gap:14px;width:66%;margin:12px auto 0;background:#ea6f12;color:#fff;border:0;border-radius:4px;padding:14px 18px;font-weight:800;font-size:15px;cursor:pointer;line-height:1.2;}
.kp-felder-dist-icon{font-weight:900;letter-spacing:1px;font-size:18px;line-height:1;}
.kp-felder-dist.is-disabled{background:#ececec;color:#bdbdbd;cursor:not-allowed;}
.kp-felder-dist.is-disabled .kp-felder-dist-icon{opacity:.8;}

@media (max-width: 900px){
  .kp-accessory{ grid-template-columns:108px minmax(0,1fr); padding:20px; gap:18px; border-radius:26px; }
  .kp-accessory-visual{ width:108px; height:108px; border-radius:22px; }
  .kp-accessory-visual svg{ width:62px; height:42px; }
  .kp-accessory-content{ padding-right:64px; }
  .kp-accessory-kicker{ font-size:13px; margin-bottom:8px; }
  .kp-accessory-title{ font-size:18px; margin-bottom:8px; }
  .kp-accessory-subtitle{ min-height:34px; padding:0 12px; font-size:12px; margin-bottom:12px; }
  .kp-accessory-add-wrap{ width:100%; }
  .kp-accessory-add{ min-width:0; min-height:46px; padding:0 16px; font-size:14px; }
  .kp-accessory-state{ top:14px; right:14px; }
  .kp-accessory-close{ width:40px; height:40px; border-radius:12px; padding:8px; }
  .kp-accessory-remove{ min-width:0; width:100%; min-height:48px; font-size:15px; }
  .kp-field--led_count .kp-stepper-input{ min-height:64px; font-size:20px; }
  .kp-field--led_count .kp-stepper-btn{ width:64px; height:64px; }
  .kp-field--led_control .kp-pill{ min-width:136px; min-height:54px; font-size:16px; }
}


/* v2.4.34: Dach-LED nutzt wieder globale Frontend-Styles */
.kp-accessory{
  grid-template-columns:132px minmax(0,1fr) auto;
  gap:22px;
  padding:24px;
  border-radius:26px;
  background:#fbfbfb;
}
.kp-accessory-visual{
  width:124px;
  height:124px;
  border-radius:24px;
}
.kp-accessory-content{
  padding-right:0;
  min-width:0;
}
.kp-accessory-kicker{
  margin-bottom:8px;
}
.kp-accessory-title{
  margin-bottom:8px;
  font-size:22px;
  line-height:1.12;
  word-break:normal;
  overflow-wrap:anywhere;
}
.kp-accessory-subtitle{
  min-height:36px;
  margin-bottom:14px;
  padding:0 14px;
}
.kp-accessory-add-wrap{
  justify-content:flex-start;
}
.kp-accessory-state{
  position:static;
  align-self:start;
  justify-self:end;
}
.kp-accessory-close{
  width:42px;
  height:42px;
  border-radius:12px;
  padding:9px;
  box-shadow:none;
}
.kp-accessory-remove-wrap{
  grid-column:1 / -1;
  padding-top:16px;
  margin-top:0;
}
.kp-accessory-remove{
  width:100%;
  min-height:48px;
  border-radius:8px;
}

.kp-field--led_count .kp-row{
  display:flex;
}
.kp-field--led_count .kp-stepper{
  grid-template-columns:1fr auto auto auto;
  gap:8px;
  padding:6px 8px;
  border:1px solid rgba(0,0,0,.14);
  border-radius:8px;
  overflow:visible;
  background:#fff;
}
.kp-field--led_count .kp-stepper-input{
  min-height:auto;
  padding:0;
  font-size:14px;
  font-weight:900;
}
.kp-field--led_count .kp-stepper-unit{
  width:auto;
  padding-right:4px;
  overflow:visible;
  font-size:12px;
  font-weight:900;
  opacity:.7;
}
.kp-field--led_count .kp-stepper-btn{
  width:34px;
  height:34px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:8px;
  font-size:18px;
  color:inherit;
}
.kp-field--led_count .kp-stepper-btn:last-child{
  color:inherit;
}
.kp-field--led_control .kp-radio{
  display:flex;
  flex-wrap:wrap;
  gap:0;
}
.kp-field--led_control .kp-pill{
  min-width:0;
  min-height:auto;
  margin-right:8px;
  margin-bottom:8px;
  border-radius:4px;
  padding:12px 20px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  color:inherit;
  font-size:14px;
  font-weight:900;
}
.kp-field--led_control .kp-pill.is-active{
  background:#e8f6ef;
  color:#1aa06a;
  border-color:#1aa06a;
  box-shadow:none;
}

@media (max-width: 900px){
  .kp-accessory{
    grid-template-columns:108px minmax(0,1fr) auto;
    padding:20px;
    gap:16px;
    border-radius:24px;
  }
  .kp-accessory-visual{
    width:108px;
    height:108px;
    border-radius:20px;
  }
  .kp-accessory-visual svg{
    width:62px;
    height:42px;
  }
  .kp-accessory-content{
    padding-right:0;
  }
  .kp-accessory-title{
    font-size:20px;
  }
  .kp-accessory-subtitle{
    min-height:34px;
    font-size:12px;
  }
}

@media (max-width: 640px){
  .kp-accessory{
    grid-template-columns:1fr;
    gap:14px;
  }
  .kp-accessory-visual{
    width:96px;
    height:96px;
  }
  .kp-accessory-visual svg{
    width:54px;
    height:36px;
  }
  .kp-accessory-state{
    position:absolute;
    top:16px;
    right:16px;
  }
  .kp-accessory-title{
    font-size:18px;
  }
  .kp-accessory-subtitle{
    max-width:max-content;
  }
}


/* v2.4.35: Dach-LED auf globale UI-Linie zurückgeführt */
.kp-accessory{
  position:relative;
  display:grid;
  grid-template-columns:120px minmax(0,1fr);
  gap:18px;
  align-items:center;
  padding:22px;
  margin-top:10px;
  border:1px solid rgba(26,160,106,.18);
  border-radius:28px;
  background:#fbfbfb;
  overflow:hidden;
}
.kp-accessory-visual{
  width:112px;
  height:112px;
  border-radius:22px;
  background:#f2f2f2;
  display:flex;
  align-items:center;
  justify-content:center;
}
.kp-accessory-visual svg{ width:64px; height:44px; }
.kp-accessory-content{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  padding-right:64px;
}
.kp-accessory-kicker{
  margin:0 0 8px;
  font-size:14px;
  line-height:1.1;
  letter-spacing:.08em;
}
.kp-accessory-title{
  margin:0 0 10px;
  font-size:18px;
  line-height:1.12;
  font-weight:500;
  color:#1aa06a;
  word-break:normal;
  overflow-wrap:normal;
  white-space:normal;
}
.kp-accessory-subtitle{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  margin:0 0 14px;
  padding:0 14px;
  border-radius:999px;
  background:#ececec;
  color:#4a4a4a;
  font-size:13px;
  font-weight:800;
  line-height:1.1;
  white-space:nowrap;
}
.kp-accessory-add-wrap{ display:flex; width:100%; }
.kp-accessory-add,
.kp-accessory-remove{
  min-height:50px;
  padding:0 20px;
  border:1px solid rgba(0,0,0,.10);
  border-radius:8px;
  background:#f3f3f3;
  color:#444;
  font-size:16px;
  font-weight:800;
}
.kp-accessory-add{ min-width:0; }
.kp-accessory-state{
  position:absolute;
  top:16px;
  right:16px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.kp-accessory-close{
  width:40px;
  height:40px;
  padding:8px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:10px;
  background:#fff;
  color:#21ad6e;
  box-shadow:none;
}
.kp-accessory-remove-wrap{
  grid-column:1 / -1;
  padding-top:14px;
  margin-top:0;
}
.kp-accessory-remove{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}
.kp-accessory-remove span{ font-size:22px; line-height:1; }

.kp-field--led_count .kp-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}
.kp-field--led_count .kp-stepper{
  display:grid;
  grid-template-columns:minmax(0,1fr) 78px 78px;
  gap:0;
  width:100%;
  padding:0;
  border:1px solid rgba(0,0,0,.16);
  border-radius:4px;
  overflow:hidden;
  background:#fff;
}
.kp-field--led_count .kp-stepper-input{
  min-height:78px;
  padding:0 18px;
  border:0;
  font-size:22px;
  font-weight:500;
}
.kp-field--led_count .kp-stepper-unit{ display:none; }
.kp-field--led_count .kp-stepper-btn{
  width:auto;
  height:78px;
  border:0;
  border-left:1px solid rgba(0,0,0,.14);
  border-radius:0;
  background:#fff;
  font-size:30px;
  font-weight:700;
  line-height:1;
  color:#4a4a4a;
}
.kp-field--led_count .kp-stepper-btn:last-child{ color:#4a4a4a; }
.kp-field--led_count .kp-range{
  min-width:54px;
  font-size:11px;
  font-weight:800;
  color:rgba(0,0,0,.6);
  white-space:nowrap;
}

.kp-field--led_control .kp-radio{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.kp-field--led_control .kp-pill{
  min-width:0;
  margin:0;
  padding:12px 24px;
  border-radius:4px;
  border:1px solid rgba(0,0,0,.18);
  background:#fff;
  color:#444;
  font-size:16px;
  font-weight:700;
}
.kp-field--led_control .kp-pill.is-active{
  background:#e8f6ef;
  color:#1aa06a;
  border-color:#1aa06a;
  box-shadow:none;
}

@media (max-width: 900px){
  .kp-accessory{
    grid-template-columns:104px minmax(0,1fr);
    gap:16px;
    padding:18px;
    border-radius:24px;
  }
  .kp-accessory-visual{
    width:96px;
    height:96px;
    border-radius:18px;
  }
  .kp-accessory-visual svg{ width:56px; height:38px; }
  .kp-accessory-content{ padding-right:52px; }
  .kp-accessory-kicker{ font-size:13px; }
  .kp-accessory-title{ font-size:16px; }
  .kp-accessory-subtitle{
    min-height:34px;
    padding:0 12px;
    font-size:12px;
    white-space:normal;
  }
  .kp-accessory-add,
  .kp-accessory-remove{ min-height:46px; font-size:15px; }
  .kp-field--led_count .kp-stepper{
    grid-template-columns:minmax(0,1fr) 74px 74px;
  }
  .kp-field--led_count .kp-stepper-input{ min-height:74px; font-size:20px; }
  .kp-field--led_count .kp-stepper-btn{ height:74px; font-size:28px; }
}

@media (max-width: 640px){
  .kp-accessory{
    grid-template-columns:96px minmax(0,1fr);
    gap:14px;
    padding:16px;
  }
  .kp-accessory-visual{
    width:88px;
    height:88px;
    border-radius:16px;
  }
  .kp-accessory-visual svg{ width:50px; height:34px; }
  .kp-accessory-content{ padding-right:46px; }
  .kp-accessory-kicker{ font-size:12px; margin-bottom:6px; }
  .kp-accessory-title{ font-size:15px; margin-bottom:8px; }
  .kp-accessory-subtitle{ max-width:none; margin-bottom:12px; }
  .kp-accessory-state{ top:12px; right:12px; }
  .kp-accessory-close{ width:36px; height:36px; padding:7px; }
  .kp-field--led_count .kp-row{
    grid-template-columns:1fr;
    gap:8px;
  }
  .kp-field--led_count .kp-stepper{
    grid-template-columns:minmax(0,1fr) 70px 70px;
  }
  .kp-field--led_count .kp-stepper-input{ min-height:70px; padding:0 14px; font-size:18px; }
  .kp-field--led_count .kp-stepper-btn{ height:70px; font-size:26px; }
  .kp-field--led_count .kp-range{ justify-self:start; }
  .kp-field--led_control .kp-pill{ padding:12px 20px; font-size:15px; }
}


/* Build 2.4.36: LED-Stepper wieder auf globalen Stepper zurückführen */
.kp-field--led_count .kp-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.kp-field--led_count .kp-stepper{
  display:grid;
  grid-template-columns:1fr auto auto auto;
  align-items:center;
  gap:8px;
  width:100%;
  border:1px solid rgba(0,0,0,.14);
  border-radius:8px;
  padding:6px 8px;
  background:#fff;
  max-width:none;
  min-height:0;
  box-shadow:none;
}
.kp-field--led_count .kp-stepper-input{
  border:0;
  outline:none;
  font-weight:900;
  font-size:14px;
  width:100%;
  min-height:0;
  padding:0;
  background:transparent;
  color:inherit;
  border-radius:0;
  box-shadow:none;
}
.kp-field--led_count .kp-stepper-unit{
  display:block;
  width:auto;
  padding-right:4px;
  overflow:visible;
  font-size:12px;
  font-weight:900;
  opacity:.7;
}
.kp-field--led_count .kp-stepper-btn{
  width:34px;
  height:34px;
  border-radius:8px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer;
  font-weight:900;
  font-size:18px;
  line-height:0;
  color:inherit;
}
.kp-field--led_count .kp-stepper-btn:last-child{
  color:inherit;
}
.kp-field--led_count .kp-range{
  font-size:11px;
  opacity:.6;
  white-space:nowrap;
}
@media (max-width: 640px){
  .kp-field--led_count .kp-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
  }
  .kp-field--led_count .kp-stepper{
    padding:6px 8px;
    gap:8px;
  }
  .kp-field--led_count .kp-stepper-input{
    min-height:0;
    padding:0;
    font-size:14px;
  }
  .kp-field--led_count .kp-stepper-btn{
    width:34px;
    height:34px;
    font-size:18px;
  }
}

/* Build 2.4.37: Dach-LED Karte kompakt, ohne Überstände, auf globale UI abgestimmt */
.kp-field2--accessory_toggle .kp-accessory,
.kp-accessory{
  display:grid;
  grid-template-columns:96px minmax(0,1fr) auto;
  align-items:center;
  gap:16px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(26,160,106,.18);
  background:#fbfbfb;
  overflow:hidden;
}
.kp-accessory.is-idle{
  border-color:rgba(0,0,0,.08);
}
.kp-accessory-visual{
  width:96px;
  height:96px;
  border-radius:18px;
  flex:0 0 96px;
}
.kp-accessory-visual svg{
  width:54px;
  height:36px;
}
.kp-accessory-content{
  min-width:0;
  padding-right:0;
  gap:0;
}
.kp-accessory-kicker{
  margin:0 0 6px;
  font-size:13px;
  line-height:1.1;
  letter-spacing:.08em;
}
.kp-accessory-title{
  margin:0 0 8px;
  font-size:17px;
  line-height:1.15;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
}
.kp-accessory-subtitle{
  display:inline-flex;
  align-items:center;
  align-self:flex-start;
  min-height:32px;
  max-width:100%;
  margin:0;
  padding:0 12px;
  border-radius:999px;
  font-size:12px;
  line-height:1.1;
  white-space:nowrap;
}
.kp-accessory-add-wrap{
  margin-top:10px;
  width:auto;
}
.kp-accessory-add{
  min-height:40px;
  padding:0 14px;
  border-radius:8px;
  font-size:14px;
}
.kp-accessory-state{
  position:static;
  align-self:start;
  justify-self:end;
}
.kp-accessory-close{
  width:36px;
  height:36px;
  padding:8px;
  border-radius:8px;
  box-shadow:none;
}
.kp-accessory-remove-wrap{
  grid-column:2 / -1;
  padding-top:12px;
  margin-top:0;
}
.kp-accessory-remove{
  min-height:44px;
  padding:0 16px;
  border-radius:8px;
  font-size:14px;
}
.kp-accessory-remove span{
  font-size:22px;
}

@media (max-width: 640px){
  .kp-field2--accessory_toggle .kp-accessory,
  .kp-accessory{
    grid-template-columns:84px minmax(0,1fr) auto;
    gap:12px;
    padding:14px;
    border-radius:18px;
  }
  .kp-accessory-visual{
    width:84px;
    height:84px;
    border-radius:16px;
    flex-basis:84px;
  }
  .kp-accessory-visual svg{
    width:46px;
    height:32px;
  }
  .kp-accessory-kicker{
    font-size:12px;
    margin-bottom:5px;
  }
  .kp-accessory-title{
    font-size:15px;
    margin-bottom:7px;
  }
  .kp-accessory-subtitle{
    min-height:30px;
    padding:0 10px;
    font-size:11px;
  }
  .kp-accessory-add{
    min-height:36px;
    padding:0 12px;
    font-size:13px;
  }
  .kp-accessory-close{
    width:32px;
    height:32px;
    padding:7px;
  }
  .kp-accessory-remove-wrap{
    grid-column:1 / -1;
    padding-top:10px;
  }
  .kp-accessory-remove{
    width:100%;
    min-height:40px;
    font-size:13px;
  }
}


/* Build 2.4.40: LED-Karte ohne Remove-Square und mit stabilem Subtitle-Badge */
.kp-field--led_package .kp-accessory,
.kp-field2--accessory_toggle .kp-accessory,
.kp-accessory{
  grid-template-columns: 104px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  padding: 22px;
  border-radius: 22px;
}
.kp-accessory-visual{
  width: 104px;
  height: 104px;
  border-radius: 20px;
  background: #f5f5f5;
  color: #47515a;
}
.kp-accessory-visual svg{
  width: 52px;
  height: 52px;
}
.kp-accessory-content{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  min-width:0;
  padding-right:0;
}
.kp-accessory-kicker{
  margin: 2px 0 8px;
  font-size: 13px;
  letter-spacing: .08em;
}
.kp-accessory-title{
  margin: 0 0 10px;
  font-size: 18px;
  line-height: 1.15;
  word-break: normal;
  overflow-wrap: anywhere;
}
.kp-accessory-subtitle{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  width:auto;
  max-width:100%;
  min-height: 36px;
  margin: 0;
  padding: 0 16px;
  border-radius: 999px;
  background: #f0f0f0;
  color:#555;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}
.kp-accessory-subtitle-icon{
  display:inline-flex;
  width:16px;
  height:16px;
  color:#8d8d8d;
  flex:0 0 16px;
}
.kp-accessory-subtitle-icon svg{ width:100%; height:100%; }
.kp-accessory-add-wrap{ margin-top: 12px; width:100%; }
.kp-accessory-add{
  min-height: 44px;
  padding: 0 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
}
.kp-accessory-state{
  display:none;
}
.kp-accessory-close{
  display:none;
}
.kp-accessory-remove-wrap{
  grid-column: 2 / -1;
  padding-top: 14px;
  width:100%;
}
.kp-accessory-remove{
  min-height: 48px;
  padding: 0 18px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 700;
}
@media (max-width: 640px){
  .kp-field--led_package .kp-accessory,
  .kp-field2--accessory_toggle .kp-accessory,
  .kp-accessory{
    grid-template-columns: 92px minmax(0, 1fr);
    align-items: start;
    gap: 14px;
    padding: 18px;
  }
  .kp-accessory-visual{
    width: 92px;
    height: 92px;
    border-radius: 18px;
  }
  .kp-accessory-visual svg{
    width: 46px;
    height: 46px;
  }
  .kp-accessory-title{
    font-size: 16px;
    margin-bottom: 8px;
  }
  .kp-accessory-subtitle{
    min-height: 34px;
    padding: 0 14px;
    font-size: 12px;
    white-space: nowrap;
  }
  .kp-accessory-remove-wrap{
    grid-column: 1 / -1;
  }
}

/* Wände Overview */
.kp-overview-groups{
  display:flex;
  flex-direction:column;
  gap:28px;
}
.kp-overview-group{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.kp-overview-heading{
  margin:0;
  color:#ea6608;
  font-size:18px;
  line-height:1.1;
  font-weight:800;
  letter-spacing:.01em;
}
.kp-overview-heading::after{
  content:'';
  display:block;
  width:72px;
  height:4px;
  margin-top:8px;
  border-radius:999px;
  background:#ea6608;
}
.kp-overview-card{
  display:grid;
  grid-template-columns:116px minmax(0,1fr) 24px;
  align-items:center;
  gap:18px;
  width:100%;
  padding:16px 18px;
  border:1px solid #e7e7e7;
  border-radius:18px;
  background:#fafafa;
  text-align:left;
  color:#4a4a4a;
  cursor:pointer;
}
.kp-overview-card:hover{
  background:#f6f6f6;
  border-color:#dddddd;
}
.kp-overview-card:hover .kp-overview-title{ color:#2f2f2f; }
.kp-overview-media{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  min-width:0;
}
.kp-overview-thumb{
  display:block;
  width:96px;
  max-width:100%;
  color:#46515b;
}
.kp-overview-thumb svg{ display:block; width:100%; height:auto; }
.kp-overview-body{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:8px;
}
.kp-overview-title{
  display:block;
  width:100%;
  margin:0;
  color:#4a4a4a;
  font-size:17px;
  line-height:1.18;
  font-weight:500;
  letter-spacing:-.01em;
  text-align:left;
  word-break:normal;
  overflow-wrap:break-word;
}
.kp-overview-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-start;
}
.kp-overview-badge{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 12px;
  border-radius:999px;
  background:#ececec;
  color:#545454;
  font-size:11px;
  line-height:1;
  font-weight:700;
  white-space:nowrap;
}
.kp-overview-chevron{
  display:flex;
  align-items:center;
  justify-content:center;
  align-self:center;
  color:#666;
}
.kp-overview-chevron svg{
  width:18px;
  height:18px;
}
@media (max-width: 900px){
  .kp-overview-groups{ gap:24px; }
  .kp-overview-card{
    grid-template-columns:104px minmax(0,1fr) 22px;
    gap:16px;
    padding:15px 16px;
    border-radius:16px;
  }
  .kp-overview-thumb{ width:88px; }
  .kp-overview-title{ font-size:16px; }
}
@media (max-width: 640px){
  .kp-overview-groups{ gap:22px; }
  .kp-overview-heading{ font-size:17px; }
  .kp-overview-heading::after{ width:54px; height:3px; margin-top:6px; }
  .kp-overview-card{
    grid-template-columns:88px minmax(0,1fr) 18px;
    gap:14px;
    padding:14px 14px;
    border-radius:14px;
  }
  .kp-overview-thumb{ width:74px; }
  .kp-overview-body{ gap:7px; }
  .kp-overview-title{ font-size:15px; line-height:1.2; }
  .kp-overview-badges{ gap:5px; }
  .kp-overview-badge{
    min-height:24px;
    padding:0 10px;
    font-size:11px;
  }
  .kp-overview-chevron svg{ width:16px; height:16px; }
}
/* Robust fallback: legacy Wände controls never render in Wände overview */
.kp-section[data-step-id="waende"] .kp-field--seitenwand,
.kp-section[data-step-id="waende"] .kp-field--wand_hinten{
  display:none !important;
}

.kp-section[data-step-id="waende"] .kp-field--waende-katalog{
  margin:0;
}


/* Wände Detailseite */
.kp-wall-detail{ display:flex; flex-direction:column; gap:22px; }
.kp-wall-detail-back{ display:inline-flex; align-items:center; gap:10px; width:max-content; padding:0; border:0; background:transparent; color:#4e4e4e; font-size:14px; font-weight:700; cursor:pointer; }
.kp-wall-detail-back svg{ width:18px; height:18px; }
.kp-wall-detail-title-wrap{ padding-top:6px; }
.kp-wall-detail-title{ margin:0; color:#ea6608; font-size:20px; line-height:1.15; font-weight:800; }
.kp-wall-detail-title::after{ content:''; display:block; width:72px; height:4px; margin-top:10px; border-radius:999px; background:#ea6608; }
.kp-wall-detail-section{ display:flex; flex-direction:column; gap:12px; }
.kp-wall-detail-heading{ margin:0; color:#404040; font-size:18px; line-height:1.2; font-weight:800; }
.kp-wall-detail-copy{ margin:0; color:#525252; font-size:14px; line-height:1.35; max-width:520px; }
.kp-wall-detail-subheading{ color:#444; font-size:14px; line-height:1.2; font-weight:800; }
.kp-wall-detail-picker{ display:inline-flex; align-items:center; gap:10px; width:max-content; padding:0; border:0; background:transparent; color:#4d82f3; font-size:16px; font-weight:700; cursor:pointer; }
.kp-wall-detail-picker-plus{ font-size:22px; line-height:1; font-weight:400; }
.kp-wall-detail-placement-selected{ display:none; flex-wrap:wrap; gap:8px; }
.kp-wall-detail-placement-pill{ display:inline-flex; align-items:center; min-height:34px; padding:0 14px; border-radius:999px; font-size:13px; font-weight:700; background:#efefef; color:#555; }
.kp-wall-detail-modal{ position:fixed; inset:0; z-index:40; display:none; align-items:center; justify-content:center; padding:24px; }
.kp-wall-detail-modal.is-open{ display:flex; }
.kp-wall-detail-modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.18); }
.kp-wall-detail-modal-dialog{ position:relative; width:min(100%, 402px); max-height:min(86vh, 680px); overflow:auto; padding:28px 26px 26px; background:#fff; box-shadow:0 18px 42px rgba(0,0,0,.12); }
.kp-wall-detail-modal-title-wrap{ margin-bottom:12px; }
.kp-wall-detail-modal-title{ margin:0; color:#ea6608; font-size:18px; line-height:1.12; font-weight:500; }
.kp-wall-detail-modal-title::after{ content:''; display:block; width:78px; height:3px; margin-top:8px; border-radius:999px; background:#ea6608; }
.kp-wall-detail-modal-list{ display:flex; flex-direction:column; gap:10px; }
.kp-wall-detail-modal-option{ display:flex; align-items:center; gap:12px; min-height:28px; color:#4b4b4b; font-size:15px; line-height:1.3; cursor:pointer; }
.kp-wall-detail-modal-option input{ width:16px; height:16px; margin:0; accent-color:#ea6608; }
.kp-wall-detail-modal-option.is-active span{ color:#272727; }
.kp-wall-detail-modal-actions{ display:flex; justify-content:flex-end; padding-top:22px; }
.kp-wall-detail-modal-close{ display:inline-flex; align-items:center; gap:10px; min-height:42px; padding:0 18px; border:0; background:#ea6608; color:#fff; font-size:15px; font-weight:700; cursor:pointer; }
.kp-wall-detail-modal-close span{ font-size:18px; line-height:1; }
.kp-wall-detail-check{ display:inline-flex; align-items:center; gap:12px; width:max-content; padding:0; border:0; background:transparent; color:#494949; font-size:16px; font-weight:500; cursor:pointer; }
.kp-wall-detail-check-box{ display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border:1px solid #dbdbdb; background:#fff; color:transparent; }
.kp-wall-detail-check-box svg{ width:16px; height:16px; }
.kp-wall-detail-check.is-active .kp-wall-detail-check-box{ border-color:#ea6608; background:#ea6608; color:#fff; }
.kp-wall-detail-material{ display:flex; flex-direction:column; gap:10px; }
.kp-wall-detail-material-grid{ display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:10px; }
.kp-wall-detail-material-card{ display:flex; flex-direction:column; align-items:center; justify-content:flex-start; gap:12px; min-height:184px; padding:18px 14px 16px; border:1px solid #d9d9d9; border-radius:3px; background:#fff; text-align:center; color:#4e4e4e; cursor:pointer; }
.kp-wall-detail-material-card.is-active{ border-color:#1aa06a; box-shadow:0 0 0 1px #1aa06a inset; }
.kp-material-swatch{ display:flex; align-items:center; justify-content:center; width:100%; min-height:102px; }
.kp-material-swatch svg{ width:86px; height:auto; display:block; }
.kp-wall-detail-material-label{ font-size:14px; line-height:1.15; font-weight:800; color:inherit; }
.kp-wall-detail-material-card.is-active .kp-wall-detail-material-label{ color:#1aa06a; }
@media (max-width: 760px){ .kp-wall-detail{ gap:20px; } .kp-wall-detail-title{ font-size:18px; } .kp-wall-detail-heading{ font-size:17px; } .kp-wall-detail-copy{ font-size:13px; } .kp-wall-detail-check{ font-size:15px; } .kp-wall-detail-material-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); gap:10px; } .kp-wall-detail-material-card{ min-height:170px; padding:16px 10px 14px; } .kp-material-swatch{ min-height:90px; } .kp-material-swatch svg{ width:78px; } .kp-wall-detail-material-label{ font-size:13px; } }
@media (max-width: 560px){ .kp-wall-detail-material-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px){ .kp-wall-detail-modal{ padding:16px; } .kp-wall-detail-modal-dialog{ width:min(100%, 360px); padding:24px 20px 22px; } .kp-wall-detail-modal-option{ font-size:14px; } .kp-wall-detail-modal-close{ width:100%; justify-content:center; } }
