/* Assurdix Devis V6 Design System */

/* Cacher le header/footer du site sur les pages devis */
#navbar{display:none !important}
footer{display:none !important}
.axeptio_overlay{z-index:90 !important}
body{padding-top:0 !important}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
:root{
  --o:#EA580C;--o2:#F97316;--o3:#FBBF24;
  --grad:linear-gradient(135deg,#EA580C 0%,#F97316 60%,#FBBF24 100%);
  --o-bg:rgba(234,88,12,.07);--o-border:rgba(234,88,12,.18);--o-glow:rgba(234,88,12,.3);
  --bg:#FFFFFF;--bg2:#F8F8FA;--bg3:#F0F0F4;
  --ink:#111118;--ink2:#3D3D4A;--muted:#71717A;
  --border:#E4E4E7;--border2:#CDCDD6;
  --green:#16A34A;--green-bg:#F0FDF4;--green-b:rgba(22,163,74,.2);
}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg2);color:var(--ink);min-height:100vh;font-weight:400}

/* ── TOPBAR ── */
.topbar{
  background:var(--bg);border-bottom:1px solid var(--border);
  height:60px;display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;position:sticky;top:0;z-index:100;
}
.topbar img{height:28px}
.topbar-r{display:flex;align-items:center;gap:16px}
.tb-secure{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}
.tb-help{font-size:13px;font-weight:500;color:var(--o);text-decoration:none}
.tb-timer{
  font-size:13px;color:var(--ink2);font-weight:600;
  display:flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:100px;
  background:var(--o-bg);border:1px solid var(--o-border);
  transition:all .3s;
}
.tb-timer.warn{color:var(--o);background:rgba(234,88,12,.12);font-weight:700}
.tb-timer.danger{color:#EF4444;background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.2);font-weight:700}
.tb-timer.done{color:var(--green);background:var(--green-bg);border-color:var(--green-b);font-weight:700}

/* ── PROGRESS ── */
.prog-wrap{background:var(--bg);border-bottom:1px solid var(--border);padding:16px 5%}
.prog-inner{max-width:500px;margin:0 auto;display:flex;align-items:center;gap:0}
.ps{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.ps::after{content:'';position:absolute;top:16px;left:calc(50% + 18px);right:calc(-50% + 18px);height:3px;background:var(--border);z-index:0;border-radius:2px}
.ps:last-child::after{display:none}
.ps.done::after{background:var(--o)}
.ps.active::after{background:linear-gradient(to right,var(--o) 50%,var(--border) 100%)}
.ps-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;font-family:'Nunito',sans-serif;border:2.5px solid var(--border);background:var(--bg);color:var(--muted);z-index:1;transition:all .3s}
.ps.done .ps-dot{background:var(--o);border-color:var(--o);color:#fff}
.ps.active .ps-dot{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 0 0 5px var(--o-bg)}
.ps-lbl{font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap}
.ps.active .ps-lbl{color:var(--o);font-weight:700}
.ps.done .ps-lbl{color:var(--ink2)}

/* ── CONTAINER ── */
.wrap{max-width:760px;margin:0 auto;padding:28px 20px 80px}

/* ── STEP 0/2/3 — layout 2 cols (main + neo sidebar) ── */
.dvs-layout{max-width:1060px;margin:0 auto;padding:14px 20px 30px;display:flex;gap:20px;align-items:flex-start}
.dvs-main{flex:1;min-width:0}
.dvs-card{padding:20px 22px}
.dvs-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;position:sticky;top:80px}

/* ── STEP 1/3 — rows de 2 ou 3 inputs ── */
.dvs-row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dvs-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ── Layout adresse postale : 2 lignes (rue pleine largeur, CP + ville) ── */
.dvs-address-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dvs-address-grid .dvs-address-street{grid-column:1 / -1}

/* ── SUCCES — ligne tel rappel : input + bouton cote-a-cote ── */
.dvs-callback-row{display:flex;gap:10px;align-items:flex-end}
.dvs-callback-btn{max-width:160px;padding:13px 18px}

/* ── SCREEN ── */
.screen{display:none}
.screen.active{display:block;animation:fadeUp .32s cubic-bezier(.16,1,.3,1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── CARD ── */
.card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:0 2px 8px rgba(0,0,0,.04);margin-bottom:14px}
.card-title{font-family:'Nunito',sans-serif;font-size:22px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:6px}
.card-sub{font-size:14px;color:var(--muted);font-weight:300;margin-bottom:24px;line-height:1.6}

/* ── BTN NEXT ── */
.btn-next{
  width:100%;padding:15px;border-radius:12px;
  background:var(--grad);color:#fff;border:none;
  font-size:15px;font-weight:700;font-family:inherit;
  cursor:pointer;box-shadow:0 6px 20px var(--o-glow);
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .3s cubic-bezier(.16,1,.3,1);
}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 10px 28px var(--o-glow)}
.btn-next:disabled{background:var(--bg3);box-shadow:none;color:var(--muted);transform:none;cursor:not-allowed}

/* Sticky bottom bar pour le bouton Continuer */
.sticky-bottom{
  position:sticky;bottom:0;left:0;right:0;
  background:linear-gradient(to top, var(--bg2) 60%, transparent);
  padding:16px 0 12px;
  z-index:50;
}
.btn-next.activated{
  animation:btnPulse .4s cubic-bezier(.16,1,.3,1);
}
@keyframes btnPulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.02)}
  100%{transform:scale(1)}
}
.btn-back{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:4px;padding:8px 0 0;transition:color .2s}
.btn-back:hover{color:var(--ink)}

