/* ══════════════════════════════════════════
   JuridCI — Style commun formulaires
   Inspiré de Swiftlet : blanc, clean, sobre
   ══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Instrument+Serif:ital@1&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ind:#5B4FE8;
  --ind2:#4338CA;
  --ind-lt:#EEF0FF;
  --or:#F59E0B;
  --or-lt:#FEF3C7;
  --vt:#10B981;
  --vt-lt:#D1FAE5;
  --danger:#EF4444;
  --danger-lt:#FEF2F2;
  --noir:#0D0D12;
  --texte:#1F2937;
  --muted:#6B7280;
  --border:#E5E7EB;
  --border2:#D1D5DB;
  --bg:#F9F9FB;
  --w:#fff;
  --r:10px;
  --r-lg:14px;
}

html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--bg);color:var(--texte);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

/* ── NAV ── */
.nav{
  position:sticky;top:0;z-index:200;
  height:60px;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-weight:800;font-size:18px;color:var(--noir);
  text-decoration:none;display:flex;align-items:center;gap:8px;
}
.nav-logo-mark{
  width:30px;height:30px;border-radius:7px;
  background:var(--ind);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:14px;
}
.nav-logo span{color:var(--ind)}
.nav-back{
  font-size:13px;font-weight:500;color:var(--muted);
  text-decoration:none;display:flex;align-items:center;gap:5px;
  transition:.2s;
}
.nav-back:hover{color:var(--ind)}

/* ── LAYOUT FORMULAIRE ── */
.form-page{padding:0 5% 60px;max-width:1200px;margin:0 auto}
.form-layout{display:grid;grid-template-columns:240px 1fr;gap:32px;padding-top:32px}

/* ── SIDEBAR ── */
.sidebar{
  position:sticky;top:80px;align-self:start;
  background:var(--w);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:24px;
  height:fit-content;
}
.sidebar-title{font-size:15px;font-weight:800;color:var(--noir);margin-bottom:4px}
.sidebar-sub{font-size:12px;color:var(--muted);margin-bottom:20px;line-height:1.5}

.step-nav{display:flex;flex-direction:column;gap:2px;margin-bottom:24px}
.step-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:8px;cursor:pointer;
  transition:.18s;
}
.step-item:hover{background:var(--bg)}
.step-item.active{background:var(--ind-lt)}
.step-item.done .step-circle{background:var(--vt);border-color:var(--vt);color:#fff}
.step-circle{
  width:24px;height:24px;border-radius:50%;
  border:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--muted);flex-shrink:0;
  transition:.2s;
}
.step-item.active .step-circle{background:var(--ind);border-color:var(--ind);color:#fff}
.step-label{font-size:12.5px;font-weight:500;color:var(--muted);transition:.2s}
.step-item.active .step-label{color:var(--ind);font-weight:600}
.step-item.done .step-label{color:var(--texte)}

.sidebar-docs{border-top:1px solid var(--border);padding-top:16px}
.sidebar-docs-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:10px}
.doc-item{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--muted);padding:5px 0;
}
.doc-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--border2);flex-shrink:0;transition:.3s;
}
.doc-dot.ready{background:var(--vt)}

/* ── MAIN ── */
.form-main{min-width:0}

