/* ============================================================
   État des lieux — Groupe Verlaine
   Design system (charte Verlaine, mobile-first, terrain)
   ============================================================ */
:root{
  --navy:#0d1c4d;
  --navy-2:#0a1640;
  --navy-soft:#1a2c5e;
  --red:#e8412f;
  --red-deep:#cf3019;
  --green:#1f8a5b;
  --green-soft:#e7f5ee;
  --amber:#f5a623;
  --ink:#15233f;
  --ink-2:#3a455e;
  --muted:#6b7690;
  --faint:#9aa3b8;
  --line:#e7eaf2;
  --line-2:#eef0f6;
  --bg:#f4f6fb;
  --card:#ffffff;
  --radius:16px;
  --radius-sm:12px;
  --shadow-sm:0 2px 10px rgba(13,28,77,.06);
  --shadow:0 14px 40px rgba(13,28,77,.10);
  --ease:cubic-bezier(.2,.7,.2,1);
  --tap:54px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:'Manrope',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:#0a1230;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
*{-webkit-tap-highlight-color:transparent;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,select,textarea{font-family:inherit;}

/* ===== App shell ===== */
.app{
  width:100%;max-width:480px;margin:0 auto;
  min-height:100vh;min-height:100dvh;
  background:var(--bg);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
@media(min-width:520px){
  body{padding:0;display:flex;align-items:stretch;justify-content:center;}
  .app{max-width:440px;min-height:100vh;box-shadow:0 0 80px rgba(0,0,0,.45);}
}
@media(min-width:900px){
  body{background:radial-gradient(120% 90% at 50% 0%, #122254 0%, #0a1230 70%);padding:28px 0;}
  .app{min-height:calc(100vh - 56px);border-radius:30px;overflow:hidden;}
}
/* PWA mobile : fond clair pour les zones sûres (encoche / barre d'accueil) */
@media(max-width:519px){ body{background:var(--bg);} }

/* ===== App bar ===== */
.appbar{
  position:sticky;top:0;z-index:30;
  background:var(--navy);color:#fff;
  padding:calc(14px + env(safe-area-inset-top)) 16px 14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 2px 16px rgba(10,18,48,.3);
}
.appbar-back{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:#fff;flex:0 0 auto;
  transition:background .15s var(--ease);
}
.appbar-back:active{background:rgba(255,255,255,.22);}
.appbar-back svg{width:20px;height:20px;}
.appbar-titles{flex:1;min-width:0;}
.appbar-kicker{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.appbar-title{font-size:17px;font-weight:800;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.appbar-logo{height:26px;width:auto;flex:0 0 auto;opacity:.95;}
.appbar-lang{
  font-size:12px;font-weight:800;color:#fff;
  background:rgba(255,255,255,.12);border-radius:999px;
  padding:6px 11px;flex:0 0 auto;letter-spacing:.04em;
}

/* progress */
.progress{height:4px;background:rgba(255,255,255,.16);display:flex;}
.progress-fill{background:var(--red);transition:width .35s var(--ease);}

/* ===== Screen ===== */
.screen{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:22px 18px calc(28px + env(safe-area-inset-bottom));}
.screen-pad{padding-bottom:120px;}

.eyebrow{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin:0 0 8px;}
.h1{font-size:25px;line-height:1.18;font-weight:800;letter-spacing:-.02em;color:var(--navy);margin:0 0 8px;}
.h2{font-size:19px;font-weight:800;color:var(--navy);margin:0 0 4px;letter-spacing:-.01em;}
.lead{font-size:15px;color:var(--muted);margin:0 0 22px;line-height:1.55;}
.section-label{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin:0 0 12px;}

/* ===== Action bar ===== */
.actionbar{
  position:sticky;bottom:0;z-index:25;
  background:linear-gradient(180deg, rgba(244,246,251,0) 0%, var(--bg) 26%);
  padding:14px 18px calc(16px + env(safe-area-inset-bottom));
  display:flex;gap:12px;
}
.actionbar.stacked{flex-direction:column;}

/* ===== Buttons ===== */
.btn{
  display:flex;align-items:center;justify-content:center;gap:9px;
  min-height:var(--tap);padding:0 22px;border-radius:999px;
  font-size:16px;font-weight:800;letter-spacing:-.01em;
  transition:transform .12s var(--ease),background .16s var(--ease),box-shadow .16s var(--ease),opacity .16s;
  width:100%;
}
.btn svg{width:20px;height:20px;}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 22px rgba(232,65,47,.26);}
.btn-primary:active{transform:translateY(1px);background:var(--red-deep);}
.btn-primary:disabled{background:#d7dbe6;color:#fff;box-shadow:none;cursor:not-allowed;}
.btn-dark{background:var(--navy);color:#fff;}
.btn-dark:active{transform:translateY(1px);background:var(--navy-2);}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line);box-shadow:var(--shadow-sm);}
.btn-ghost:active{background:var(--line-2);}
.btn-back{flex:0 0 auto;width:var(--tap);padding:0;}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 10px 22px rgba(37,211,102,.3);}
.btn-wa:active{transform:translateY(1px);}

/* ===== Language picker (home) ===== */
.langrow{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:30px;}
.langbtn{
  background:#fff;border:2px solid var(--line);border-radius:var(--radius);
  padding:16px 8px;text-align:center;transition:all .16s var(--ease);
  box-shadow:var(--shadow-sm);
}
.langbtn .flag{font-size:24px;line-height:1;}
.langbtn .lname{display:block;margin-top:8px;font-size:14px;font-weight:800;color:var(--navy);}
.langbtn.active{border-color:var(--red);background:#fff5f3;}
.langbtn:active{transform:scale(.97);}

/* ===== Mode cards ===== */
.modecard{
  display:flex;align-items:center;gap:16px;width:100%;text-align:left;
  background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);
  padding:20px;margin-bottom:14px;box-shadow:var(--shadow-sm);
  transition:transform .14s var(--ease),box-shadow .16s var(--ease),border-color .16s;
}
.modecard:active{transform:scale(.985);box-shadow:var(--shadow);}
.modecard-ic{
  width:56px;height:56px;flex:0 0 auto;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:var(--navy);color:#fff;
}
.modecard-ic.after{background:var(--green);}
.modecard-ic svg{width:28px;height:28px;}
.modecard-tx{flex:1;min-width:0;}
.modecard-tx b{display:block;font-size:17px;font-weight:800;color:var(--navy);}
.modecard-tx span{display:block;font-size:13.5px;color:var(--muted);margin-top:3px;line-height:1.45;}
.modecard-arrow{color:var(--faint);flex:0 0 auto;}
.modecard-arrow svg{width:22px;height:22px;}

/* ===== Fields ===== */
.field{margin-bottom:16px;}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink-2);margin-bottom:7px;}
.field .ctrl{
  width:100%;min-height:var(--tap);padding:0 16px;
  background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  font-size:16px;color:var(--ink);outline:none;
  transition:border-color .15s var(--ease),box-shadow .15s;
}
textarea.ctrl{min-height:90px;padding:14px 16px;line-height:1.5;resize:vertical;}
.field .ctrl:focus{border-color:var(--navy);box-shadow:0 0 0 4px rgba(13,28,77,.08);}
.field .ctrl::placeholder{color:var(--faint);}
.field .ctrl[readonly]{background:#f6f8fc;color:var(--ink-2);}
.field .hint{font-size:12.5px;color:var(--faint);margin-top:6px;}
.input-icon{position:relative;}
.input-icon .ctrl{padding-left:46px;}
.input-icon svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--faint);}

/* prefill badge */
.prefill{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12px;font-weight:700;color:var(--green);
  background:var(--green-soft);border-radius:999px;padding:6px 12px;margin-bottom:16px;
}
.prefill svg{width:14px;height:14px;}

/* client card */
.client-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:6px 18px;box-shadow:var(--shadow-sm);margin-bottom:8px;}
.client-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-2);}
.client-row:last-child{border-bottom:none;}
.client-row svg{width:19px;height:19px;color:var(--red);flex:0 0 auto;}
.client-row .cr-tx{min-width:0;}
.client-row .cr-k{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);}
.client-row .cr-v{font-size:15.5px;font-weight:700;color:var(--ink);margin-top:1px;}