/* ── INPUT ── */
.ig{margin-bottom:18px}
.ig-label{font-size:13px;font-weight:600;color:var(--ink2);margin-bottom:6px;display:block}
.ig-wrap{position:relative}
.inp{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:11px;font-size:15px;font-family:inherit;color:var(--ink);background:var(--bg);transition:all .2s;outline:none}
.inp:focus{border-color:var(--o);box-shadow:0 0 0 4px var(--o-bg)}
.inp.valid{border-color:var(--green);background:var(--green-bg)}
.inp.big{font-size:22px;font-weight:800;font-family:'Nunito',sans-serif;letter-spacing:.08em;text-align:center;text-transform:uppercase;padding:16px}
.inp-ico{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:16px;display:none}
.inp-spin{position:absolute;right:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:2px solid var(--border2);border-top-color:var(--o);animation:spin .7s linear infinite;display:none}
@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}

/* Date inputs */
.date-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Options pills */
.opts{display:flex;gap:8px;flex-wrap:wrap}
.opt{padding:8px 16px;border-radius:100px;border:1.5px solid var(--border);font-size:13px;font-weight:500;color:var(--ink2);cursor:pointer;background:var(--bg);transition:all .18s;font-family:inherit}
.opt:hover{border-color:var(--o-border);color:var(--o);background:var(--o-bg)}
.opt.sel{border-color:var(--o);background:var(--o-bg);color:var(--o);font-weight:600}

/* Q block */
.qblock{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.qblock-lbl{font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:8px;display:block}

/* Slider */
.slider-wrap{display:flex;align-items:center;gap:12px;margin-top:4px}
.slider{-webkit-appearance:none;flex:1;height:4px;border-radius:2px;background:var(--border);outline:none;cursor:pointer}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--grad);box-shadow:0 2px 6px var(--o-glow);cursor:pointer}
.slider-val{font-family:'Nunito',sans-serif;font-size:15px;font-weight:800;color:var(--o);min-width:60px;text-align:right}

