/* ─── components.css ──────────────────────────────────────────────────────────
   Tableaux, modals, formulaires, badges, KPIs, barres, recherche
   ──────────────────────────────────────────────────────────────────────────── */

.sidebar{width:230px;min-height:100vh;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;transition:width .25s ease}

.nav-badge{margin-left:auto;background:var(--red-dim);color:var(--red);font-family:var(--font-m);font-size:10px;padding:2px 7px;border-radius:100px}

.theme-toggle{background:var(--theme-toggle-bg);border:1px solid var(--border2);border-radius:20px;padding:5px 10px;cursor:pointer;display:flex;align-items:center;gap:6px;font-family:var(--font-m);font-size:11px;color:var(--text2);transition:all .2s;user-select:none}

.theme-toggle:hover{border-color:var(--border3);color:var(--text)}

.theme-toggle .toggle-icon{font-size:14px;transition:transform .3s}

body.light .theme-toggle .toggle-icon{transform:rotate(180deg)}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}

.kpi{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}

.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}

.kpi.green::before{background:var(--accent)}

.kpi.red::before{background:var(--red)}

.kpi.amber::before{background:var(--amber)}

.kpi.blue::before{background:var(--blue)}

.kpi-lbl{font-size:10px;font-family:var(--font-m);color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}

.kpi-val{font-family:var(--font-h);font-size:26px;font-weight:700;line-height:1}

.kpi-val.green{color:var(--accent)}

.kpi-val.red{color:var(--red)}

.kpi-val.amber{color:var(--amber)}

.kpi-val.blue{color:var(--blue)}

.kpi-sub{font-size:11px;color:var(--text3);margin-top:4px}

.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap;position:sticky;top:56px;z-index:9;background:var(--bg);padding:8px 0}

.search-wrap{position:relative;flex:1;min-width:180px}

.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:14px;pointer-events:none}

.s-input{width:100%;background:var(--bg2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px 8px 32px;font-family:var(--font-b);font-size:12px;outline:none;transition:border .15s}

.s-input:focus{border-color:var(--border2)}

.s-input::placeholder{color:var(--text3)}

.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:auto;max-height:calc(100vh - 180px)}

table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px}

thead th{padding:10px 12px;text-align:left;font-size:10px;font-family:var(--font-m);color:var(--text2);text-transform:uppercase;letter-spacing:1px;background:var(--bg3);border-bottom:1px solid var(--border);font-weight:500;cursor:pointer;white-space:nowrap;user-select:none}

thead th:hover{color:var(--text2)}

tbody tr{border-bottom:1px solid var(--border);transition:background .1s}

tbody tr:last-child td{border-bottom:none}

tbody tr:hover td{background:var(--bg3)}

tbody td{padding:11px 12px;font-size:12px;color:var(--text);vertical-align:middle;white-space:nowrap;border-bottom:1px solid var(--border);background:var(--bg2)}

.td-ref{font-family:var(--font-m);font-size:11px;color:var(--text2)}

.td-mono{font-family:var(--font-m)}

.td-name{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis}

.td-actions{display:flex;gap:2px}

.col-sticky{position:sticky;left:0;z-index:1;background:var(--bg2)}

.col-sticky-head{position:sticky;left:0;z-index:2;background:var(--bg3)}

tbody tr:hover .col-sticky{background:var(--bg3)}

.td-actions{position:relative;z-index:3}

.col-sticky::after,.col-sticky-head::after{content:'';position:absolute;right:-1px;top:0;bottom:0;width:1px;background:var(--border2)}

.badge{display:inline-block;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:500;font-family:var(--font-m)}

.b-ok{background:var(--accent-dim);color:var(--accent)}

.b-low{background:var(--amber-dim);color:var(--amber)}

.b-out{background:var(--red-dim);color:var(--red)}

.b-cat{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}

.mini-bar{display:flex;align-items:center;gap:6px}

.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:100;align-items:center;justify-content:center}

.modal-ov.open{display:flex}

.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;width:680px;max-width:96vw;max-height:92vh;overflow-y:auto}