/* ===== Step header ===== */
.step-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px;}
.step-num{
  width:46px;height:46px;flex:0 0 auto;border-radius:13px;
  background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;
}
.step-num svg{width:24px;height:24px;}
.step-head .sh-tx{flex:1;padding-top:1px;}

/* ===== Photo grid ===== */
.photo-block{margin-bottom:22px;}
.photogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.photo-add{
  aspect-ratio:1;border-radius:var(--radius-sm);
  border:2px dashed #c7cfe0;background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  color:var(--navy);transition:all .15s var(--ease);
}
.photo-add:active{background:var(--line-2);border-color:var(--navy);}
.photo-add svg{width:26px;height:26px;color:var(--red);}
.photo-add span{font-size:11px;font-weight:700;color:var(--muted);text-align:center;line-height:1.2;padding:0 4px;}
.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:#dde3ef;box-shadow:var(--shadow-sm);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb .rm{
  position:absolute;top:5px;right:5px;width:26px;height:26px;border-radius:50%;
  background:rgba(13,20,40,.7);color:#fff;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px);
}
.photo-thumb .rm svg{width:15px;height:15px;}
.photo-count{font-size:12.5px;font-weight:700;color:var(--muted);margin-top:10px;display:flex;align-items:center;gap:6px;}
.photo-count.ok{color:var(--green);}
.photo-count svg{width:15px;height:15px;}

