/* ════════════════════════════════════════════════════════════════
   CONFIGURATEUR — CSS spécifique (maquette configurateur_demi_ronde.html).
   La base commune (:root, header, footer, boutons, badges) vit dans style.css.
   ════════════════════════════════════════════════════════════════ */

/* Fil d'Ariane sur fond crème (la base .crumb est calée sur le bandeau sombre) */
.crumb{font-size:12.5px;color:var(--steel);padding:18px 0 4px;margin-bottom:0}
.crumb a:hover{color:var(--brand)}

.ptitle{padding:6px 0 18px}
.ptitle h1{font-size:clamp(28px,3.6vw,42px);font-weight:800}
.ptitle h1 em{font-style:normal;color:var(--brand)}
.ptitle p{color:var(--ink-soft);font-size:14.5px;margin-top:6px}

.lay{display:grid;grid-template-columns:1.06fr .94fr;gap:34px;padding:8px 0 70px;align-items:start}
@media(max-width:900px){.lay{grid-template-columns:1fr;gap:24px;padding-bottom:120px}}
.visual{position:sticky;top:88px}
@media(max-width:900px){.visual{position:static}}
.stage{border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh);position:relative;background:linear-gradient(150deg,#F1E6D5,#E6D6BE)}
.stage img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:opacity .3s}
.stage .noimg{aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:30px}
.noimg .sw{width:74px;height:74px;border-radius:50%;border:4px solid #fff;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.noimg b{font-family:'Bricolage Grotesque';font-size:16px}
.noimg span{font-size:12.5px;color:var(--ink-soft);max-width:320px}
.stage .vlabel{position:absolute;top:14px;left:14px;font-family:'Bricolage Grotesque';font-size:11.5px;font-weight:700;color:#fff;background:rgba(27,15,8,.75);backdrop-filter:blur(4px);padding:6px 13px;border-radius:999px;z-index:2}
.stage .clabel{position:absolute;top:14px;right:14px;display:flex;align-items:center;gap:8px;background:rgba(252,247,240,.92);border-radius:999px;padding:6px 12px 6px 7px;font-size:12px;font-weight:600;z-index:2;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.clabel i{width:16px;height:16px;border-radius:50%;display:inline-block;border:2px solid #fff;box-shadow:0 0 0 1px var(--line)}
.thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.th{border-radius:12px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:.15s;box-shadow:var(--sh-sm)}
.th img{width:100%;aspect-ratio:4/3;object-fit:cover}
.th.on{border-color:var(--brand)}
.th:hover{transform:translateY(-2px)}
.trust{display:flex;gap:14px;margin-top:16px;flex-wrap:wrap}
.trust div{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 13px}
.trust svg{width:14px;height:14px;stroke:var(--brand);stroke-width:2;fill:none}
.step{margin-bottom:22px}
.slbl{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.slbl i{width:24px;height:24px;border-radius:50%;background:var(--brand);color:#fff;font-style:normal;font-size:12px;display:grid;place-items:center;font-weight:800;font-family:'Bricolage Grotesque';flex:none}
.slbl h3{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.slbl em{font-style:normal;font-size:11.5px;color:var(--steel);margin-left:auto}
.vers{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ver{border:1.5px solid var(--line);border-radius:15px;padding:15px 16px;cursor:pointer;background:#fff;transition:.15s;position:relative}
.ver:hover{border-color:var(--brand)}
.ver.on{border-color:var(--brand);background:linear-gradient(160deg,#fff,#F6EEE1);box-shadow:var(--sh-sm)}
.ver b{font-family:'Bricolage Grotesque';font-size:15.5px;display:block}
.ver span{font-size:11.5px;color:var(--ink-soft);display:block;margin-top:3px}
.ver .vp{font-family:'Bricolage Grotesque';font-size:13px;color:var(--brand);margin-top:8px;display:block;font-weight:700}
.ver .chk{position:absolute;top:12px;right:12px;width:19px;height:19px;border-radius:50%;border:1.5px solid var(--steel);display:grid;place-items:center;transition:.15s}
.ver .chk svg{width:11px;height:11px;stroke:#fff;stroke-width:3;fill:none;opacity:0}
.ver.on .chk{background:var(--brand);border-color:var(--brand)}
.ver.on .chk svg{opacity:1}
@media(max-width:560px){.vers{grid-template-columns:1fr}}
.opts{display:flex;gap:10px;flex-wrap:wrap}
.opt{border:1.5px solid var(--line);border-radius:12px;padding:11px 15px;cursor:pointer;font-size:14px;font-weight:600;transition:.14s;background:#fff}
.opt small{display:block;color:var(--steel);font-size:11.5px;font-weight:500}
.opt:hover{border-color:var(--brand)}
.opt.on{border-color:var(--brand);background:linear-gradient(160deg,#fff,#F6EEE1)}
.opt.off{opacity:.4;pointer-events:none}
.cols{display:flex;gap:12px;flex-wrap:wrap}
.col{width:42px;height:42px;border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 1.5px var(--line),0 4px 10px rgba(0,0,0,.1);transition:.15s;position:relative}
.col:hover{transform:scale(1.08)}
.col.on{box-shadow:0 0 0 2.5px var(--brand),0 4px 10px rgba(0,0,0,.15);transform:scale(1.1)}
.col .cam{position:absolute;bottom:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.col .cam svg{width:9px;height:9px;stroke:var(--brand);stroke-width:2.4;fill:none}
.ralbtn{display:inline-flex;align-items:center;gap:8px;margin-top:10px;border:1.5px dashed var(--line);border-radius:12px;padding:9px 14px;font-size:13px;font-weight:600;color:var(--brand);background:#fff;cursor:pointer;font-family:inherit}
.ralbtn:hover{border-color:var(--brand)}
.ralbox{display:none;margin-top:10px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:14px;box-shadow:var(--sh-sm)}
.ralbox.open{display:block;animation:fade .25s}
.ralbox>input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13px;background:var(--cream);outline:none;margin-bottom:10px}
.ralgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px;max-height:220px;overflow:auto}
.ralsw{border:1.5px solid var(--line);border-radius:10px;padding:5px;cursor:pointer;text-align:center;background:#fff;transition:.12s}
.ralsw:hover{border-color:var(--brand)}
.ralsw.on{border-color:var(--brand);box-shadow:0 0 0 1.5px var(--brand)}
.ralsw i{display:block;height:26px;border-radius:7px;margin-bottom:4px;border:1px solid rgba(0,0,0,.08)}
.ralsw span{font-size:9.5px;font-weight:700;font-family:'Bricolage Grotesque';color:var(--ink-soft)}
.ralfree{display:flex;gap:8px;margin-top:10px}
.ralfree input{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13px;background:var(--cream);outline:none}
.ralfree button{border:0;background:var(--brand);color:#fff;border-radius:10px;padding:0 16px;font-weight:700;font-family:inherit;cursor:pointer}
.ralnote{font-size:11px;color:var(--steel);margin-top:8px}
.ralnote a{color:var(--brand);font-weight:600}
.eqs{display:flex;flex-direction:column;gap:9px}
.eq{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;cursor:pointer;transition:.14s;background:#fff}
.eq:hover{border-color:var(--brand)}
.eq.on{border-color:var(--brand);background:linear-gradient(160deg,#fff,#F6EEE1)}
.eq .bx{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--steel);flex:none;display:grid;place-items:center;transition:.12s}
.eq .bx svg{width:12px;height:12px;stroke:#fff;stroke-width:2.6;fill:none;opacity:0}
.eq.on .bx{background:var(--brand);border-color:var(--brand)}
.eq.on .bx svg{opacity:1}
.eq .tx{flex:1}
.eq .tx b{font-size:14px;font-weight:600;display:block}
.eq .tx span{font-size:11.5px;color:var(--steel)}
.eq .pr{font-family:'Bricolage Grotesque';font-weight:800;font-size:14px;color:var(--brand);text-align:right}
.eq .pr .htv{display:block;font-family:'Inter';font-weight:500;font-size:10px;color:var(--steel)}
.egrp{font-family:'Bricolage Grotesque';font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--steel);margin:12px 0 4px 2px}
.eqs .egrp:first-child{margin-top:0}
.cechip{display:inline-block;font-family:'Bricolage Grotesque';font-size:9.5px;font-weight:700;color:var(--dispo);border:1px solid var(--dispo);border-radius:5px;padding:0 5px;vertical-align:2px;margin-left:2px}
.eq.lock{background:#F7F3EC;border-style:dashed;cursor:pointer}
.eq.lock:hover{border-color:var(--steel)}
.eq.lock .tx b{color:var(--ink-soft)}
.eq.lock .tx span{color:var(--steel)}
.bx.lk{border-style:dashed}
.bx.lk svg{opacity:1;stroke:var(--steel);stroke-width:1.8;width:13px;height:13px}
.pr.lkp{font-size:11px;color:var(--steel);font-family:'Inter';font-weight:600;background:#EDE5D8;border-radius:999px;padding:4px 10px;white-space:nowrap}
.lockmsg{display:none;font-size:12px;color:var(--ink-soft);background:#F6F1EA;border:1px dashed var(--line);border-radius:10px;padding:9px 13px;margin:-3px 0 6px}
.lockmsg.show{display:block;animation:fade .25s}
.lockmsg a{color:var(--brand);font-weight:600}
.lockmsg button{background:none;border:0;padding:0;font:inherit;font-size:12px;color:var(--brand);font-weight:600;cursor:pointer}
.modeseg{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 14px;margin-bottom:20px;box-shadow:var(--sh-sm);flex-wrap:wrap}
.modeseg .ml{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-family:'Bricolage Grotesque'}
.modeseg .seg{flex:1;min-width:230px;margin:0}
.fixnote{font-size:12.5px;color:var(--ink);background:linear-gradient(160deg,#fff,#F6EEE1);border:1px solid var(--line);border-radius:12px;padding:11px 14px;margin-bottom:12px}
.acat{border:1px solid var(--line);border-radius:13px;background:#fff;margin-bottom:9px;overflow:hidden}
.acat summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:13px 15px;font-weight:700;font-size:13.5px;font-family:'Bricolage Grotesque'}
.acat summary::-webkit-details-marker{display:none}
.acat summary .n{font-size:11px;font-weight:600;color:var(--steel);font-family:'Inter';margin-left:auto}
.acat summary .car{width:20px;height:20px;border-radius:6px;background:var(--sand);display:grid;place-items:center;transition:transform .25s}
.acat[open] summary .car{transform:rotate(90deg)}
.acat summary .car svg{width:11px;height:11px;stroke:var(--brand);stroke-width:2.6;fill:none}
.acat .abody{padding:0 10px 10px;display:flex;flex-direction:column;gap:8px}
.stockb{font-size:9.5px;font-weight:700;font-family:'Bricolage Grotesque';border-radius:5px;padding:1px 6px;margin-left:4px;vertical-align:2px}
.st-s{color:#fff;background:var(--dispo)}
.st-c{color:var(--brand-d);background:#F4EADB;border:1px solid #E6D6BE}
.hint{font-size:12.5px;color:var(--ink-soft);background:#F6F1EA;border:1px dashed var(--line);border-radius:11px;padding:10px 14px;margin-top:10px}
.hint a{color:var(--brand);font-weight:600}
.sum{border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--sh);padding:20px;margin-top:6px}
.sline{display:flex;justify-content:space-between;font-size:13.5px;color:var(--ink-soft);padding:5px 0;gap:14px}
.sline b{color:var(--ink);font-weight:600}
.sline .sp{font-weight:600;color:var(--ink);text-align:right}
.tot{display:flex;align-items:flex-end;justify-content:space-between;border-top:1px solid var(--line);margin-top:12px;padding-top:14px}
.tot .big{font-family:'Bricolage Grotesque';font-size:34px;font-weight:800;line-height:1}
.tot .ht{font-size:12px;color:var(--steel);text-align:right}
.loaline{margin-top:12px;background:linear-gradient(160deg,#fff,#F6EEE1);border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-size:12.5px;color:var(--ink)}
.loaline b{font-family:'Bricolage Grotesque';color:var(--brand)}
.loaline small{display:block;color:var(--steel);font-size:10.5px;margin-top:3px}
.cta{width:100%;margin-top:14px;background:var(--brand);color:#fff;border:0;border-radius:13px;padding:16px;font-size:15.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;gap:9px;position:relative;overflow:hidden}
.cta:hover{background:var(--brand-d)}
.cta svg{width:19px;height:19px;stroke:#fff;stroke-width:2;fill:none}
.reassure{font-size:11.5px;color:var(--steel);text-align:center;margin-top:9px}

/* Ancre du CTA nav « Demander un devis » (/configurateur/#devis) — dégage le header fixe */
#devis{scroll-margin-top:90px}

.form{margin-top:14px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--sh-sm);padding:20px;display:none}
.form.open{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.form h3{font-size:17px;font-weight:800;margin-bottom:4px}
.form>div>p{font-size:12.5px;color:var(--ink-soft);margin-bottom:14px}
.seg{display:flex;background:var(--sand);border-radius:11px;padding:4px;margin-bottom:14px}
.seg button{flex:1;border:0;background:transparent;padding:10px;border-radius:8px;font-family:inherit;font-weight:600;font-size:13.5px;color:var(--ink-soft);cursor:pointer;transition:.15s}
.seg button.on{background:#fff;color:var(--ink);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.field{margin-bottom:11px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:5px;color:var(--ink-soft)}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px;font-family:inherit;font-size:14px;color:var(--ink);background:var(--cream);outline:none;transition:.15s}
.field input:focus,.field textarea:focus{border-color:var(--brand);background:#fff}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.tva{display:none}
.tva.show{display:block;animation:fade .25s}
.tvanote{font-size:11.5px;color:var(--brand-d);background:#F4EADB;border-radius:9px;padding:8px 11px;margin-top:-4px;margin-bottom:11px;display:none}
.tvanote.show{display:block}
.send{width:100%;background:var(--espresso);color:#fff;border:0;border-radius:11px;padding:14px;font-weight:700;font-size:14.5px;font-family:inherit;cursor:pointer;margin-top:4px;transition:.15s}
.send:hover{background:#000}
.send:disabled{opacity:.6;cursor:wait}

/* Erreur d'envoi CF7 — discrète, sous le bouton */
.senderr{display:none;font-size:12.5px;color:var(--ember-d);background:#F4EADB;border:1px solid #E6D6BE;border-radius:9px;padding:8px 11px;margin-top:8px}
.senderr.show{display:block;animation:fade .25s}

.ok{display:none;text-align:center;padding:12px 0}
.ok.show{display:block;animation:fade .3s}
.ok .circ{width:56px;height:56px;border-radius:50%;background:var(--sand);margin:0 auto 12px;display:grid;place-items:center}
.ok .circ svg{width:28px;height:28px;stroke:var(--dispo);stroke-width:2.4;fill:none}
.ok h3{margin-bottom:6px}
.ok p{font-size:13px;color:var(--ink-soft)}
.mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(252,247,240,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:12px 16px calc(12px + env(safe-area-inset-bottom));box-shadow:0 -8px 30px rgba(110,69,30,.15)}
.mbar .in{display:flex;align-items:center;justify-content:space-between;gap:14px;max-width:640px;margin:0 auto}
.mbar .mt{font-family:'Bricolage Grotesque';font-weight:800;font-size:21px;line-height:1}
.mbar .mh{font-size:10.5px;color:var(--steel)}
.mbar button{background:var(--brand);color:#fff;border:0;border-radius:999px;padding:13px 22px;font-weight:700;font-size:14px;font-family:inherit;cursor:pointer;white-space:nowrap}
@media(max-width:900px){.mbar{display:block}}
@media(max-width:900px){footer.f-simple{margin-bottom:74px}}
