:root{
  --bg:#0d1014; --bg2:#11151b; --panel:#161b22; --panel2:#1b212b; --line:#28303c;
  --txt:#eef2f7; --mut:#94a1b2; --accent:#ff6a36; --accent2:#e8511d;
  --ok:#34c77b; --err:#ff5d5d; --rad:18px;
  --pvc:#cfd6dd; --composite:#aab3bd; --alu:#8b95a0; --bois:#b07a3c;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--txt);
  font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif}
body{padding-bottom:40px;overflow-x:hidden}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
.hidden{display:none!important}

body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60vw 40vw at 85% -5%,rgba(255,106,54,.16),transparent 60%),
    radial-gradient(50vw 40vw at 0% 0%,rgba(40,80,140,.12),transparent 55%)}

header{position:sticky;top:0;z-index:30;backdrop-filter:blur(16px);
  background:linear-gradient(180deg,rgba(13,16,20,.92),rgba(13,16,20,.6));
  border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:14px;padding:13px 18px;max-width:1100px;margin:0 auto}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--txt)}
.logo .mark{width:34px;height:34px;border-radius:9px;flex:0 0 auto;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent2));font-weight:800;color:#1a0c06;
  box-shadow:0 6px 20px -6px var(--accent)}
.logo b{font-size:16px;letter-spacing:.3px;line-height:1}
.logo small{display:block;font-size:10.5px;color:var(--mut);font-weight:500;margin-top:2px}
.tabs{margin-left:auto;display:flex;gap:6px;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:4px}
.tab{border:0;background:transparent;color:var(--mut);padding:8px 15px;border-radius:9px;font-size:14px;
  font-weight:600;transition:.15s}