/* single-slot (PV pages, cheque) */
.slot{
  border:2px dashed #c7cfe0;background:#fff;border-radius:var(--radius-sm);
  min-height:128px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:var(--navy);position:relative;overflow:hidden;transition:all .15s var(--ease);width:100%;
}
.slot:active{background:var(--line-2);}
.slot svg{width:30px;height:30px;color:var(--red);}
.slot span{font-size:13px;font-weight:700;color:var(--muted);}
.slot.filled{border-style:solid;border-color:var(--green);padding:0;}
.slot.filled img{width:100%;height:170px;object-fit:cover;}
.slot .slot-rm{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(13,20,40,.72);color:#fff;display:flex;align-items:center;justify-content:center;}
.slot .slot-rm svg{width:16px;height:16px;color:#fff;}
.slot-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.slot-tag{position:absolute;top:8px;left:8px;background:var(--navy);color:#fff;font-size:11px;font-weight:800;padding:4px 9px;border-radius:8px;}

/* ===== Segmented (état / règlement) ===== */
.seg{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#eef1f7;border-radius:14px;padding:6px;}
.seg button{
  min-height:48px;border-radius:10px;font-size:15px;font-weight:800;color:var(--muted);
  display:flex;align-items:center;justify-content:center;gap:8px;transition:all .16s var(--ease);
}
.seg button svg{width:18px;height:18px;}
.seg button.on-good{background:var(--green);color:#fff;box-shadow:0 4px 12px rgba(31,138,91,.3);}
.seg button.on-bad{background:var(--red);color:#fff;box-shadow:0 4px 12px rgba(232,65,47,.3);}
.seg button.on-neutral{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm);}

/* defaut chips */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px;}
.chip{
  padding:11px 18px;border-radius:999px;font-size:14px;font-weight:700;
  background:#fff;border:1.5px solid var(--line);color:var(--ink-2);transition:all .14s var(--ease);
}
.chip.on{background:var(--navy);border-color:var(--navy);color:#fff;}
.chip:active{transform:scale(.95);}

/* warn / required box */
.req-box{background:#fff7f5;border:1.5px solid #f6cfc8;border-radius:var(--radius-sm);padding:16px;margin-top:14px;}
.req-box .rb-title{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:800;color:var(--red);margin-bottom:14px;}
.req-box .rb-title svg{width:17px;height:17px;}

/* counter */
.counter{display:flex;align-items:center;gap:0;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;width:fit-content;}
.counter button{width:54px;height:54px;display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:24px;font-weight:700;}
.counter button:active{background:var(--line-2);}
.counter button:disabled{color:var(--faint);}
.counter .cval{min-width:58px;text-align:center;font-size:20px;font-weight:800;color:var(--navy);}
.counter svg{width:20px;height:20px;}

/* ===== Recap ===== */
.recap-note{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--muted);background:#eef1f7;border-radius:10px;padding:10px 14px;margin-bottom:18px;}
.recap-note svg{width:16px;height:16px;color:var(--navy);flex:0 0 auto;}
.recap-sec{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden;}
.recap-sec-h{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line-2);}
.recap-sec-h svg{width:18px;height:18px;color:var(--red);}
.recap-sec-h b{font-size:14.5px;font-weight:800;color:var(--navy);flex:1;}
.recap-sec-body{padding:14px 16px;}
.recap-line{display:flex;justify-content:space-between;gap:14px;font-size:14px;padding:6px 0;}
.recap-line .rk{color:var(--muted);font-weight:600;}
.recap-line .rv{color:var(--ink);font-weight:700;text-align:right;}
.badge-state{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px;}
.badge-state.good{background:var(--green-soft);color:var(--green);}
.badge-state.bad{background:#fdeceA;background:#fdecea;color:var(--red);}
.badge-state.skip{background:#eef1f7;color:var(--muted);}
.recap-thumbs{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px;}
.recap-thumbs img{width:62px;height:62px;border-radius:9px;object-fit:cover;box-shadow:var(--shadow-sm);}

/* signature */
.sigpad-wrap{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.sigpad{display:block;width:100%;height:200px;touch-action:none;background:repeating-linear-gradient(0deg,#fff,#fff 38px,#f1f3f9 39px);}
.sigpad-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--line-2);}
.sigpad-bar .sb-hint{font-size:12.5px;color:var(--faint);font-weight:600;}
.sigpad-clear{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:800;color:var(--red);padding:6px 10px;}
.sigpad-clear svg{width:15px;height:15px;}

.certify{display:flex;align-items:flex-start;gap:11px;margin:18px 2px 6px;}
.certify input{width:24px;height:24px;flex:0 0 auto;accent-color:var(--green);margin-top:1px;}
.certify label{font-size:13.5px;color:var(--ink-2);line-height:1.45;font-weight:600;}

/* ===== Sending / confirmation overlay ===== */
.overlay{position:absolute;inset:0;z-index:60;background:rgba(8,14,36,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:28px;animation:fade .2s var(--ease);}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{background:#fff;border-radius:22px;padding:32px 26px;text-align:center;width:100%;max-width:340px;box-shadow:var(--shadow);animation:pop .26s var(--ease);}
@keyframes pop{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}
.sheet-ic{width:72px;height:72px;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;}
.sheet-ic.ok{background:var(--green-soft);color:var(--green);}
.sheet-ic.ok svg{width:38px;height:38px;}
.sheet h3{font-size:21px;font-weight:800;color:var(--navy);margin:0 0 8px;}
.sheet p{font-size:14.5px;color:var(--muted);margin:0 0 22px;line-height:1.55;}
.spinner{width:54px;height:54px;border-radius:50%;border:5px solid var(--line);border-top-color:var(--red);margin:0 auto 18px;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Final screen ===== */
.final{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:36px 26px;background:radial-gradient(120% 70% at 50% 0%, #16285e 0%, var(--navy) 60%);color:#fff;}
.final-ic{width:96px;height:96px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;margin-bottom:24px;}
.final-ic svg{width:50px;height:50px;color:#fff;}
.final h1{font-size:28px;font-weight:800;margin:0 0 10px;letter-spacing:-.02em;}
.final p{font-size:15.5px;color:rgba(255,255,255,.78);margin:0 0 6px;max-width:30ch;line-height:1.55;}
.final-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:16px 18px;margin:22px 0 8px;width:100%;max-width:340px;text-align:left;}
.final-card .fc-k{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.5);}
.final-card .fc-v{font-size:15px;font-weight:700;margin-top:2px;}
.final-actions{width:100%;max-width:340px;margin-top:18px;display:flex;flex-direction:column;gap:12px;}
.final-note{display:flex;align-items:center;gap:7px;justify-content:center;font-size:12.5px;color:rgba(255,255,255,.6);font-weight:600;margin-top:4px;}
.final-note svg{width:15px;height:15px;}
.final .btn-text{background:none;color:rgba(255,255,255,.7);font-weight:700;font-size:14px;min-height:auto;padding:8px;}

/* error toast */
.toast{position:absolute;left:50%;bottom:96px;transform:translateX(-50%);z-index:70;background:var(--navy);color:#fff;font-size:13.5px;font-weight:700;padding:12px 18px;border-radius:999px;box-shadow:var(--shadow);display:flex;align-items:center;gap:8px;animation:pop .2s var(--ease);max-width:90%;}
.toast svg{width:17px;height:17px;color:var(--amber);flex:0 0 auto;}

/* skip / non concerné */
.skip-toggle{display:flex;align-items:center;gap:12px;width:100%;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;font-size:14.5px;font-weight:700;color:var(--ink-2);margin-bottom:20px;box-shadow:var(--shadow-sm);transition:all .15s var(--ease);}
.skip-toggle:active{transform:scale(.99);}
.skip-toggle .sk-box{width:24px;height:24px;border-radius:7px;border:2px solid #c7cfe0;display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:#fff;transition:all .15s var(--ease);}
.skip-toggle svg:last-child{color:var(--faint);flex:0 0 auto;}
.skip-toggle.on{border-color:var(--navy);background:#f4f7fd;color:var(--navy);}
.skip-toggle.on .sk-box{background:var(--navy);border-color:var(--navy);}
.skip-toggle.on svg:last-child{color:var(--navy);}
.skip-note{background:#f6f8fc;border:1.5px dashed #c7cfe0;border-radius:var(--radius);padding:30px 24px;text-align:center;color:var(--muted);font-size:14.5px;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:12px;}
.skip-note svg{color:var(--faint);}

.fade-in{animation:scin .28s var(--ease);}
@keyframes scin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
