:root{
  --ink:#1c1c1c;--taupe:#d0ccc7;--slate:#535366;--white:#fff;
  --slate-08:rgba(83,83,102,.08);--slate-14:rgba(83,83,102,.14);
  --taupe-soft:#efedea;--line:#e6e4df;--paper:#fff;--muted:#807b82;
  --ok:#3f6b4e;--ok-soft:#eaf0eb;--warn:#9a6a14;--warn-soft:#f3ecd9;--danger:#b23b3b;
  --serif:"Tenor Sans",Georgia,serif;--sans:"Jost",-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --r:3px;--shadow:0 1px 2px rgba(28,28,28,.04),0 12px 30px rgba(28,28,28,.06);
}
*{box-sizing:border-box}html,body{margin:0}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.topbar{position:sticky;top:0;z-index:15;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;gap:18px;height:66px}
.brand{font-family:var(--serif);font-size:18px;color:var(--ink);text-decoration:none;letter-spacing:.4px}
.nav{display:flex;gap:4px;margin-left:14px;flex-wrap:wrap}
.nav a{color:var(--muted);text-decoration:none;font-size:12px;text-transform:uppercase;letter-spacing:.12em;padding:8px 11px;border-radius:var(--r)}
.nav a:hover{color:var(--ink)}.nav a.here{color:var(--ink);box-shadow:inset 0 -2px 0 var(--ink)}
.top-right{margin-left:auto}
.btn{font-family:var(--sans);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--ink);background:var(--white);color:var(--ink);padding:10px 16px;border-radius:2px;cursor:pointer;text-decoration:none;display:inline-block}
.btn:hover{background:#faf9f8}.btn-ink{background:var(--ink);color:#fff}.btn-ink:hover{background:#000}
.page{padding:32px 0 4px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ey{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);font-weight:500}
.page h1{font-family:var(--serif);font-weight:400;font-size:32px;margin:11px 0 6px;letter-spacing:.4px}
.page h1 .ac{color:var(--slate)}
.page p{color:var(--muted);margin:0;max-width:64ch}
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:20px 0 14px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.seg button{font-family:var(--sans);font-size:12px;border:0;background:var(--white);color:var(--muted);padding:8px 13px;cursor:pointer}
.seg button.on{background:var(--ink);color:#fff}
.search{flex:1;min-width:230px;display:flex;align-items:center;border:1px solid var(--line);border-radius:2px;padding:9px 12px;background:var(--white)}
.search input{border:0;outline:0;width:100%;font-family:var(--sans);font-size:14px;background:transparent}
.tablewrap{border:1px solid var(--line);border-radius:var(--r);background:var(--white);box-shadow:var(--shadow);overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:680px}
th{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
th.right,td.right{text-align:right}
td{padding:11px 14px;border-bottom:1px solid #f1efec;font-size:14px;vertical-align:middle}
tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:#faf9f8}
.lbl{font-weight:500}.mono{font-family:ui-monospace,Menlo,monospace}.small{font-size:12px}.num{font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}.empty{text-align:center;color:var(--muted);padding:22px}
.b{font-size:10px;text-transform:uppercase;letter-spacing:.05em;border-radius:2px;padding:3px 8px;border:1px solid var(--line);background:var(--taupe-soft);color:var(--muted)}
.b.laser{background:var(--slate-08);border-color:var(--slate-14);color:var(--slate)}
.b.accessoire{background:#fff;border-style:dashed}
.pill{font-size:10px;text-transform:uppercase;letter-spacing:.05em;border-radius:2px;padding:2px 7px}
.pill.ok{background:var(--ok-soft);color:var(--ok)}.pill.warn{background:var(--warn-soft);color:var(--warn)}.pill.out{background:#fbecec;color:var(--danger)}
code{font-family:ui-monospace,Menlo,monospace;font-size:.85em;background:var(--taupe-soft);padding:1px 5px;border-radius:2px}

/* ===== gestion (bilan / ventes / marchés / catalogue / équipe) ===== */
.flash{margin:14px 0 0;padding:11px 14px;border-radius:var(--r);font-size:13.5px;border:1px solid}
.flash.ok{background:var(--ok-soft);color:var(--ok);border-color:#d8e5db}
.flash.err{background:#fbecec;color:var(--danger);border-color:#f0d4d4}

.login-body{background:var(--taupe-soft);display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:34px;width:min(420px,92vw)}

.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted);flex:1;min-width:150px}
.fld input,.fld select,.inp{font-family:var(--sans);font-size:14px;color:var(--ink);border:1px solid var(--line);border-radius:2px;padding:9px 11px;background:var(--white);width:100%}
.fld input:focus,.fld select:focus,.inp:focus{outline:0;border-color:var(--slate)}
.fld input[type=color]{padding:2px;height:39px;width:64px}
.frow{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin:8px 0}
.lnk{border:0;background:none;font-family:var(--sans);font-size:12.5px;color:var(--slate);cursor:pointer;text-decoration:underline;padding:6px}
.lnk.danger{color:var(--danger)}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:8px 0 20px}
.kpi{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px}
.kpi-l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.kpi-v{font-family:var(--serif);font-size:27px;margin-top:6px}

.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:16px}
.statcard{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.statcard h3{font-family:var(--serif);font-weight:400;font-size:17px;margin:0;padding:13px 16px;border-bottom:1px solid var(--line)}
table.stat{min-width:0}
table.stat td{padding:9px 14px}
.barcell{width:32%;min-width:80px}
.bar{display:block;height:7px;background:var(--slate);opacity:.35;border-radius:2px;min-width:2px}
tr.annulee td{opacity:.45;text-decoration:line-through}
tr.annulee td:last-child{text-decoration:none}

.chips{display:flex;flex-wrap:wrap;gap:8px;padding:13px 16px}
.chip summary{display:flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:2px;padding:6px 11px;cursor:pointer;font-size:13px;background:var(--white);list-style:none}
.chip summary::-webkit-details-marker{display:none}
.chip[open] summary{background:var(--taupe-soft)}
.chipform{display:flex;gap:8px;align-items:center;padding:9px;border:1px solid var(--line);border-top:0;background:#faf9f8}
.chipform input[type=text]{width:130px;border:1px solid var(--line);border-radius:2px;padding:7px 9px;font-family:var(--sans)}
.dot{display:inline-block;width:13px;height:13px;border-radius:50%;border:1px solid rgba(0,0,0,.15);flex:none}

.csgrid{display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 10px}
.csbox{display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:2px;padding:5px 9px;font-size:12.5px;cursor:pointer;background:var(--white)}
.csbox:has(input:checked){background:var(--slate-08);border-color:var(--slate-14)}

details.acc summary{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;list-style:none;flex-wrap:wrap}
details.acc summary::-webkit-details-marker{display:none}
details.acc summary::before{content:"›";color:var(--muted);transition:transform .15s;font-size:15px}
details.acc[open] > summary::before{transform:rotate(90deg)}
details.acc.inner{border-top:1px solid var(--line)}
details.acc.modele{border-top:1px solid #f1efec;margin-left:8px}
.accbody{padding:6px 16px 16px}
.accfoot{padding:12px 16px;border-top:1px solid var(--line);display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.sflabel{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);padding:10px 16px 2px;font-weight:500}
.frow.classique{padding:4px 0;border-bottom:1px solid #f1efec}
.frow.classique:last-child{border-bottom:0}