.modal-hdr{padding:22px 26px 0;display:flex;align-items:center;justify-content:space-between}

.modal-hdr h2{font-family:var(--font-h);font-size:17px;font-weight:700}

.modal-x{background:none;border:none;color:var(--text3);cursor:pointer;font-size:18px;padding:4px;border-radius:6px;transition:all .15s}

.modal-x:hover{background:var(--bg3);color:var(--text)}

.modal-body{padding:20px 26px}

.modal-sec{font-size:10px;font-family:var(--font-m);color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.fgrid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

.fg{display:flex;flex-direction:column;gap:6px}

.fg.full{grid-column:1/-1}

.flbl{font-size:10px;font-family:var(--font-m);color:var(--text3);text-transform:uppercase;letter-spacing:1px}

.finput,.fsel,.ftxt{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 11px;font-family:var(--font-b);font-size:12px;outline:none;transition:border .15s;width:100%}

.finput:focus,.fsel:focus,.ftxt:focus{border-color:var(--accent)}

.finput::placeholder{color:var(--text3)}

.ftxt{resize:vertical;min-height:60px}

.modal-ftr{padding:0 26px 22px;display:flex;gap:8px;justify-content:flex-end}

.url-config{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 18px;margin:0 0 16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.url-lbl{font-size:11px;font-family:var(--font-m);color:var(--text3);white-space:nowrap}

.url-input{flex:1;min-width:200px;background:var(--bg2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 11px;font-family:var(--font-m);font-size:12px;outline:none}

.url-input:focus{border-color:var(--accent)}

.url-tabs{display:flex;gap:6px}

.url-tab{padding:5px 12px;border-radius:6px;font-size:11px;font-family:var(--font-m);cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text2);transition:all .15s}

.url-tab.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}

.sel-all-row{display:flex;align-items:center;gap:8px;padding:0 0 8px}

.sel-all-row label{font-size:12px;color:var(--text2);cursor:pointer}

.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:500;font-family:var(--font-m)}

.pi-lbl{font-size:10px;font-family:var(--font-m);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}

.pi-val{font-size:13px;font-weight:500;word-break:break-all}

.pi-val a{color:var(--blue);text-decoration:none}

.pi-val a:hover{text-decoration:underline}

.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-top:8px}

.photo-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;border:1px solid var(--border);cursor:pointer}

.photo-thumb:hover{border-color:var(--accent)}

.photo-add{width:100%;aspect-ratio:1;border:1px dashed var(--border2);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text3);font-size:24px;transition:all .15s}

.photo-add:hover{border-color:var(--accent);color:var(--accent)}

.status-selector{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}

.status-opt{padding:6px 13px;border-radius:20px;font-size:12px;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--text2);transition:all .15s;font-family:var(--font-b)}

.status-opt:hover{background:var(--bg3)}

.status-opt.selected{font-weight:600}

.status-opt[data-s=todo].selected{background:var(--bg3);color:var(--text);border-color:var(--border3)}

.status-opt[data-s=inprogress].selected{background:var(--blue-dim);color:var(--blue);border-color:var(--blue)}

.status-opt[data-s=shipped].selected{background:var(--purple-dim);color:var(--purple);border-color:var(--purple)}

.status-opt[data-s=received].selected{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}

.status-opt[data-s=issue].selected{background:var(--red-dim);color:var(--red);border-color:var(--red)}

.status-opt[data-s=cancelled].selected{background:var(--bg3);color:var(--text3);border-color:var(--text3)}

.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:300;align-items:center;justify-content:center;cursor:zoom-out}

.lightbox.open{display:flex}

.lightbox img{max-width:90vw;max-height:90vh;border-radius:10px}

.toast-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}


@media (max-width: 768px) {
  .main { width: 100%; }
  .kpi-grid { grid-template-columns: repeat(2,1fr) !important; gap: 8px; }
  .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { min-width: 600px; }
  .toolbar { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; }
  .fgrid, .fgrid-3 { grid-template-columns: 1fr !important; }
  .fg.full { grid-column: 1 !important; }
}

::-webkit-scrollbar { width: 5px; height: 5px; }