/* ── SCREEN 0 — TUNNEL ── */
.tunnel-split{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.tc{border:1.5px solid var(--border);border-radius:18px;padding:22px 20px;background:var(--bg);transition:all .22s}
.tc.pro{border-color:var(--o-border)}
.tc-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.tc-ico{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.tc-ico.orange{background:var(--o-bg);border:1px solid var(--o-border)}
.tc-ico.grey{background:var(--bg2);border:1px solid var(--border)}
.tc-badge{font-size:10px;font-weight:700;letter-spacing:.04em;padding:3px 10px;border-radius:100px;align-self:flex-start}
.tc-badge.grad{background:var(--grad);color:#fff}
.tc-badge.grey{background:none;border:1px solid var(--border);color:var(--muted)}
.tc-title{font-family:'Nunito',sans-serif;font-size:16px;font-weight:800;color:var(--ink);margin-bottom:4px}
.tc-sub{font-size:12px;color:var(--muted);font-weight:300;line-height:1.5;margin-bottom:14px}

/* SIREN inline */
.siren-inp{width:100%;padding:11px 38px 11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:18px;font-weight:800;font-family:'Nunito',sans-serif;letter-spacing:.1em;text-align:center;color:var(--ink);background:var(--bg2);transition:all .2s;outline:none;position:relative}
.siren-inp:focus{border-color:var(--o);background:var(--bg);box-shadow:0 0 0 3px var(--o-bg)}
.siren-inp.valid{border-color:var(--green);background:var(--green-bg)}
.siren-res{margin-top:8px;padding:9px 12px;background:var(--green-bg);border:1px solid var(--green-b);border-radius:9px;display:none;animation:fadeUp .25s ease}
.siren-res.show{display:flex;align-items:center;gap:9px}
.sr-check{width:22px;height:22px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.sr-name{font-size:12px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif}
.sr-ape{font-size:10px;color:var(--muted);display:block;margin-top:1px}

/* Particulier mini cards */
.pp-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;display:block}
.pp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:0}
.pp{border:1.5px solid var(--border);border-radius:10px;padding:8px 6px;text-align:center;cursor:pointer;background:var(--bg);transition:all .18s;position:relative}
.pp:hover{border-color:var(--o-border);background:var(--o-bg)}
.pp.sel{border-color:var(--o);background:var(--o-bg)}
.pp.sel::after{content:'✓';position:absolute;top:3px;right:6px;font-size:9px;font-weight:800;color:var(--o)}
.pp-ico{font-size:20px;display:block;margin-bottom:2px;line-height:1}
.pp-name{font-size:10px;font-weight:600;color:var(--ink);font-family:'Nunito',sans-serif}
.pp.autre{border-style:dashed}

/* SmartScan full-width */
.ss-bar{
  border:1.5px dashed var(--border2);border-radius:14px;
  padding:18px 22px;cursor:pointer;background:var(--bg2);
  transition:all .22s;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-bottom:14px;
}
.ss-bar:hover,.ss-bar.drag{border-color:var(--o);background:var(--o-bg);box-shadow:0 4px 16px var(--o-glow)}
.ss-bar input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.ss-left{display:flex;align-items:center;gap:13px}
.ss-ico{font-size:24px;flex-shrink:0}
.ss-title{font-size:14px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif;margin-bottom:2px}
.ss-sub{font-size:11px;color:var(--muted);font-weight:300}
.ss-tags{display:flex;gap:5px;flex-wrap:wrap;flex-shrink:0}
.ss-tag{font-size:10px;font-weight:600;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:100px;padding:3px 9px}

/* Timer badge */
.timer-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--o-bg);border:1.5px solid var(--o-border);
  border-radius:100px;padding:6px 18px;
  transition:all .3s;
}
.timer-badge.warn{border-color:var(--o);background:rgba(234,88,12,.12)}
.timer-badge.danger{border-color:#EF4444;background:rgba(239,68,68,.08)}
.timer-badge.expired{border-color:#EF4444;background:rgba(239,68,68,.08)}
.timer-num{font-family:'Nunito',sans-serif;font-size:26px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;transition:all .3s}
.timer-badge.danger .timer-num{background:none;-webkit-text-fill-color:#EF4444;color:#EF4444}

/* Garanties */
.guarantees{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;padding-top:14px}
.g-item{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}

/* ── FORMS ── */
.form-icon{font-size:32px;margin-bottom:10px;display:block}
.form-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--o-bg);border:1px solid var(--o-border);
  border-radius:100px;padding:4px 12px;
  font-size:11px;font-weight:600;color:var(--o);
  margin-bottom:16px;
}
/* OCR prefill highlight */
.ocr-filled{border-color:var(--green)!important;background:var(--green-bg)!important}
.ocr-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10px;font-weight:600;color:var(--green);
  background:var(--green-bg);border:1px solid var(--green-b);
  border-radius:100px;padding:2px 8px;margin-left:6px;
}

