/* QUICKRFMP — design system */
*{box-sizing:border-box;margin:0}
:root{--p:#2563eb;--pd:#1e293b;--a:#f59e0b;--bg:#f3f5f9;--card:#fff;--txt:#1a202c;--mut:#64748b;
--line:#e2e8f0;--ok:#16a34a;--warn:#d97706;--bad:#dc2626;--r:12px;--sh:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04)}
html{font-size:15px}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh}
a{color:var(--p);text-decoration:none}a:hover{text-decoration:underline}
.layout{display:flex;min-height:100vh}
/* ─ Sidebar ─ */
.side{width:232px;background:var(--pd);color:#e9edf4;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0}
.side .brand{padding:18px 16px 12px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.09)}
.side .brand img{max-height:38px;max-width:130px}
.side .brand .bname{font-weight:700;font-size:.95rem;line-height:1.2}
.side nav{flex:1;overflow-y:auto;padding:10px 8px}
.side .sec{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);padding:14px 10px 4px}
.side nav a{display:flex;align-items:center;gap:9px;color:#dbe3ee;padding:8px 10px;border-radius:8px;font-size:.9rem;margin:1px 0}
.side nav a:hover{background:rgba(255,255,255,.08);text-decoration:none}
.side nav a.on{background:var(--p);color:#fff;font-weight:600}
.side nav a .ic{width:19px;text-align:center;opacity:.9}
.side .foot{padding:10px;border-top:1px solid rgba(255,255,255,.09);font-size:.8rem}
.side .foot a{color:#c4cede}
.badge-n{background:var(--a);color:#fff;font-size:.68rem;border-radius:9px;padding:1px 7px;margin-left:auto;font-weight:700}
/* ─ Main ─ */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:var(--card);border-bottom:1px solid var(--line);padding:10px 22px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:40}
.topbar h1{font-size:1.12rem;font-weight:700}
.topbar .grow{flex:1}
.searchbox{position:relative}
.searchbox input{width:230px;padding:7px 12px 7px 32px;border:1px solid var(--line);border-radius:20px;background:var(--bg);font-size:.85rem}
.searchbox:before{content:'🔍';position:absolute;left:10px;top:6px;font-size:.8rem;opacity:.5}
.tswitch{padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--card);font-weight:600;font-size:.85rem;cursor:pointer}
.content{padding:22px;max-width:1420px;width:100%;margin:0 auto}
/* ─ Composants ─ */
.grid{display:grid;gap:16px}.g2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.g3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.g4{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:18px}
.card h2{font-size:.98rem;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card h2 .grow{flex:1}
.kpi .lbl{color:var(--mut);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:1.65rem;font-weight:800;margin-top:2px}
.kpi .sub{color:var(--mut);font-size:.8rem;margin-top:2px}
table.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{text-align:left;color:var(--mut);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:8px 10px;border-bottom:2px solid var(--line)}
.tbl td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:hover td{background:#f8fafc}
.tbl .right,th.right,td.right{text-align:right}
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.72rem;font-weight:700}
.b-gray{background:#eef1f6;color:#475569}.b-blue{background:#dbeafe;color:#1d4ed8}
.b-green{background:#dcfce7;color:#15803d}.b-amber{background:#fef3c7;color:#b45309}
.b-red{background:#fee2e2;color:#b91c1c}.b-purple{background:#ede9fe;color:#6d28d9}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--p);color:#fff;border:none;padding:8px 15px;border-radius:8px;font-size:.86rem;font-weight:600;cursor:pointer;text-decoration:none!important}
.btn:hover{filter:brightness(1.08)}
.btn.sec{background:var(--card);color:var(--txt);border:1px solid var(--line)}
.btn.ghost{background:transparent;color:var(--p);border:1px dashed var(--p)}
.btn.danger{background:var(--bad)}.btn.ok{background:var(--ok)}
.btn.sm{padding:4px 10px;font-size:.78rem}
.btn.big{padding:12px 26px;font-size:1rem}
/* forms */
label.f{display:block;margin-bottom:11px;font-size:.85rem}
label.f span{display:block;font-weight:600;margin-bottom:4px;color:#334155}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{
width:100%;padding:8px 11px;border:1px solid #cbd5e1;border-radius:8px;font-size:.88rem;font-family:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid color-mix(in srgb,var(--p) 30%,transparent);border-color:var(--p)}
textarea{min-height:90px;resize:vertical}
.frow{display:flex;gap:12px}.frow>*{flex:1}
.chk{display:flex;align-items:center;gap:8px;font-size:.86rem;margin-bottom:10px}
.chk input{width:17px;height:17px}
.help{font-size:.78rem;color:var(--mut);margin-top:3px}
/* kanban */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px}
.kcol{background:#eceff5;border-radius:var(--r);min-width:240px;width:240px;flex-shrink:0;padding:10px}
.kcol h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mut);padding:2px 6px 8px;display:flex}
.kcol h3 .cnt{margin-left:auto;background:#fff;border-radius:10px;padding:0 8px;font-size:.72rem}
.kcard{background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 11px;margin-bottom:8px;cursor:grab;box-shadow:var(--sh);font-size:.85rem}
.kcard .t{font-weight:600;margin-bottom:3px}
.kcard .m{color:var(--mut);font-size:.76rem}
.kcol.over{outline:2px dashed var(--p);outline-offset:-4px}
/* modal */
.modal{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:100;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.modal.open{display:flex}
.mbox{background:#fff;border-radius:14px;max-width:640px;width:100%;padding:22px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.mbox h2{margin-bottom:14px}
.mbox .mfoot{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
/* toast */
.toast{position:fixed;bottom:22px;right:22px;background:#0f172a;color:#fff;padding:13px 20px;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.3);z-index:200;font-size:.9rem;animation:pop .25s}
@keyframes pop{from{transform:translateY(14px);opacity:0}}
/* misc */
.muted{color:var(--mut)}.small{font-size:.8rem}.mt{margin-top:14px}.mb{margin-bottom:14px}
.flex{display:flex;align-items:center;gap:10px}.grow{flex:1}.wrap{flex-wrap:wrap}
.right-al{text-align:right}
.empty{color:var(--mut);text-align:center;padding:34px 10px;font-size:.9rem}
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--line);margin-bottom:16px;flex-wrap:wrap}
.tabs a{padding:9px 15px;font-weight:600;font-size:.87rem;color:var(--mut);border-radius:8px 8px 0 0;border-bottom:2px solid transparent;margin-bottom:-2px}
.tabs a.on{color:var(--p);border-color:var(--p)}
.tabs a:hover{text-decoration:none;background:#f8fafc}
.agenda{width:100%;border-collapse:collapse;table-layout:fixed}
.agenda th{padding:6px;color:var(--mut);font-size:.72rem;text-transform:uppercase}
.agenda td{border:1px solid var(--line);vertical-align:top;height:96px;padding:5px;font-size:.76rem;background:#fff}
.agenda td.off{background:#f6f8fb}
.agenda .dn{font-weight:700;color:var(--mut);margin-bottom:3px}
.agenda td.today .dn{color:var(--p)}
.agenda .ev{display:block;background:var(--p);color:#fff;border-radius:5px;padding:2px 6px;margin-bottom:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.stars label{font-size:1.9rem;cursor:pointer;color:#cbd5e1}
.stars input{display:none}
.tuto{background:#eef6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 14px;font-size:.83rem;margin:10px 0}
.tuto b{color:#1d4ed8}
.tuto ol{margin:6px 0 0 18px}
.sig-pad{border:2px dashed var(--line);border-radius:10px;padding:18px;text-align:center;background:#fafbfd}
.pubwrap{max-width:860px;margin:0 auto;padding:24px 14px}
.pubcard{background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(15,23,42,.12);padding:30px}
.pubhead{padding:26px 30px;border-radius:16px 16px 0 0;color:#fff}
.doc-body h2{font-size:1.02rem;margin:18px 0 8px;padding-bottom:4px;border-bottom:2px solid var(--line)}
.doc-body table{width:100%;border-collapse:collapse;margin:8px 0;font-size:.88rem}
.doc-body th{background:var(--pd);color:#fff;padding:7px;text-align:left;font-size:.78rem}
.doc-body td{padding:7px;border-bottom:1px solid var(--line)}
.doc-body .right{text-align:right}
.doc-body .muted{color:var(--mut);font-size:.8rem}
.doc-body .badge{background:var(--p);color:#fff;padding:2px 8px;border-radius:6px;font-size:.75rem}
.doc-body .total-line{font-weight:800;font-size:1.02rem}
@media(max-width:900px){.side{position:fixed;left:-240px;transition:left .2s;z-index:90}.side.open{left:0}
.burger{display:block!important}.content{padding:14px}.searchbox input{width:130px}}
.burger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer}
@media print{.side,.topbar,.noprint{display:none!important}.content{padding:0}}
