/* Konfigurator */
.konf__grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.konf__visual{position:sticky;top:100px}
.konf__visual img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);display:block;background:var(--soft);transition:transform .2s}
.konf__visual img.is-mirrored{transform:scaleX(-1)}
.konf__stage{position:relative}
.konf__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:42px;height:42px;border:none;border-radius:50%;background:var(--accent,#4a8dc9);color:#fff;font-size:1.7rem;line-height:1;font-weight:700;cursor:pointer;display:grid;place-items:center;box-shadow:0 2px 9px rgba(0,0,0,.28);opacity:.93;transition:.15s;padding:0}
.konf__arrow:hover{opacity:1;transform:translateY(-50%) scale(1.08)}
.konf__arrow--prev{left:12px}
.konf__arrow--next{right:12px}
.konf__dots{display:flex;gap:8px;justify-content:center;margin-top:11px}
.konf__dot{width:10px;height:10px;border-radius:50%;background:var(--line,#d8d8d2);border:none;padding:0;cursor:pointer;transition:.15s}
.konf__dot:hover{background:var(--muted,#9a9a93)}
.konf__dot.is-active{background:var(--accent,#4a8dc9);transform:scale(1.18)}
@media(max-width:860px){.konf__arrow{width:38px;height:38px;font-size:1.5rem}}
.konf__cap{text-align:center;font-weight:600;margin-top:12px;color:var(--ink);font-size:.96rem}
.konf__hint{font-size:.82rem;color:var(--muted);margin-top:4px;text-align:center}
.konf__steps{display:flex;flex-direction:column;gap:22px}
.konf__step{border:1px solid var(--line);border-radius:14px;padding:20px 22px;margin:0}
.konf__step legend{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.05rem;padding:0 6px}
.konf__step legend span{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:.85rem}
.konf__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.konf__note{font-size:.85rem;color:var(--muted);margin-top:10px}
.field{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{font:inherit;font-weight:400;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light,#a9d4f0)}
.konf__opts{display:flex;gap:10px;flex-wrap:wrap}
.konf__opt{flex:1;min-width:120px;cursor:pointer}
.konf__opt input{position:absolute;opacity:0}
.konf__opt span{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1.5px solid var(--line);border-radius:10px;font-weight:600;transition:.15s}
.konf__opt input:checked+span{border-color:var(--accent);background:var(--accent-light,#eaf3fb);color:var(--accent-dark,#3a73a8)}
.konf__colors .sw{width:18px;height:18px;border-radius:50%;display:inline-block}
.konf__colors .konf__opt span{flex-direction:column;gap:5px;text-align:center;line-height:1.2}
.konf__colors small{color:var(--muted);font-weight:400;font-size:.72rem}
.konf__checks{display:flex;gap:18px;flex-wrap:wrap}
.konf__check{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer}
.konf__check input,.check-label input{width:18px;height:18px;accent-color:var(--accent)}
.check-label{display:flex;gap:10px;align-items:flex-start;font-weight:400;font-size:.9rem;color:var(--muted);margin-top:14px;cursor:pointer}
.check-label a{color:var(--accent-dark,#3a73a8);text-decoration:underline}
.konf__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.konf__submit{width:100%;margin-top:6px;font-size:1.05rem;padding:15px}
.konf__error{background:#fdecea;color:#a3271e;border:1px solid #f5c6c0;border-radius:10px;padding:12px 14px;margin-top:12px;font-size:.92rem}
.konf__done{text-align:center;padding:30px;border:1px solid var(--line);border-radius:14px;background:var(--soft)}
.konf__done svg{width:54px;height:54px;color:var(--accent);margin-bottom:12px}
.konf__done h3{margin-bottom:8px}
/* Wizard */
.konf__step{display:none}
.konf__step.is-active{display:block;animation:konfIn .25s ease}
@keyframes konfIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.konf__progress{margin-bottom:22px}
.konf__progresshead{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;font-size:.92rem;font-weight:600}
.konf__progresshead #konfStepName{color:var(--accent-dark,#3a73a8)}
.konf__bar{height:7px;background:#e7e7e2;border-radius:99px;overflow:hidden}
.konf__bar i{display:block;height:100%;background:var(--accent);border-radius:99px;transition:width .35s ease}
.konf__opt.is-disabled{opacity:.4;cursor:not-allowed}
.konf__opt.is-disabled span{background:#f6f5f1;border-style:dashed}
.konf__lock{margin:12px 0 0;font-size:.86rem;color:#8a5a00;background:#fff7e6;border:1px solid #f0d9a8;border-radius:9px;padding:11px 13px;line-height:1.5}
.konf__group{border:1px solid var(--line);border-radius:12px;padding:18px 18px 20px;margin-bottom:16px;background:var(--soft);transition:opacity .2s}
.konf__group:last-child{margin-bottom:0}
.konf__group.is-locked{opacity:.4;filter:grayscale(.3)}
.konf__group.is-locked select,.konf__group.is-locked input{cursor:not-allowed}
.konf__grouptitle{margin:0 0 4px;font-size:1.06rem;font-weight:700}
.konf__groupdesc{margin:0 0 14px;font-size:.86rem;color:var(--muted);line-height:1.5}
.konf__minilabel{font-weight:600;font-size:.86rem;margin:0 0 8px;color:var(--ink)}
.konf__sublabel{font-weight:700;margin:20px 0 11px;font-size:1rem}
.konf__sublabel:first-of-type{margin-top:4px}
.konf__checks--stack{flex-direction:column;gap:14px;align-items:flex-start}
.konf__nav{display:flex;gap:12px;margin-top:24px}
.konf__nav .btn{min-height:52px;display:inline-flex;align-items:center;justify-content:center;font-size:1.02rem}
.konf__nav .btn[hidden]{display:none}
.konf__next,.konf__submit{flex:1;width:auto;margin-top:0}
.konf__back{flex:0 0 auto;padding-left:22px;padding-right:22px;color:var(--ink);border:1px solid var(--line)}

@media(max-width:860px){
  .konf__grid{grid-template-columns:1fr;gap:20px}
  .konf__visual{position:static}
  .konf__visual img{max-height:230px;object-fit:cover}
  .konf__row{grid-template-columns:1fr}
  .konf__step{border:none;padding:0}
  .konf__opt{min-width:0}
  .konf__nav{gap:10px}
  .konf__nav .btn{min-height:54px}
}
.konf__filehint{display:block;color:var(--muted);font-size:.82rem;margin-top:6px;font-weight:400;line-height:1.45}
.konf__filelabel{font-size:.9rem;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.konf__fileinput{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
.konf__filerow{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.konf__filebtn{display:inline-block;padding:11px 18px;background:var(--accent-light,#eaf3fb);color:var(--accent-dark,#3a73a8);border:1px solid var(--accent,#4a8dc9);border-radius:10px;font-weight:600;cursor:pointer;font-size:.92rem}
.konf__filebtn:hover{background:var(--accent,#4a8dc9);color:#fff}
.konf__filestatus{color:var(--muted);font-weight:400;font-size:.9rem}
.konf__hitze{margin-top:14px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:#fff}
.konf__hitze[hidden]{display:none}
.konf__hitzehint{color:var(--muted);font-weight:400;font-size:.84rem}
.konf__hitzedesc{margin:8px 0 0;font-size:.85rem;color:var(--muted);line-height:1.5}