/* ── SCAN PROCESSING ── */
.scan-card{background:var(--ink);border-radius:16px;padding:24px;margin-bottom:14px;overflow:hidden;position:relative}
.scan-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(234,88,12,.15) 0%,transparent 70%)}
.scan-top{display:flex;align-items:center;gap:12px;margin-bottom:16px;position:relative;z-index:1}
.scan-ico{width:40px;height:40px;border-radius:12px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.scan-title{font-size:14px;font-weight:700;color:#fff;font-family:'Nunito',sans-serif}
.scan-sub{font-size:12px;color:rgba(255,255,255,.4);font-weight:300}
.scan-progress{height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin-bottom:14px;position:relative;z-index:1}
.scan-bar{height:100%;width:0;background:var(--grad);border-radius:2px;transition:width .3s ease}
.scan-steps{display:flex;flex-direction:column;gap:7px;position:relative;z-index:1}
.scan-step{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.35);transition:color .3s}
.scan-step.active{color:#F97316;font-weight:500}
.scan-step.done{color:rgba(255,255,255,.6)}
.scan-step-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.2);flex-shrink:0;transition:background .3s}
.scan-step.active .scan-step-dot{background:var(--o2);animation:blink .8s infinite}
.scan-step.done .scan-step-dot{background:#4ADE9F}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* OCR results */
.ocr-result{display:none;animation:fadeUp .3s ease;margin-bottom:14px}
.ocr-result.show{display:block}
.ocr-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.ocr-title{font-size:14px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif}
.ocr-tag{font-size:11px;font-weight:600;color:var(--green);background:var(--green-bg);padding:3px 10px;border-radius:100px;border:1px solid var(--green-b)}
.ocr-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ocr-field{background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:10px 13px}
.ocr-key{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:2px}
.ocr-val{font-size:13px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif}
.ocr-val.o{color:var(--o)}

/* ── PRODUCT CARDS (étape pro) ── */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}
.prod-card{border:1.5px solid var(--border);border-radius:12px;padding:14px 12px;cursor:pointer;background:var(--bg);transition:all .2s;position:relative;overflow:hidden}
.prod-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .22s}
.prod-card:hover{border-color:var(--o-border);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.07)}
.prod-card:hover::after{transform:scaleX(1)}
.prod-card.sel{border-color:var(--o);background:var(--o-bg)}
.prod-card.sel::after{transform:scaleX(1)}
.prod-card.rec{border-color:var(--o-border)}
.pc-reco{position:absolute;top:7px;right:7px;font-size:9px;font-weight:700;background:var(--grad);color:#fff;border-radius:100px;padding:2px 7px;letter-spacing:.03em}
.pc-ico{font-size:22px;margin-bottom:6px;display:block}
.pc-name{font-size:12px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif;margin-bottom:2px}
.pc-desc{font-size:11px;color:var(--muted);font-weight:300;line-height:1.3}
.pc-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;margin-top:8px;transition:all .2s}
.prod-card.sel .pc-check{background:var(--o);border-color:var(--o)}
.pc-check svg{display:none}
.prod-card.sel .pc-check svg{display:block}
.prod-summary{font-size:12px;color:var(--muted);padding:8px 0 4px}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-grid .ig{margin-bottom:0}
.full{grid-column:1/-1}
.creneaux{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:6px}
.cren{border:1.5px solid var(--border);border-radius:9px;padding:9px 6px;text-align:center;cursor:pointer;font-size:11px;font-weight:600;color:var(--muted);background:var(--bg);transition:all .18s;font-family:inherit}
.cren:hover{border-color:var(--o-border);color:var(--o);background:var(--o-bg)}
.cren.sel{border-color:var(--o);background:var(--o-bg);color:var(--o)}
.cren-ico{font-size:15px;display:block;margin-bottom:3px}

