:root{
  --bg:#f4f7fb;--panel:#ffffff;--panel2:#eef2f7;--line:#dce3ec;--txt:#1c2733;--muted:#5f6c7b;--accent:#2563eb;
  --green:#1a7f37;--amber:#9a6700;--orange:#bc4c00;--red:#cf222e;--violet:#6639ba;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.muted{color:var(--muted)}.small{font-size:11px}
header{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#ffffff,#f4f7fb);border-bottom:1px solid var(--line);padding:10px 16px;box-shadow:0 1px 3px rgba(20,40,70,.05)}
.brand{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.brand h1{font-size:16px;margin:0;font-weight:650;color:#12203a}
.tag{font-size:11px;color:var(--muted);border:1px solid var(--line);background:#fff;padding:2px 8px;border-radius:20px}
.stats{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:6px 10px;min-width:70px;box-shadow:0 1px 2px rgba(20,40,70,.04)}
.stat b{display:block;font-size:16px}.stat span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.progress{height:6px;background:var(--panel2);border-radius:4px;overflow:hidden;margin-top:8px}
.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--accent))}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}
input,select,textarea,button{font-family:inherit;font-size:13px;color:var(--txt);background:#fff;border:1px solid var(--line);border-radius:7px;padding:6px 9px}
input::placeholder{color:#9aa6b3}button{cursor:pointer}button:hover{border-color:var(--accent)}
.btn-ghost{background:#fff}
main{padding:16px;max-width:1180px;margin:0 auto}
.batchbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.pager{display:flex;gap:6px;align-items:center}
.card{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px;box-shadow:0 1px 3px rgba(20,40,70,.06)}
.card[data-st="valide"]{border-left-color:var(--green)}
.card[data-st="corrige"]{border-left-color:var(--accent)}
.card[data-st="deep"]{border-left-color:var(--violet)}
.card[data-st="reanalyser"]{border-left-color:var(--amber)}
.card[data-st="supprimer"]{border-left-color:var(--red);background:#fff6f6;opacity:.85}
.row1{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.person{font-size:16px;font-weight:650;color:#12203a}.role{color:var(--muted);font-size:12px;margin-top:1px}
.firme{margin-top:6px;font-size:12px;color:var(--muted)}.firme b{color:var(--txt);font-weight:600}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;align-items:center}
.badge{font-size:11px;padding:2px 8px;border-radius:20px;border:1px solid var(--line);background:var(--panel2);white-space:nowrap}
.b-niv{border-color:#c3d0e0;background:#eef3fb}.b-site{border-color:var(--orange);color:#9a3f00;background:#fdf1e8}
.conf{font-weight:700}.conf.hi{color:var(--green)}.conf.mid{color:var(--amber)}.conf.lo{color:var(--red)}
.fr-El{color:var(--green)}.fr-Mo{color:var(--amber)}.fr-Fa{color:var(--red)}.fr-Ac{color:var(--muted)}
.note-src{font-size:11px;color:var(--orange);margin-top:4px}
.actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.actions button{font-size:12px;padding:5px 10px;font-weight:600;background:#fff}
.a-val{border-color:var(--green);color:var(--green)}.a-val:hover{background:rgba(26,127,55,.10)}
.a-cor{border-color:var(--accent);color:var(--accent)}.a-cor:hover{background:rgba(37,99,235,.10)}
.a-deep{border-color:var(--violet);color:var(--violet)}.a-deep:hover{background:rgba(102,57,186,.10)}
.a-rea{border-color:var(--amber);color:var(--amber)}.a-rea:hover{background:rgba(154,103,0,.10)}
.a-sup{border-color:var(--red);color:var(--red)}.a-sup:hover{background:rgba(207,34,46,.10)}
.on{outline:2px solid currentColor;outline-offset:1px}
.edit,.reason{margin-top:10px;display:none;background:var(--panel2);border:1px dashed var(--line);border-radius:8px;padding:10px}
.edit.show,.reason.show{display:block}
.edit label{display:block;font-size:11px;color:var(--muted);margin:6px 0 2px}
.edit input,.edit select{width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.reason textarea{width:100%;min-height:52px}
.decided-by{font-size:11px;color:var(--muted);margin-top:6px}
footer{color:var(--muted);font-size:11px;text-align:center;padding:24px}
kbd{background:#fff;border:1px solid var(--line);border-bottom-width:2px;border-radius:4px;padding:1px 5px;font-size:11px}
/* login */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:linear-gradient(160deg,#eaf1fb,#f4f7fb)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:26px;width:340px;display:flex;flex-direction:column;gap:6px;box-shadow:0 8px 30px rgba(20,40,70,.10)}
.login-card h1{font-size:18px;margin:0 0 2px;color:#12203a}
.login-card label{font-size:12px;color:var(--muted);margin-top:8px}
.login-card input{width:100%}
.login-card button{margin-top:14px;background:var(--accent);color:#fff;font-weight:700;border:none;padding:9px}
.login-card button:hover{background:#1d4fd0}
.err{background:#fdecec;border:1px solid #f3b7bb;border-radius:7px;padding:8px;font-size:12px;color:#b02a37}
/* ===== tableau de review ===== */
.ta-c{text-align:center}
table.rev{width:100%;border-collapse:collapse;font-size:13px;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.rev thead th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:8px 10px;background:#eef3f9;border-bottom:1px solid var(--line);white-space:nowrap}
.rev tbody td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.rrow:hover>td{background:#f7fafd}
.rrow[data-st="supprimer"]>td{background:#fff6f6}
.rev .sub{font-size:11px;margin-top:2px}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle}
.d-a_verifier{background:#c3ccd6}.d-valide{background:var(--green)}.d-corrige{background:var(--accent)}
.d-deep{background:var(--violet)}.d-reanalyser{background:var(--amber)}.d-supprimer{background:var(--red)}
.stlbl{font-size:11px;color:var(--muted)}
.c-st{white-space:nowrap}
.tgl{cursor:pointer;color:var(--muted);user-select:none;font-size:11px}
.em-pub{color:var(--green)}.em-der{color:var(--amber)}.em-non{color:var(--muted)}
.em-badge{font-size:9px;border:1px solid currentColor;border-radius:8px;padding:0 4px;vertical-align:middle}
.src-ok{color:var(--green);font-size:12px}.src-warn{color:var(--red);font-size:12px}
.c-act{white-space:nowrap}
.abtn{font-size:12px;padding:3px 6px;line-height:1;margin:0 1px;background:#fff;border:1px solid var(--line);border-radius:6px}
.abtn.a-val.on{background:var(--green);color:#fff;border-color:var(--green)}
.abtn.a-cor.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.abtn.a-deep.on{background:var(--violet);color:#fff;border-color:var(--violet)}
.abtn.a-rea.on{background:var(--amber);color:#fff;border-color:var(--amber)}
.abtn.a-sup.on{background:var(--red);color:#fff;border-color:var(--red)}
tr.detail>td{background:var(--panel2);padding:12px 14px}
.dwrap{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dcol .dlbl{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:4px;font-weight:600}
.excerpt{margin-top:6px;padding:8px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:6px;font-style:italic;color:#33414f}
.dcol .grid2 input,.dcol .grid2 select{width:100%}
.dcol textarea{width:100%;min-height:48px;margin-top:4px}
@media(max-width:820px){.dwrap{grid-template-columns:1fr}}
.d-prio_email{background:#0d9488}
.abtn.a-prio.on{background:#0d9488;color:#fff;border-color:#0d9488}
.srcbtn{font-size:11px;padding:2px 7px;border-radius:6px;background:#fff;border:1px solid var(--line);cursor:pointer}
.srcbtn.src-ok{color:var(--green);border-color:#bfe3c8}.srcbtn.src-warn{color:var(--red);border-color:#f3c0c4}
.em-badge{cursor:pointer}
.hint{color:#b7c2ce;font-size:10px}
.certbar{height:8px;background:var(--panel2);border-radius:4px;overflow:hidden;margin-top:3px}
.certbar i{display:block;height:100%;background:linear-gradient(90deg,var(--red),var(--amber),var(--green))}
/* ===== overlays (tooltip) ===== */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;left:0;top:calc(100% + 5px);z-index:60;
  background:#12203a;color:#fff;padding:7px 9px;border-radius:7px;font-size:11px;font-weight:400;line-height:1.35;
  width:230px;white-space:normal;box-shadow:0 6px 18px rgba(15,30,55,.28)}
[data-tip]:hover::before{content:"";position:absolute;left:14px;top:calc(100% + 0px);border:5px solid transparent;border-bottom-color:#12203a;z-index:61}
.c-act [data-tip]:hover::after{left:auto;right:0}
/* ===== pop-up modale ===== */
.modal-bg{position:fixed;inset:0;background:rgba(18,32,58,.42);display:none;align-items:center;justify-content:center;z-index:100}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:12px;max-width:560px;width:92%;padding:20px 22px;box-shadow:0 24px 70px rgba(0,0,0,.28);max-height:82vh;overflow:auto}
.modal h3{margin:0 0 12px;font-size:16px;color:#12203a}
.modal .close{float:right;cursor:pointer;color:var(--muted);font-size:14px}
.mrow{margin:10px 0}
.mlbl{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;display:block;margin-bottom:2px}
.mbtn{display:inline-block;margin-top:14px;background:var(--accent);color:#fff;padding:9px 16px;border-radius:8px;font-weight:600;text-decoration:none}
.mbtn:hover{background:#1d4fd0;text-decoration:none}
.warnbox{background:#fdf1e8;border:1px solid #f0c69a;color:#9a3f00;padding:9px;border-radius:8px;font-size:12px;margin:10px 0}
/* ===== certitude / priorité / alertes ===== */
.pdot{display:inline-block;width:9px;height:9px;border-radius:50%;vertical-align:middle;margin-right:2px}
.p-Haute{background:var(--red)}.p-Moyenne{background:var(--amber)}.p-Basse{background:var(--green)}
.alert{cursor:help;color:var(--red);font-weight:700}
.bce-ok{color:var(--green);font-weight:700;cursor:help}
.bce-ko{color:var(--red);font-weight:700;cursor:help;font-size:10px}
.alertbox{background:#fdecec;border:1px solid #f3b7bb;color:#b02a37;padding:8px;border-radius:8px;font-size:12px;margin-bottom:10px;line-height:1.5}
