/* AFO Overkapping-configurator stijl. */
.cfg-wrap{padding:36px 0 80px;background:var(--bg-soft)}
/* Configurator breder dan de standaard content-breedte (meer werkruimte + grotere 3D-preview). */
.cfg-wrap > .container{max-width:1480px}
.cfg-resume{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;background:var(--secondary);color:#fff;border-radius:12px;padding:14px 20px;margin-bottom:18px}
.cfg-resume span{font-weight:500}
.cfg-resume-act{display:flex;gap:10px;flex-shrink:0}
.cfg-resume .btn-sm{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff}
.cfg-resume .btn-sm:hover{background:rgba(255,255,255,.12)}
/* Klikbare stap-navigatie */
.cfg-steps{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.cfg-stepchip{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:.82rem;font-weight:600;padding:6px 12px 6px 7px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--muted);cursor:pointer;transition:.15s}
.cfg-stepchip:disabled{opacity:.5;cursor:not-allowed}
.cfg-stepchip-n{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#e3e1e0;color:var(--secondary);font-size:.72rem}
.cfg-stepchip.done:not(.active){border-color:color-mix(in srgb,var(--primary) 40%,transparent);color:var(--secondary)}
.cfg-stepchip.done .cfg-stepchip-n{background:color-mix(in srgb,var(--primary) 15%,#fff);color:var(--primary)}
.cfg-stepchip.active{background:var(--secondary);color:#fff;border-color:var(--secondary)}
.cfg-stepchip.active .cfg-stepchip-n{background:var(--primary);color:#fff}
.cfg-stepchip:not(:disabled):hover{border-color:var(--primary)}
@media(max-width:600px){.cfg-stepchip-l{display:none}.cfg-stepchip{padding:6px}}

.cfg-progress{height:6px;background:#e3e1e0;border-radius:999px;overflow:hidden;margin-bottom:28px}
.cfg-progress-bar{height:100%;background:var(--primary);width:11%;transition:width .25s}

/* Overzicht op de laatste stap */
.cfg-review{background:var(--bg-soft);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin:0 0 18px}
.cfg-review-head{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}
.cfg-review-head strong{font-size:1.1rem;color:var(--secondary)}
.cfg-review-head span{font-size:.88rem;color:var(--muted)}
.cfg-review-table{width:100%;border-collapse:collapse;font-size:.9rem}
.cfg-review-table td{padding:5px 0;border-bottom:1px solid var(--border)}
.cfg-review-table td:last-child{text-align:right;white-space:nowrap}
.cfg-review-ex td{color:var(--muted)}
.cfg-review-incl td{font-weight:700;color:var(--secondary);border-bottom:0;font-size:1rem}
.cfg-review-range{font-size:.82rem;color:var(--muted);margin:8px 0 0}
.cfg-review-incl-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-wrap:wrap;gap:6px 16px}
.cfg-review-incl-list li{position:relative;padding-left:20px;font-size:.84rem;font-weight:600;color:var(--secondary)}
.cfg-review-incl-list li::before{content:"✓";position:absolute;left:0;color:var(--primary);font-weight:800}

/* Vertrouwen in de zijbalk */
.cfg-aside-trust{display:flex;flex-direction:column;gap:14px}
.cfg-leadtime{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:.9rem;color:var(--secondary)}
.cfg-leadtime svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}
.cfg-aside-review{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.cfg-aside-review .stars{color:#f5a623;font-size:.95rem;letter-spacing:1px}
.cfg-aside-review p{font-size:.9rem;font-style:italic;color:var(--secondary);margin:6px 0}
.cfg-aside-review span{font-size:.82rem;color:var(--muted);font-weight:600}
.cfg-aside-faq details{background:#fff;border:1px solid var(--border);border-radius:10px;padding:4px 14px;margin-bottom:8px}
.cfg-aside-faq summary{cursor:pointer;font-weight:600;font-size:.88rem;padding:9px 0;color:var(--secondary);list-style:none}
.cfg-aside-faq summary::-webkit-details-marker{display:none}
.cfg-aside-faq summary::after{content:"+";float:right;color:var(--primary);font-weight:700}
.cfg-aside-faq details[open] summary::after{content:"–"}
.cfg-aside-faq p{font-size:.85rem;color:var(--muted);margin:0 0 12px;line-height:1.5}

.cfg-layout{display:grid;grid-template-columns:1fr 440px;gap:32px;align-items:start}
.cfg-main{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;min-height:420px}
.cfg-step h2{margin-top:0}

/* Pakketten / bundels */
.cfg-bundles-wrap{margin-bottom:8px}
.cfg-bundles-wrap>h2{margin-top:0}
.cfg-bundles{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:14px}
.cfg-bundle{text-align:left;background:#fff;border:2px solid var(--border);border-radius:12px;padding:18px;cursor:pointer;display:flex;flex-direction:column;gap:6px;font:inherit;transition:.15s}
.cfg-bundle:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.cfg-bundle strong{color:var(--secondary);font-size:1.15rem}
.cfg-bundle-tag{font-size:.88rem;color:var(--muted)}
.cfg-bundle-hint{margin-top:auto;font-size:.85rem;color:var(--primary);font-weight:700}
.cfg-or{display:flex;align-items:center;text-align:center;gap:14px;color:var(--muted);font-size:.85rem;margin:24px 0 4px}
.cfg-or::before,.cfg-or::after{content:"";flex:1;height:1px;background:var(--border)}

/* Optiekaarten */
.cfg-options{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.cfg-card{position:relative;text-align:left;background:#fff;border:2px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;display:flex;flex-direction:column;gap:6px;font:inherit;transition:.15s}
.cfg-badge{position:absolute;top:10px;right:10px;z-index:1;background:var(--primary);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.02em;padding:4px 9px;border-radius:999px;text-transform:uppercase;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.cfg-card:hover{border-color:var(--primary)}
.cfg-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent)}
.cfg-card-img{display:block;height:120px;border-radius:9px;background:#e7e5e4 center/cover no-repeat;margin-bottom:12px}
.cfg-card-img--ph{background:linear-gradient(135deg,#edebea,#dcd9d7);position:relative}
.cfg-card-img--ph::after{content:"AFO";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head,sans-serif);font-weight:800;letter-spacing:.1em;color:#bfbbb8;font-size:1rem}
.cfg-card-ic{display:flex;align-items:center;justify-content:center;height:120px;border-radius:9px;margin-bottom:12px;background:linear-gradient(135deg,#f3f2f1,#e3e1e0)}
.cfg-card-ic svg{width:46px;height:46px;color:var(--secondary)}
.cfg-card-body{display:flex;flex-direction:column;gap:6px}
.cfg-card strong{color:var(--secondary)}
.cfg-card-desc{font-size:.85rem;color:var(--muted);font-weight:400}
.cfg-card-hint{font-size:.8rem;color:var(--primary);font-weight:700;margin-top:auto}
/* Accessoire-aantallen */
.cfg-acc-card .cfg-card-hint{margin-top:6px}
.cfg-stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:8px;overflow:hidden;width:fit-content;margin-top:8px}
.cfg-stepper button{width:34px;height:32px;border:0;background:#fff;font-size:1.15rem;line-height:1;cursor:pointer;color:var(--secondary)}
.cfg-stepper button:hover{background:var(--bg-soft)}
.cfg-stepper span{min-width:32px;text-align:center;font-weight:700}
.cfg-acc-toggle{font:inherit;font-weight:600;font-size:.85rem;padding:7px 14px;border:1px solid var(--primary);border-radius:8px;background:#fff;color:var(--primary);cursor:pointer;width:fit-content;margin-top:8px}
.cfg-acc-toggle.on{background:var(--primary);color:#fff}

/* Afmetingen */
.cfg-presets{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px}
.cfg-presets-label{font-weight:700;font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.cfg-preset{font:inherit;font-weight:600;font-size:.9rem;padding:8px 14px;border:1px solid var(--border);border-radius:999px;background:#fff;cursor:pointer;transition:.15s}
.cfg-preset:hover{border-color:var(--primary);color:var(--primary)}
.cfg-preset.selected{background:var(--primary);color:#fff;border-color:var(--primary)}
.cfg-dims{display:flex;flex-direction:column;gap:22px;max-width:520px}
.cfg-dim label{display:flex;justify-content:space-between;font-weight:600;margin-bottom:6px}
.cfg-dim output{color:var(--primary)}
.cfg-dim input[type=range]{width:100%;accent-color:var(--primary)}
.cfg-placement{margin-top:26px;border:1px solid var(--border);border-radius:12px;padding:14px 18px}
.cfg-placement legend{font-weight:700;padding:0 6px}
.cfg-placement label{margin-right:20px}

/* Kleuren */
.cfg-colors{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.cfg-color{display:flex;align-items:center;gap:10px;border:2px solid var(--border);border-radius:10px;padding:10px;background:#fff;cursor:pointer;font:inherit}
.cfg-color.selected{border-color:var(--primary);box-shadow:0 0 0 3px rgba(29,78,216,.15)}
.cfg-color .swatch{width:28px;height:28px;border-radius:6px;border:1px solid rgba(0,0,0,.15);flex-shrink:0}

/* Zijde-selectors */
.cfg-side-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}
.cfg-side-label{min-width:120px;font-weight:600}
.cfg-side-row select{flex:1;min-width:160px;padding:9px;border:1px solid var(--border);border-radius:8px}
.cfg-motor{display:flex;align-items:center;gap:6px;font-weight:500}

/* Velden */
.cfg-field{display:block;font-weight:600;max-width:300px}
.cfg-field input{width:100%;margin-top:6px;padding:11px;border:1px solid var(--border);border-radius:8px}

/* Lead form */
.cfg-lead{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:620px}
.cfg-lead label{display:flex;flex-direction:column;font-weight:600}
.cfg-lead .cfg-wide,.cfg-lead .cfg-consent,.cfg-lead button{grid-column:1/-1}
.cfg-lead input,.cfg-lead textarea,.cfg-lead select{margin-top:6px;padding:11px;border:1px solid var(--border);border-radius:8px;font:inherit;font-weight:400;background:#fff}
.cfg-consent{flex-direction:row!important;align-items:center;gap:8px;font-weight:400}
.cfg-trust{grid-column:1/-1;list-style:none;margin:0;padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;background:var(--bg-soft);border:1px solid var(--border);border-radius:10px}
.cfg-trust li{position:relative;padding-left:24px;font-size:.88rem;font-weight:500;color:var(--secondary)}
.cfg-trust li::before{content:"";position:absolute;left:0;top:1px;width:16px;height:16px;border-radius:50%;background:var(--primary);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat}
.cfg-reassure{grid-column:1/-1;margin:0;font-size:.8rem;color:var(--muted);text-align:center}
.hp{position:absolute;left:-9999px;height:0;overflow:hidden}
@media(max-width:520px){.cfg-trust{grid-template-columns:1fr}}

/* Navigatie */
.cfg-nav{display:flex;justify-content:space-between;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}
.cfg-nav button:disabled{opacity:.4;cursor:not-allowed}

/* Aside */
.cfg-aside{position:sticky;top:90px;display:flex;flex-direction:column;gap:16px}
.cfg-preview{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;min-height:150px;display:flex;align-items:center;justify-content:center}
.cfg-preview-empty{color:var(--muted);text-align:center;font-size:.9rem}
/* 3D-voorbeeld: canvas vult het kader, met een subtiele draai-hint */
.cfg-preview.is-3d{padding:0;height:300px;min-height:300px;overflow:hidden;position:relative;display:block}
.cfg-preview.is-3d canvas{display:block;width:100%;height:100%;cursor:grab}
.cfg-preview.is-3d canvas:active{cursor:grabbing}
.cfg-3d-hint{position:absolute;left:10px;bottom:10px;background:rgba(31,29,33,.6);color:#fff;font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:999px;pointer-events:none;backdrop-filter:blur(2px)}
.cfg-3d-toolbar{position:absolute;top:10px;right:10px;z-index:2;display:flex;gap:4px}
.cfg-3d-btn{font:inherit;font-size:.74rem;font-weight:600;background:rgba(31,29,33,.6);color:#fff;border:0;border-radius:6px;padding:5px 8px;cursor:pointer;line-height:1;backdrop-filter:blur(2px)}
.cfg-3d-btn:hover{background:rgba(31,29,33,.9)}
.cfg-price-card{background:var(--secondary);color:#fff;border-radius:var(--radius);padding:22px}
.cfg-price-label{font-size:.85rem;opacity:.8}
.cfg-price{display:block;font-size:2rem;font-weight:800;margin:4px 0}
.cfg-range{font-size:.85rem;opacity:.85}
.cfg-summary{list-style:none;padding:14px 0 0;margin:14px 0 0;border-top:1px solid rgba(255,255,255,.15);font-size:.85rem;max-height:240px;overflow:auto}
.cfg-summary li{display:flex;justify-content:space-between;gap:10px;padding:3px 0;opacity:.92}
.cfg-disclaimer{font-size:.75rem;color:var(--muted);line-height:1.5}
.cfg-promo{background:color-mix(in srgb,var(--primary) 10%,#fff);border:1px solid color-mix(in srgb,var(--primary) 35%,transparent);color:var(--secondary);border-radius:10px;padding:12px 18px;margin-bottom:16px;font-size:.92rem}
.cfg-promo strong{color:var(--primary)}
.cfg-upsell{display:flex;gap:8px;align-items:flex-start;background:#fff8ec;border:1px solid #f0d9a8;border-radius:10px;padding:12px 14px;font-size:.85rem;color:#7a5a1a;line-height:1.45}
.cfg-upsell[hidden]{display:none}
.cfg-share-btn{width:100%;background:#fff;border:1px solid var(--border);border-radius:10px;padding:11px;font:inherit;font-weight:600;font-size:.9rem;color:var(--secondary);cursor:pointer;transition:.15s}
.cfg-share-btn:hover{border-color:var(--primary);color:var(--primary)}

/* Exit-intent modal */
.cfg-exit{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(31,29,33,.55);backdrop-filter:blur(2px);animation:cfgFade .2s ease}
.cfg-exit[hidden]{display:none}
@keyframes cfgFade{from{opacity:0}to{opacity:1}}
.cfg-exit-card{position:relative;background:#fff;border-radius:16px;max-width:440px;width:100%;padding:34px 30px;box-shadow:0 24px 60px rgba(31,29,33,.35);text-align:center;animation:cfgPop .25s ease}
@keyframes cfgPop{from{transform:translateY(12px) scale(.98);opacity:.6}to{transform:none;opacity:1}}
.cfg-exit-card h3{margin:0 0 10px;font-size:1.45rem}
.cfg-exit-card>div>p{color:var(--muted);margin:0 0 18px}
.cfg-exit-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:1.7rem;line-height:1;color:#9b9799;cursor:pointer}
.cfg-exit-close:hover{color:var(--secondary)}
.cfg-exit-form{display:flex;flex-direction:column;gap:12px;text-align:left}
.cfg-exit-form input[type=email]{padding:13px;border:1px solid var(--border);border-radius:9px;font:inherit}
.cfg-exit-consent{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:var(--muted)}
.cfg-exit-form .btn{width:100%;justify-content:center}
.cfg-exit-alt{margin:14px 0 0}
.cfg-exit-dismiss{background:none;border:0;color:var(--muted);text-decoration:underline;cursor:pointer;font:inherit;font-size:.86rem}
.cfg-exit-dismiss:hover{color:var(--secondary)}

@media(max-width:900px){
  .cfg-layout{grid-template-columns:1fr}
  .cfg-aside{position:static;order:-1}
  .cfg-lead{grid-template-columns:1fr}
}