.tab.on{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#1a0c06}
.claims{display:flex;gap:7px;flex-wrap:wrap;padding:0 18px 12px;max-width:1100px;margin:0 auto}
.claims span{font-size:11px;color:var(--mut);background:var(--panel);border:1px solid var(--line);
  padding:4px 10px;border-radius:20px}
.claims span::before{content:"✓ ";color:var(--ok)}

main{max-width:1100px;margin:0 auto;padding:20px 18px}

.stepper{display:flex;align-items:center;gap:6px;margin-bottom:22px;overflow-x:auto;padding-bottom:4px}
.step{display:flex;align-items:center;gap:8px;flex:0 0 auto;color:var(--mut);font-size:13px;font-weight:600}
.step .n{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;font-size:12px;
  background:var(--panel);border:1px solid var(--line);transition:.2s}
.step.done .n{background:var(--ok);color:#04210f;border-color:var(--ok)}
.step.cur .n{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#1a0c06;border-color:transparent;
  box-shadow:0 0 0 4px rgba(255,106,54,.18)}
.step.cur{color:var(--txt)}
.step .ln{width:24px;height:2px;background:var(--line);border-radius:2px}

.sec{animation:rise .35s ease both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.sec h2{font-size:20px;margin:0 0 4px;font-weight:700}
.sec p.lead{color:var(--mut);margin:0 0 18px;font-size:13.5px}

.drop{border:1.5px dashed var(--line);border-radius:var(--rad);padding:34px 20px;text-align:center;
  background:var(--panel);transition:.2s;position:relative;overflow:hidden}
.drop.has{border-style:solid;padding:0}
.drop .ph{font-size:42px;margin-bottom:8px}
.drop .big{font-size:16px;font-weight:600}
.drop .sub{color:var(--mut);font-size:13px;margin-top:4px}
.drop img.preview{width:100%;max-height:340px;object-fit:cover;border-radius:var(--rad)}
.drop .change{position:absolute;right:12px;bottom:12px;background:rgba(0,0,0,.6);color:#fff;
  border:1px solid rgba(255,255,255,.2);padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600}
.cap-row{display:flex;gap:10px;margin-top:14px}
.cap-row .btn{flex:1}

.btn{border:0;border-radius:12px;padding:13px 18px;font-size:15px;font-weight:700;color:#1a0c06;
  background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 8px 24px -10px var(--accent);
  transition:.16s}
.btn:active{transform:scale(.97)}
.btn.ghost{background:var(--panel);color:var(--txt);border:1px solid var(--line);box-shadow:none}
.btn:disabled{opacity:.45;box-shadow:none;cursor:not-allowed}
.btn.full{width:100%}
.navrow{display:flex;gap:10px;margin-top:22px}
.navrow .btn{flex:1}

.grid{display:grid;gap:13px}
.types{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.choice{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);padding:16px;
  text-align:left;transition:.16s;position:relative}
.choice:active{transform:scale(.98)}
.choice.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset,0 10px 30px -16px var(--accent)}
.choice .ic{width:38px;height:38px;color:var(--accent);margin-bottom:10px}
.choice .ti{font-size:15px;font-weight:700}
.choice .ds{font-size:12px;color:var(--mut);margin-top:2px}
.choice.on::after{content:"✓";position:absolute;top:12px;right:14px;color:var(--accent);font-weight:800}

.prods{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.pcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;
  transition:.16s;text-align:left;display:flex;flex-direction:column;position:relative}
.pcard:active{transform:scale(.985)}
.pcard.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset,0 14px 40px -18px var(--accent)}
.pcard .imgwrap{aspect-ratio:4/3;background:#0a0d11;position:relative;overflow:hidden}
.pcard .imgwrap img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pcard:hover .imgwrap img{transform:scale(1.05)}
.pcard .noimg{width:100%;height:100%;display:grid;place-items:center;color:var(--mut);font-size:12px;text-align:center;padding:10px}
.badge{position:absolute;top:10px;left:10px;font-size:10.5px;font-weight:800;letter-spacing:.4px;
  text-transform:uppercase;padding:4px 9px;border-radius:8px;color:#10141a;background:var(--alu)}
.badge.pvc{background:var(--pvc)} .badge.composite{background:var(--composite)}
.badge.alu{background:var(--alu)} .badge.bois{background:var(--bois);color:#fff}
.pcard .body{padding:13px 14px;display:flex;flex-direction:column;gap:7px;flex:1}
.pcard .pn{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}
.pcard .pn .tg{font-size:10.5px;font-weight:700;color:var(--accent);border:1px solid var(--accent);
  border-radius:6px;padding:1px 6px}
.pcard .pd{font-size:12.5px;color:var(--mut);line-height:1.45;flex:1}
.pcard .hl{display:flex;flex-wrap:wrap;gap:5px}
.pcard .hl span{font-size:10.5px;color:var(--txt);background:var(--panel2);border:1px solid var(--line);
  padding:3px 8px;border-radius:7px}
.pcard.on::before{content:"✓";position:absolute;z-index:2;top:10px;right:10px;font-size:13px;
  font-weight:800;color:#1a0c06;background:var(--accent);width:26px;height:26px;border-radius:8px;display:grid;place-items:center}

.colors{display:flex;flex-wrap:wrap;gap:12px}
.col{display:flex;flex-direction:column;align-items:center;gap:6px;border:0;background:transparent;width:64px}
.col .dot{width:50px;height:50px;border-radius:14px;border:2px solid var(--line);transition:.16s;
  box-shadow:inset 0 -8px 14px rgba(0,0,0,.25)}
.col.on .dot{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,106,54,.25),inset 0 -8px 14px rgba(0,0,0,.25)}
.col .cl{font-size:11px;color:var(--mut);text-align:center;line-height:1.2}
.col.on .cl{color:var(--txt)}

.recap{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--rad);padding:14px;margin-bottom:16px}
.recap img{width:64px;height:64px;border-radius:12px;object-fit:cover;flex:0 0 auto;background:#0a0d11}
.recap .info{flex:1;min-width:0}
.recap .info b{font-size:15px}
.recap .info div{font-size:12.5px;color:var(--mut)}
.recap .sw{width:22px;height:22px;border-radius:7px;border:1px solid var(--line);flex:0 0 auto}

.prog{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 10px}
.ring{--p:0;width:128px;height:128px;border-radius:50%;display:grid;place-items:center;margin-bottom:18px;
  background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--line) 0)}
.ring .in{width:104px;height:104px;border-radius:50%;background:var(--bg);display:grid;place-items:center;
  font-size:26px;font-weight:700}
.phases{display:flex;flex-direction:column;gap:9px;width:100%;max-width:360px;margin-top:8px}
.phl{display:flex;align-items:center;gap:11px;color:var(--mut);font-size:14px;text-align:left}
.phl .b{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);flex:0 0 auto;display:grid;place-items:center;font-size:11px}
.phl.on{color:var(--txt)} .phl.on .b{border-color:var(--accent);color:var(--accent)}
.phl.ok .b{background:var(--ok);color:#04210f;border-color:var(--ok)}
.note{color:var(--mut);font-size:12.5px;margin-top:14px}
.errbox{background:rgba(255,93,93,.1);border:1px solid var(--err);color:#ffd2d2;padding:14px;border-radius:12px;font-size:14px}

.ba{position:relative;border-radius:var(--rad);overflow:hidden;touch-action:none;user-select:none;border:1px solid var(--line)}
.ba img{width:100%;display:block;pointer-events:none}
.ba .after{position:absolute;inset:0;overflow:hidden;width:50%}
.ba .after img{height:100%;width:auto;max-width:none}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--accent);transform:translateX(-50%);
  box-shadow:0 0 14px var(--accent)}
.ba .handle::after{content:"⟺";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:38px;height:38px;border-radius:50%;background:var(--accent);color:#1a0c06;display:grid;place-items:center;font-weight:800}
.ba .lab{position:absolute;bottom:10px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;border-radius:8px;
  background:rgba(0,0,0,.6);color:#fff}
.ba .lab.l{left:10px} .ba .lab.r{right:10px}

.matgroup{margin-bottom:26px}
.matgroup h3{display:flex;align-items:center;gap:10px;font-size:17px;margin:0 0 4px}
.matgroup h3 .chip{width:14px;height:14px;border-radius:4px;border:1px solid var(--line)}
.matgroup .blurb{color:var(--mut);font-size:13px;margin:0 0 14px}

.demolbl{font-size:13px;color:var(--mut);margin-bottom:10px;font-weight:600}
.demos{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
.demo{border:1px solid var(--line);background:var(--panel);border-radius:13px;overflow:hidden;padding:0;
  display:flex;flex-direction:column;transition:.16s;position:relative}
.demo:active{transform:scale(.97)}
.demo.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.demo img{width:100%;aspect-ratio:4/3;object-fit:cover;background:#0a0d11}
.demo span{font-size:11.5px;color:var(--txt);padding:7px 9px;text-align:left}
.demo.on::after{content:"✓";position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:7px;
  background:var(--accent);color:#1a0c06;font-weight:800;display:grid;place-items:center;font-size:12px}

.gal{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.gal a{border-radius:14px;overflow:hidden;border:1px solid var(--line);display:block;aspect-ratio:4/3;background:#0a0d11}
.gal a img{width:100%;height:100%;object-fit:cover}
.empty{color:var(--mut);text-align:center;padding:50px 20px;font-size:14px}

@media(max-width:600px){
  .claims{display:none}
  .logo small{display:none}
  .sec h2{font-size:18px}
}

/* Sélecteur mode de rendu (rapide / fidèle) — ajouté 07/06 soir */
.modepick{display:flex;gap:10px;margin:4px 0 14px}
.modeopt{flex:1;display:flex;flex-direction:column;gap:2px;align-items:flex-start;
  border:1px solid var(--line);background:var(--panel);color:var(--txt);
  border-radius:12px;padding:11px 13px;cursor:pointer;text-align:left;transition:.15s}
.modeopt b{font-size:14px;font-weight:800}
.modeopt span{font-size:11.5px;color:var(--mut)}
.modeopt.on{border-color:transparent;color:#1a0c06;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 6px 18px -8px var(--accent)}
.modeopt.on span{color:#3a1a0c}
.modeopt:active{transform:scale(.97)}