/* Barre de progression */
.progress-wrap{
  height:4px;background:var(--border);border-radius:99px;
  overflow:hidden;margin-bottom:28px;
}
.progress-bar{
  height:100%;background:linear-gradient(90deg,var(--ind),#8B5CF6);
  border-radius:99px;transition:width .4s ease;
}

/* ── PANELS ── */
.step-panel{display:none}
.step-panel.active{display:block}

.step-eyebrow{
  font-size:12px;font-weight:700;color:var(--ind);
  letter-spacing:.8px;text-transform:uppercase;margin-bottom:8px;
}
.step-title{
  font-size:clamp(20px,2.5vw,26px);font-weight:800;
  color:var(--noir);margin-bottom:6px;letter-spacing:-.4px;
}
.step-desc{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:24px}

/* ── FIELDSETS ── */
.fs{
  background:var(--w);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:22px 24px;margin-bottom:16px;
}
.fs-title{
  font-size:13px;font-weight:700;color:var(--noir);
  margin-bottom:16px;display:flex;align-items:center;gap:8px;
}

/* ── CHAMPS ── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1/-1}

label{font-size:12.5px;font-weight:600;color:var(--texte)}
.req{color:var(--danger)}
.opt{font-weight:400;color:var(--muted);font-size:11.5px}

input,select,textarea{
  width:100%;height:40px;
  border:1.5px solid var(--border);border-radius:var(--r);
  padding:0 12px;font-size:13.5px;
  font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--noir);background:var(--w);
  outline:none;transition:.18s;
  -webkit-appearance:none;appearance:none;
}
input[type="checkbox"],input[type="radio"]{
  width:16px;height:16px;min-width:16px;
  -webkit-appearance:checkbox;appearance:checkbox;
  cursor:pointer;flex-shrink:0;padding:0;
  accent-color:var(--ind);
}
input:focus,select:focus,textarea:focus{border-color:var(--ind);box-shadow:0 0 0 3px rgba(91,79,232,.1)}
input[type="checkbox"]:focus,input[type="radio"]:focus{box-shadow:none;border-color:transparent}
input::placeholder{color:var(--border2)}
select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
textarea{height:auto;padding:10px 12px;resize:vertical;line-height:1.6}

.hint{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:2px}

/* ── INFOBULLES ── */
.ib{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 16px;border-radius:var(--r);
  font-size:13px;line-height:1.55;margin-bottom:14px;
}
.ib.vert{background:var(--vt-lt);color:#065F46}
.ib.rouge{background:var(--danger-lt);color:#991B1B}
.ib.or{background:var(--or-lt);color:#92400E}
.ib-icon{flex-shrink:0;font-size:14px}

/* ── CAPITAL SUMMARY ── */
.cap-summary{
  display:none;background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r);padding:14px 16px;margin-top:12px;
}
.cap-summary.show{display:block}
.cap-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:3px 0}
.cap-row span:last-child{font-weight:600}
.cap-total{font-weight:700;font-size:14px;border-top:1px solid var(--border);padding-top:8px;margin-top:4px}

/* ── ASSOCIÉS ── */
.assoc-block{border-top:2px solid var(--ind-lt);margin-top:20px;padding-top:16px}
.assoc-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
}
.assoc-head span{font-size:14px;font-weight:700;color:var(--noir)}

/* ── BILAN ── */
.bilan{
  display:none;background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:16px 20px;margin-top:16px;
}
.bilan.show{display:block}
.bilan-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.bilan-ecart{display:flex;justify-content:space-between;font-size:14px;font-weight:700;padding:8px 0;border-top:1px solid var(--border);margin-top:4px}
.bilan-alert,.bilan-ok{font-size:12.5px;padding:8px 12px;border-radius:7px;margin-top:8px;display:none}
.bilan-alert{background:var(--danger-lt);color:#991B1B}
.bilan-ok{background:var(--vt-lt);color:#065F46}

/* ── ACTIVITÉS ── */
.act-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.act-row{display:flex;gap:8px;align-items:center}
.act-row input{flex:1}
.clause-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.clause-label{font-size:12.5px;font-weight:600;color:var(--texte)}
.clause-text{
  font-size:12px;color:var(--muted);line-height:1.7;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r);padding:12px 14px;
}
.tranche-box{
  height:40px;border-radius:var(--r);border:1.5px solid var(--border);
  padding:0 12px;display:flex;align-items:center;
  font-size:13px;color:var(--muted);background:var(--bg);
}
.regime-badge{
  display:none;align-items:center;gap:8px;
  background:var(--ind-lt);color:var(--ind);
  border-radius:var(--r);padding:10px 14px;
  font-size:13px;font-weight:600;margin-top:10px;
}
.regime-badge.show{display:flex}

/* ── UPLOAD ── */
.upload{
  position:relative;border:2px dashed var(--border2);border-radius:var(--r-lg);
  padding:20px;text-align:center;cursor:pointer;transition:.2s;overflow:hidden;
}
.upload:hover{border-color:var(--ind);background:var(--ind-lt)}
.upload input[type=file]{
  position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;
}
.upload-icon{font-size:24px;margin-bottom:6px}
.upload-label{font-size:13px;font-weight:600;color:var(--texte)}
.upload-sub{font-size:11.5px;color:var(--muted);margin-top:3px}
.upload-name{
  font-size:12px;color:var(--vt);font-weight:600;
  margin-top:6px;display:none;
}

/* ── RÉCAP ── */
.recap-card{
  background:var(--w);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;
}
.recap-head{
  padding:12px 18px;background:var(--bg);
  border-bottom:1px solid var(--border);
  font-size:13px;font-weight:700;
}
.recap-body{padding:14px 18px}
.recap-row{display:flex;align-items:flex-start;gap:12px;padding:5px 0;font-size:13px}
.rk{font-weight:600;color:var(--muted);min-width:140px;flex-shrink:0}
.rv{color:var(--texte);flex:1}

/* ── PAIEMENT ── */
.tarif-box{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 22px;margin-bottom:20px;
}
.tarif-row{display:flex;justify-content:space-between;font-size:13.5px;padding:4px 0}
.tarif-total{font-weight:800;font-size:16px;border-top:1px solid var(--border);padding-top:10px;margin-top:6px;display:flex;justify-content:space-between;width:100%}

.pay-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.pay-opt{
  border:2px solid var(--border);border-radius:var(--r-lg);
  padding:16px 12px;text-align:center;cursor:pointer;transition:.2s;
}
.pay-opt:hover{border-color:var(--ind)}
.pay-opt.sel{border-color:var(--ind);background:var(--ind-lt)}
.pay-logo{
  width:44px;height:44px;border-radius:10px;margin:0 auto 8px;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:11px;letter-spacing:.3px;
}
.wave{background:#003DA5;color:#fff}
.orange{background:#FF6600;color:#fff}
.mtn{background:#FFCC00;color:#111}
.pay-opt-name{font-size:12.5px;font-weight:700}
.pay-instr{
  display:none;background:var(--ind-lt);border:1px solid var(--ind-mid,#C7C3F7);
  border-radius:var(--r);padding:14px 16px;font-size:13.5px;line-height:1.6;
  margin-bottom:12px;
}
.pay-instr.show{display:block}

/* Valeurs calculées */
.val-display,.parts-display,.pct-display{
  height:40px;border-radius:var(--r);border:1.5px solid var(--border);
  padding:0 12px;display:flex;align-items:center;
  font-size:13.5px;background:var(--bg);color:var(--texte);font-weight:600;
}
.parts-display{color:var(--ind)}

/* ── BOUTONS ── */
.btn{
  padding:10px 22px;border-radius:var(--r);border:1.5px solid var(--border);
  font:600 14px 'Plus Jakarta Sans',sans-serif;cursor:pointer;transition:.2s;
  background:var(--w);color:var(--texte);
}
.btn:hover{border-color:var(--border2);background:var(--bg)}
.btn-next{
  background:var(--ind);border-color:var(--ind);color:#fff;
}
.btn-next:hover{background:var(--ind2);border-color:var(--ind2)}
.btn:disabled{opacity:.4;cursor:default}
.btn-pay{
  background:var(--ind);border-color:var(--ind);color:#fff;
  font-size:15px;font-weight:700;
  box-shadow:0 4px 16px rgba(91,79,232,.3);
}
.btn-pay:hover{background:var(--ind2)}

.btn-add{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 18px;border-radius:var(--r);
  border:1.5px dashed var(--border2);
  font:600 13px 'Plus Jakarta Sans',sans-serif;
  color:var(--muted);background:transparent;cursor:pointer;
  transition:.2s;margin-top:12px;
}
.btn-add:hover{border-color:var(--ind);color:var(--ind);background:var(--ind-lt)}
.btn-del{
  padding:5px 12px;border-radius:6px;border:1px solid var(--border);
  font:500 12px 'Plus Jakarta Sans',sans-serif;color:var(--muted);
  background:var(--w);cursor:pointer;transition:.2s;
}
.btn-del:hover{border-color:var(--danger);color:var(--danger)}
.btn-del-sm{
  width:28px;height:28px;border-radius:6px;border:1px solid var(--border);
  font-size:15px;color:var(--muted);background:var(--w);cursor:pointer;
  transition:.2s;flex-shrink:0;display:flex;align-items:center;justify-content:center;
}
.btn-del-sm:hover{border-color:var(--danger);color:var(--danger)}

.nav-btns{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:24px;gap:12px;
}

/* ── SUCCÈS ── */
.success-wrap{
  text-align:center;padding:60px 20px;
  background:var(--w);border:1px solid var(--border);
  border-radius:var(--r-lg);
}
.success-icon{font-size:52px;margin-bottom:20px;display:block}
.success-title{font-size:26px;font-weight:800;color:var(--noir);margin-bottom:10px}
.success-sub{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:28px}
.success-docs{
  display:inline-flex;flex-direction:column;gap:8px;
  margin-bottom:28px;text-align:left;
}
.success-doc{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;background:var(--vt-lt);
  border-radius:var(--r);font-size:13.5px;font-weight:600;color:#065F46;
}
.success-doc::before{content:'✓';font-weight:800}

/* ── OR (EI) ── */
.btn-next.or{background:var(--or);border-color:var(--or)}
.btn-next.or:hover{background:#D97706;border-color:#D97706}
.btn-pay.or{background:var(--or);border-color:var(--or)}
.doc-dot.ready-or{background:var(--or)}
.step-item.active.or .step-circle{background:var(--or);border-color:var(--or)}
.step-item.active.or .step-label{color:var(--or)}
.step-eyebrow.or{color:var(--or)}

/* ── RESPONSIVE ── */
@media(max-width:800px){
  .form-layout{grid-template-columns:1fr}
  .sidebar{position:static;display:flex;flex-direction:column}
  .step-nav{flex-direction:row;flex-wrap:wrap;gap:4px}
  .step-label{display:none}
  .fg{grid-template-columns:1fr}
  .field.full{grid-column:1}
  .pay-opts{grid-template-columns:1fr}
}

/* ══ DATE PICKER CUSTOM ══ */
.dp-wrap{position:relative}
.dp-input{cursor:pointer;background:var(--w) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") no-repeat right 12px center}
.dp-input:read-only{cursor:pointer}

.dp-calendar{
  display:none;position:absolute;top:calc(100% + 6px);left:0;z-index:999;
  background:var(--w);border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:16px;box-shadow:0 8px 32px rgba(0,0,0,.12);min-width:280px;
}
.dp-calendar.open{display:block}

.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.dp-nav{
  width:28px;height:28px;border-radius:6px;border:1px solid var(--border);
  background:var(--w);cursor:pointer;font-size:14px;color:var(--texte);
  display:flex;align-items:center;justify-content:center;transition:.15s;
}
.dp-nav:hover{background:var(--ind-lt);border-color:var(--ind);color:var(--ind)}
.dp-selects{display:flex;gap:6px}
.dp-sel{
  height:30px;border:1px solid var(--border);border-radius:6px;
  padding:0 8px;font-size:12.5px;font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--texte);background:var(--w);cursor:pointer;outline:none;
}
.dp-sel:focus{border-color:var(--ind)}

.dp-days-head{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}
.dp-day-name{text-align:center;font-size:11px;font-weight:700;color:var(--muted);padding:4px 0}

.dp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dp-day{
  height:34px;border-radius:7px;border:none;background:transparent;
  font-size:13px;font-family:'Plus Jakarta Sans',sans-serif;cursor:pointer;
  color:var(--texte);transition:.15s;display:flex;align-items:center;justify-content:center;
}
.dp-day:hover:not(.empty):not(.selected){background:var(--ind-lt);color:var(--ind)}
.dp-day.selected{background:var(--ind);color:#fff;font-weight:700}
.dp-day.today:not(.selected){border:1.5px solid var(--ind);color:var(--ind)}
.dp-day.empty{cursor:default;pointer-events:none}
.dp-day.other-month{color:var(--border2)}
.dp-day.dp-disabled,.dp-day[disabled]{color:var(--border2);opacity:.4;cursor:not-allowed;pointer-events:none}