/* ── CONFIRMATION ── */
.confirm-wrap{background:var(--ink);border-radius:20px;padding:36px;text-align:center;position:relative;overflow:hidden}
.confirm-wrap::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:450px;height:450px;border-radius:50%;background:radial-gradient(ellipse,rgba(234,88,12,.18) 0%,transparent 70%);pointer-events:none}
.cf-emoji{font-size:48px;display:block;margin-bottom:12px;position:relative;z-index:1}
.cf-ref{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:4px 14px;font-size:11px;color:rgba(255,255,255,.4);font-family:'Courier New',monospace;margin-bottom:14px;position:relative;z-index:1}
.cf-title{font-family:'Nunito',sans-serif;font-size:26px;font-weight:900;color:#fff;letter-spacing:-.5px;margin-bottom:8px;position:relative;z-index:1}
.cf-sub{font-size:14px;color:rgba(255,255,255,.5);font-weight:300;line-height:1.6;margin-bottom:24px;position:relative;z-index:1}
.cf-conseiller{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:12px;margin-bottom:20px;text-align:left;position:relative;z-index:1}
.cf-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#C4A882,#A07050);display:flex;align-items:center;justify-content:center;font-weight:800;font-family:'Nunito',sans-serif;color:#fff;font-size:12px;flex-shrink:0}
.cf-name{font-size:13px;font-weight:700;color:#fff;font-family:'Nunito',sans-serif;display:block}
.cf-status{font-size:11px;color:#4ADE9F;display:flex;align-items:center;gap:4px;font-weight:600}
.cf-dot{width:5px;height:5px;border-radius:50%;background:#4ADE9F;animation:blink 1.5s infinite}
.cf-elapsed{text-align:right;margin-left:auto}
.cf-elapsed-lbl{font-size:10px;color:rgba(255,255,255,.3);display:block}
.cf-elapsed-val{font-family:'Nunito',sans-serif;font-size:15px;font-weight:800;color:var(--o2)}
.cf-checks{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:0;position:relative;z-index:1}
.cf-check{font-size:12px;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:5px}
.cf-check svg{color:var(--o2)}

/* Espace client card */
.espace-card{background:var(--bg);border:2px solid var(--o-border);border-radius:18px;padding:28px;background:linear-gradient(135deg,var(--bg) 60%,var(--o-bg))}
.ec-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.ec-ico-wrap{width:42px;height:42px;border-radius:13px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:0 4px 12px var(--o-glow)}
.ec-title{font-family:'Nunito',sans-serif;font-size:17px;font-weight:800;color:var(--ink);margin-bottom:3px}
.ec-sub{font-size:13px;color:var(--muted);font-weight:300;line-height:1.5}
.ec-features{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}
.ec-feat{font-size:12px;color:var(--ink2);display:flex;align-items:center;gap:6px}
.ec-feat svg{color:var(--green);flex-shrink:0}
.pwd-strength{display:flex;gap:4px;margin-top:6px}
.pwd-bar{flex:1;height:3px;border-radius:2px;background:var(--border);transition:background .3s}
.app-btns{display:flex;gap:10px;margin-top:14px}
.app-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border-radius:10px;border:1.5px solid var(--border);background:var(--bg);font-size:12px;font-weight:600;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .2s}

/* ── REASSURANCE SIDEBAR ── */
.reassurance-sidebar{
  width:200px;flex-shrink:0;
  display:flex;flex-direction:column;gap:10px;
  position:sticky;top:80px;
  padding-top:30px;
}
.reassurance-card{
  background:var(--bg);border:1px solid var(--border);border-radius:12px;
  padding:14px 14px;
}
.reassurance-ico{font-size:16px;display:block;margin-bottom:4px}
.reassurance-title{font-family:'Nunito',sans-serif;font-size:12px;font-weight:800;color:var(--ink);margin-bottom:2px}
.reassurance-desc{font-size:10px;color:var(--muted);font-weight:300;line-height:1.4}
@media(max-width:960px){
  .reassurance-sidebar{display:none}
}
@media(max-width:768px){
  /* Topbar plus compacte */
  .topbar{padding:0 16px;height:54px}
  .topbar img{height:24px}
  .topbar-r{gap:10px}
  .tb-secure{display:none}
  .tb-help{font-size:12px}
  .tb-timer{font-size:11px;padding:4px 9px}

  /* Progress steps */
  .prog-wrap{padding:10px 12px}
  .ps-lbl{font-size:10px}
  .ps-dot{width:26px;height:26px;font-size:11px}
  .ps::after{top:13px;left:calc(50% + 15px);right:calc(-50% + 15px);height:2px}

  /* Container + cards */
  .wrap{padding:18px 14px 80px}
  .card{padding:20px 18px;border-radius:16px}
  .card-title{font-size:18px}
  .card-sub{font-size:13px;margin-bottom:18px}

  /* Inputs */
  .inp{padding:12px 14px;font-size:14px}
  .inp.big{font-size:18px;padding:14px}
  .ig{margin-bottom:14px}

  /* Step 0/2/3 — layout flex passe en column, ordre naturel : card puis sidebar */
  .dvs-layout{flex-direction:column;padding:10px 14px 30px;gap:14px}
  .dvs-main{width:100%}
  .dvs-sidebar{width:100%;position:static;top:auto}
  .dvs-card{padding:16px 14px}
  /* Step 1/3 — rows de 2 ou 3 -> 1 col en mobile */
  .dvs-row2,.dvs-row3{grid-template-columns:1fr;gap:0}
  /* Adresse : street pleine largeur, CP + ville restent cote a cote en mobile */
  .dvs-address-grid{gap:10px}
  /* Succes — ligne tel + bouton -> stack vertical */
  .dvs-callback-row{flex-direction:column;align-items:stretch;gap:12px}
  .dvs-callback-btn{max-width:none;width:100%}
  /* Step 0 — tunnel split passe en 1 col */
  .tunnel-split{grid-template-columns:1fr;gap:10px}
  .tc{padding:18px 16px}

  /* Particulier mini cards : reste 3 cols mais plus serre */
  .pp-grid{gap:4px}
  .pp{padding:7px 4px}
  .pp-ico{font-size:18px}

  /* SmartScan bar : flex column */
  .ss-bar{flex-direction:column;align-items:flex-start;padding:14px 16px;gap:10px}
  .ss-tags{margin-top:4px}

  /* Forms grids 2 cols -> 1 col */
  .ocr-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .ec-features{grid-template-columns:1fr}

  /* Date row reste 2 cols (suffisamment serre pour DD / MM) */
  /* Creneaux : 3 cols -> 2 cols */
  .creneaux{grid-template-columns:repeat(2,1fr)}

  /* Produits cards : 3 cols -> 1 col */
  .prod-grid{grid-template-columns:1fr}

  /* Timer num plus petit */
  .timer-num{font-size:22px}

  /* Boutons suivant/back */
  .btn-next{padding:13px;font-size:14px}

  /* Garanties + checks alignement */
  .guarantees{gap:12px;font-size:11px}
  .cf-checks{gap:12px}
}
@media(max-width:480px){
  .pp-grid{grid-template-columns:repeat(2,1fr)}
  .ps-lbl{display:none}
  .ps-dot{width:24px;height:24px;font-size:10px}
}
.app-btn:hover{border-color:var(--o-border);color:var(--o);background:var(--o-bg)}

/* ── NEO COMPANION SIDEBAR ── */
.dossier-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg2);margin-bottom:5px;transition:all .3s cubic-bezier(.16,1,.3,1)}
.dossier-row.filled{background:#F0FDF4;border-color:rgba(22,163,74,.2)}
.dr-key{font-size:10px;color:var(--muted)}
.dr-val{font-size:11px;font-weight:700;font-family:'Nunito',sans-serif;color:var(--ink);opacity:0;transform:translateX(6px);transition:all .3s cubic-bezier(.16,1,.3,1)}
.dossier-row.filled .dr-val{opacity:1;transform:translateX(0);color:#16A34A}
.dossier-row.filled .dr-key{color:#16A34A}
.dossier-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:8px}
.dossier-progress-fill{height:100%;background:var(--grad);border-radius:2px;width:0;transition:width .5s cubic-bezier(.16,1,.3,1)}
.dossier-progress-label{display:flex;justify-content:space-between;font-size:9px;color:var(--muted);margin-top:4px}
.neo-bubble{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:14px;margin-top:8px}
.neo-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.neo-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#EA580C,#FBBF24);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;font-family:'Nunito',sans-serif;flex-shrink:0}
.neo-name{font-size:11px;font-weight:700;color:var(--ink);font-family:'Nunito',sans-serif}
.neo-status{font-size:9px;color:#16A34A;display:flex;align-items:center;gap:3px;font-weight:600}
.neo-dot{width:5px;height:5px;border-radius:50%;background:#16A34A;animation:bpulse 2s infinite}
.neo-message{font-size:11px;color:var(--ink2);line-height:1.55;font-weight:300;margin-bottom:8px;min-height:36px;transition:opacity .3s ease}
.neo-actions{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}
.neo-action-btn{padding:5px 10px;border-radius:100px;border:1px solid var(--o-border);background:var(--o-bg);color:var(--o);font-size:10px;font-weight:600;cursor:pointer;font-family:inherit;text-align:left;transition:all .2s}
.neo-action-btn:hover{background:var(--o);color:#fff}
.neo-ask-btn{width:100%;padding:7px;border-radius:8px;border:1px dashed var(--border2);background:none;color:var(--muted);font-size:10px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}
.neo-ask-btn:hover{border-color:var(--o);color:var(--o)}
