:root{
  --bg:#0f1720; --panel:#16212e; --panel2:#1d2b3a; --line:#2a3b4d;
  --ink:#e7eef6; --muted:#93a7bd; --brand:#2ea3ff; --brand2:#1b7fd1;
  --good:#37c98b; --warn:#f5b74e; --bad:#ff6b6b; --chip:#243546;
  --radius:12px; --shadow:0 6px 24px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,#0c141d,#0f1720 240px);color:var(--ink);}
a{color:var(--brand)}
header.top{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(12,20,29,.9);backdrop-filter:blur(8px);z-index:10}
.logo{font-weight:800;letter-spacing:.3px;font-size:18px}
.logo b{color:var(--brand)}
.tag{color:var(--muted);font-size:12.5px;margin-left:2px}
.spacer{flex:1}
.langtoggle{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.langtoggle button{background:transparent;color:var(--muted);border:0;padding:6px 12px;cursor:pointer;font-weight:600}
.langtoggle button.active{background:var(--brand);color:#00121f}
.wrap{max-width:1080px;margin:22px auto;padding:0 18px;display:grid;grid-template-columns:1.15fr .85fr;gap:20px}
@media(max-width:900px){.wrap{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card h2{margin:0;padding:14px 16px;border-bottom:1px solid var(--line);font-size:15px;letter-spacing:.2px}
.card .body{padding:16px}
.section-title{display:flex;align-items:center;gap:8px;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:18px 0 8px}
.section-title:first-child{margin-top:0}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid.three{grid-template-columns:1fr 1fr 1fr}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1/-1}
label{font-size:12.5px;color:var(--muted);font-weight:600}
label .req{color:var(--brand)}
input,select,textarea{background:var(--panel2);border:1px solid var(--line);border-radius:9px;color:var(--ink);
  padding:9px 10px;font:inherit;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 2px rgba(46,163,255,.15)}
textarea{resize:vertical;min-height:64px}
.hint{font-size:11.5px;color:var(--muted)}
.row-inline{display:flex;gap:8px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:6px;background:var(--chip);border:1px solid var(--line);
  border-radius:999px;padding:4px 10px;font-size:12px;color:var(--muted)}
.cat-badge{font-size:11.5px;color:var(--good);font-weight:600;min-height:16px}
.seg{display:flex;gap:6px}
.seg button{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:9px;
  padding:9px;cursor:pointer;font-weight:600}
.seg button.on{background:var(--brand);border-color:var(--brand);color:#00121f}
.seg.small button{padding:6px}
.switch{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);
  border-radius:10px;padding:10px 12px;cursor:pointer}
.switch .knob{width:38px;height:22px;border-radius:999px;background:#33475b;position:relative;transition:.15s}
.switch .knob::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.15s}
.switch.on .knob{background:var(--brand)}
.switch.on .knob::after{left:18px}
.switch .txt{flex:1}
.switch .txt small{display:block;color:var(--muted);font-weight:400;margin-top:2px}
.photos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.photo-slot{border:1.5px dashed var(--line);border-radius:11px;padding:12px;text-align:center;cursor:pointer;
  background:var(--panel2);transition:.15s;position:relative;min-height:120px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:6px}
.photo-slot:hover{border-color:var(--brand)}
.photo-slot.filled{border-style:solid;border-color:var(--good);padding:0;overflow:hidden}
.photo-slot img{width:100%;height:130px;object-fit:cover;display:block}
.photo-slot .ico{font-size:26px}
.photo-slot .lbl{font-size:12.5px;font-weight:600}
.photo-slot .sub{font-size:11px;color:var(--muted)}
.actions{display:flex;gap:10px;margin-top:18px;align-items:center}
.btn{border:0;border-radius:10px;padding:11px 16px;font-weight:700;cursor:pointer;font-size:14px}
.btn.primary{background:var(--brand);color:#00121f}
.btn.primary:hover{background:var(--brand2);color:#fff}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.msg{margin-left:auto;font-size:13px}
.msg.ok{color:var(--good)} .msg.err{color:var(--bad)}
.inv-item{display:flex;gap:10px;padding:10px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:var(--panel2)}
.inv-item .thumb{width:52px;height:52px;border-radius:8px;background:var(--chip);flex-shrink:0;object-fit:cover;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:20px}
.inv-item .meta{flex:1;min-width:0}
.inv-item .meta .t{font-weight:700;font-size:14px}
.inv-item .meta .s{color:var(--muted);font-size:12px}
.inv-item .price{font-weight:800;color:var(--good);white-space:nowrap}
.badge{font-size:10.5px;padding:2px 7px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.badge.b-real{color:var(--good);border-color:var(--good)}
.badge.b-draft{color:var(--warn);border-color:var(--warn)}
.empty{color:var(--muted);text-align:center;padding:22px;font-size:13px}
.donor-lock{background:linear-gradient(90deg,rgba(46,163,255,.12),transparent);border:1px solid var(--brand);
  border-radius:10px;padding:10px 12px;display:none;align-items:center;gap:10px;margin-bottom:12px}
.donor-lock.show{display:flex}
.donor-lock .v{font-weight:700}
.donor-lock button{margin-left:auto}
.counter{font-size:12px;color:var(--muted)}
datalist{max-height:220px}
/* Typeahead maison (remplace le datalist natif, peu fiable selon navigateur) */
.ta-wrap{position:relative}
.ta-menu{position:absolute;top:calc(100% + 3px);left:0;right:0;z-index:60;background:var(--panel2);
  border:1px solid var(--brand);border-radius:10px;max-height:260px;overflow-y:auto;
  box-shadow:var(--shadow);display:none}
.ta-menu.show{display:block}
.ta-item{padding:8px 11px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-size:14px;border-bottom:1px solid rgba(255,255,255,.04)}
.ta-item:last-child{border-bottom:0}
.ta-item .ta-lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ta-item small{color:var(--muted);font-size:11px;white-space:nowrap;flex-shrink:0}
.ta-item.active,.ta-item:hover{background:var(--brand);color:#00121f}
.ta-item.active small,.ta-item:hover small{color:#003049}
.ta-empty{padding:10px 11px;color:var(--muted);font-size:12.5px}
mark{background:transparent;color:inherit;font-weight:800;text-decoration:underline}

/* ---- Auth / top-bar ---- */
.authbar{display:flex;align-items:center;gap:14px;font-size:13.5px}
.authbar a{color:var(--muted);text-decoration:none;font-weight:600}
.authbar a:hover{color:var(--ink)}
.authbar .who{color:var(--ink);font-weight:700;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn.sm{padding:6px 10px;font-size:12.5px}
.btn.full{width:100%;margin-top:6px}
.auth-wrap{max-width:560px;margin:34px auto;padding:0 18px}
.auth-card .tabs{display:flex;border-bottom:1px solid var(--line)}
.auth-card .tab{flex:1;background:transparent;border:0;color:var(--muted);padding:14px;font-weight:700;cursor:pointer;font-size:14px}
.auth-card .tab.active{color:var(--ink);box-shadow:inset 0 -2px 0 var(--brand)}
.pane .field{margin-bottom:12px}
.wrap-single{max-width:920px;margin:22px auto;padding:0 18px;display:flex;flex-direction:column;gap:18px}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat-val{font-size:26px;font-weight:800;letter-spacing:.3px}
.stat-val.good{color:var(--good)} .stat-val.warn{color:var(--warn)} .stat-val.bad{color:var(--bad)}
.stat-lbl{color:var(--muted);font-size:12.5px;margin-top:4px}
.pending-banner{background:rgba(245,183,78,.12);border:1px solid var(--warn);color:#f5d79a;border-radius:10px;padding:12px 14px;font-size:13.5px;margin-bottom:6px}
.garage-static{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 10px;font-weight:700}
.tablewrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th,.tbl td{text-align:left;padding:10px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl th{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em}
.tbl td.num,.tbl th.num{text-align:right;white-space:nowrap}
.tbl .sub{color:var(--muted);font-size:11.5px;margin-top:2px}
.tbl .acts{display:flex;gap:6px;flex-wrap:wrap}
.badge.b-bad{color:var(--bad);border-color:var(--bad)}
.inv-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}

/* ---- Dashboard ---- */
.wrap-dash{width:80%;margin:22px auto;padding:0 4px;display:flex;flex-direction:column;gap:18px}
@media(max-width:840px){.wrap-dash{width:94%}}
a.logo{text-decoration:none;color:var(--ink)}
.dash-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-head h1{font-size:20px;margin:2px 0}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:840px){.dash-grid{grid-template-columns:1fr}}
.lead-kpi.pulse{border-color:var(--warn);box-shadow:0 0 0 1px var(--warn),var(--shadow)}
.sub-h{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:14px 0 8px;font-weight:700}
.sub-h:first-child{margin-top:0}
.todo-chips{display:flex;gap:10px;flex-wrap:wrap}
.chip-lg{flex:1;min-width:140px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px;
  text-decoration:none;color:var(--muted);font-size:12.5px}
.chip-lg .n{display:block;font-size:22px;font-weight:800;color:var(--ink)}
.chip-lg:hover{border-color:var(--brand)}
.lead-item{display:flex;gap:10px;align-items:flex-start;padding:10px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:var(--panel2)}
.lead-main{flex:1;min-width:0}
.lead-top{font-size:13.5px}
.lead-part{font-size:13px;color:var(--ink);margin-top:2px}
.lead-msg{font-size:12.5px;color:var(--muted);font-style:italic;margin-top:3px}
.sub{color:var(--muted);font-size:11.5px}
.chart-title{font-size:12px;color:var(--muted);font-weight:600;margin:12px 0 6px}
.chart-title:first-child{margin-top:0}
.chart-box{position:relative;height:200px}
.chart-box.sm{height:130px}
.mini-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:7px 2px;border-bottom:1px solid rgba(255,255,255,.05);font-size:13.5px}
.mini-row:last-child{border-bottom:0}
.mini-r{white-space:nowrap;font-weight:600}
.mini-r.good{color:var(--good)}

/* ---- Inventaire ---- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.filters input{flex:1;min-width:200px}
.filters select{max-width:170px}
.tthumb{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--chip);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px}
.row-status{padding:5px 8px;font-size:12.5px}
.btn.danger{color:var(--bad);border-color:transparent}
.btn.danger:hover{border-color:var(--bad)}
.tbl td .acts{display:flex;gap:6px;white-space:nowrap}
/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(4,10,16,.7);display:flex;align-items:flex-start;justify-content:center;z-index:200;overflow-y:auto;padding:30px 16px}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);width:100%;max-width:720px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:16px}
.modal .close{background:transparent;border:0;color:var(--muted);font-size:26px;line-height:1;cursor:pointer}
.modal .close:hover{color:var(--ink)}
.modal-body{padding:18px}
.photo-strip{display:flex;gap:10px;flex-wrap:wrap}
.photo-strip .ph{position:relative;width:88px;height:88px;border-radius:9px;overflow:hidden;border:1px solid var(--line)}
.photo-strip .ph img{width:100%;height:100%;object-fit:cover;display:block}
.photo-strip .phdel{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:50%;border:0;background:rgba(0,0,0,.65);color:#fff;cursor:pointer;font-size:15px;line-height:1}
.photo-strip .phdel:hover{background:var(--bad)}

