.table-wrap{background:var(--white);border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);}
.table-head{display:grid;background:var(--surface-2);padding:10px 16px;font-size:11px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:var(--muted);border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:1.5px solid var(--border);}
.table-row{display:grid;padding:11px 16px;border-bottom:1px solid var(--border);align-items:center;font-size:13px;transition:background 0.1s;}
.table-row:nth-child(even){background:var(--surface);}
.table-row:last-child{border-bottom:none;}
.table-row:hover{background:var(--navy-light) !important;}
.empty-state{padding:3rem;text-align:center;color:var(--muted);font-size:13px;}
.empty-state-icon{font-size:32px;margin-bottom:0.75rem;opacity:0.4;}
.empty-state-title{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.empty-state-desc{font-size:12px;color:var(--muted);line-height:1.6;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:0.2px;white-space:nowrap;}
.badge-pending{background:#fff3cd;color:#7d5a00;border:1px solid #f0d878;}
.badge-done{background:var(--green-light);color:#1a6b1a;border:1px solid #b3d9b3;}
.badge-low{background:var(--amber-light);color:#7a4400;border:1px solid #f0c070;}
.badge-empty{background:var(--red-light);color:#7a0000;border:1px solid #ffb3a3;}
.badge-info{background:#e8f0ff;color:#1a3a7a;border:1px solid #b3c8f0;}
.badge-neutral{background:var(--surface-2);color:var(--muted);border:1px solid var(--border);}
.badge-ok{background:var(--green-light);color:#1a6b1a;border:1px solid #b3d9b3;}
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--navy-700);color:white;border:none;border-radius:var(--radius-sm);font-family:'Barlow Condensed','Montserrat',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:background 0.15s,box-shadow 0.15s,transform 0.1s;letter-spacing:0.3px;touch-action:manipulation;}
.btn-primary:hover{background:var(--navy-800);box-shadow:0 4px 14px rgba(0,51,102,0.32);}
.btn-primary:active{transform:scale(0.97);}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:white;color:var(--muted);font-size:12px;font-family:'Montserrat',sans-serif;font-weight:600;cursor:pointer;transition:all 0.15s;touch-action:manipulation;}
.btn-outline:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-light);}
.btn-green{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:7px;border:1.5px solid var(--green);background:none;color:var(--green);font-size:11px;font-weight:700;font-family:'Montserrat',sans-serif;cursor:pointer;white-space:nowrap;transition:all 0.15s;touch-action:manipulation;}
.btn-green:hover{background:var(--green);color:white;}
.btn-green.done{border-color:var(--border);color:var(--muted);cursor:default;}
.btn-green.done:hover{background:none;color:var(--muted);}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:7px;border:1.5px solid var(--border);background:none;color:var(--muted);font-size:12px;cursor:pointer;transition:all 0.15s;touch-action:manipulation;}
.btn-icon:hover{border-color:var(--blue);color:var(--blue);background:var(--navy-light);}
.btn-del{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:7px;border:1.5px solid rgba(204,34,0,0.35);background:none;color:var(--red);font-size:12px;cursor:pointer;transition:all 0.15s;touch-action:manipulation;}
.btn-del:hover{background:var(--red-light);border-color:var(--red);}
.filters{display:flex;gap:8px;margin-bottom:1rem;flex-wrap:wrap;align-items:center;}
.filter-input{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:'Open Sans',sans-serif;outline:none;background:white;color:var(--text);transition:border-color 0.15s,box-shadow 0.15s;}
.filter-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,85,179,0.1);}
.filter-btn{padding:7px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:white;color:var(--muted);font-size:12px;font-family:'Montserrat',sans-serif;font-weight:600;cursor:pointer;transition:all 0.15s;touch-action:manipulation;}
.filter-btn.active{background:var(--navy);color:white;border-color:var(--navy);}
/* Toggle group (garage / view switches) */
.toggle-group{display:inline-flex;border-radius:var(--radius-sm);border:1.5px solid var(--border);overflow:hidden;background:white;}
.toggle-btn{padding:7px 14px;border:none;background:none;color:var(--muted);font-size:12px;font-family:'Montserrat',sans-serif;font-weight:600;cursor:pointer;transition:background 0.15s,color 0.15s;border-right:1px solid var(--border);}
.toggle-btn:last-child{border-right:none;}
.toggle-btn.active{background:var(--navy);color:white;}
.toggle-btn:hover:not(.active){background:var(--surface-2);color:var(--navy);}
.form-hero{background:var(--navy);padding:3rem 2rem 4rem;text-align:center;border-bottom:4px solid var(--green);}
.form-hero h1{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:800;color:white;margin-bottom:6px;}
.form-hero p{font-size:14px;color:rgba(255,255,255,0.65);}
.form-card{max-width:600px;margin:-2rem auto 3rem;background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2rem;}
.form-grid{display:grid;gap:14px;margin-bottom:18px;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.7px;color:var(--muted);}
.field input,.field select,.field textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;font-size:14px;font-family:'Open Sans',sans-serif;color:var(--text);background:white;outline:none;transition:border-color 0.15s,box-shadow 0.15s;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,204,0.1);}
.field textarea{resize:none;min-height:80px;}
.divider{border:none;border-top:1px solid var(--border);margin:18px 0;}
.mats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:12px;}
.mat-item{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 11px;display:flex;align-items:center;gap:7px;cursor:pointer;transition:all 0.15s;font-size:12.5px;color:var(--text);user-select:none;touch-action:manipulation;}
.mat-item:hover{border-color:var(--blue);background:#f0f6ff;}
.mat-item.selected{border-color:var(--navy);background:#e8f0fa;color:var(--navy);font-weight:600;}
.mat-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:9px;color:white;transition:all 0.15s;}
.mat-item.selected .mat-check{background:var(--navy);border-color:var(--navy);}
.sel-list{display:flex;flex-direction:column;gap:6px;margin-top:10px;}
.sel-item{display:flex;align-items:center;justify-content:space-between;background:#eef3fa;border-radius:var(--radius-sm);padding:8px 13px;font-size:13px;color:var(--navy);}
.qty-input{width:54px;padding:5px 7px;border:1.5px solid var(--border);border-radius:6px;font-size:13px;text-align:center;outline:none;}
.success-wrap{display:none;text-align:center;padding:1.5rem 0;}
.success-icon{width:64px;height:64px;border-radius:50%;background:var(--green-light);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:28px;}
.qty-ctrl{display:flex;align-items:center;gap:6px;}
.qty-btn{width:30px;height:30px;border-radius:6px;border:1.5px solid var(--border);background:white;font-size:17px;cursor:pointer;font-weight:700;color:var(--navy);display:flex;align-items:center;justify-content:center;transition:all 0.15s;touch-action:manipulation;}
.qty-btn:hover{background:var(--navy);color:white;border-color:var(--navy);}
.alert{border-radius:var(--radius-sm);padding:11px 16px;margin-bottom:1rem;}
.alert-amber{background:var(--amber-light);border:1px solid #f0c070;color:#7a4400;}
.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;background:rgba(0,15,40,0.75);align-items:center;justify-content:center;backdrop-filter:blur(3px);}
@keyframes modalIn{from{opacity:0;transform:scale(0.96) translateY(10px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes scanLine{0%{top:0%;}50%{top:calc(100% - 2px);}100%{top:0%;}}
.modal[style*="flex"] .modal-card,.modal[style*="block"] .modal-card{animation:modalIn 0.2s cubic-bezier(.4,0,.2,1) both;}
.modal-card{background:white;border-radius:var(--radius-lg);padding:2rem;width:480px;max-width:95vw;box-shadow:var(--shadow-lg);border-top:3px solid var(--navy);}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;}
.modal-title{font-family:'Montserrat',sans-serif;font-size:17px;font-weight:700;color:var(--navy);}
.modal-close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;border:none;background:none;color:var(--muted);font-size:20px;cursor:pointer;transition:background 0.15s,color 0.15s;flex-shrink:0;}
.modal-close:hover{background:var(--surface-2);color:var(--navy);}
.modal-divider{border:none;border-top:1px solid var(--border);margin:0 0 1.25rem;}
.modal-actions{display:flex;gap:10px;margin-top:1.25rem;}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
footer{background:var(--navy);color:rgba(255,255,255,0.4);text-align:center;font-size:11px;padding:1.1rem 1rem;margin-top:4rem;border-top:2px solid var(--teal);}
footer span{color:rgba(58,170,53,0.85);}
/* Confirm modal */
.confirm-modal-card{border-top-color:var(--red);}
.confirm-modal-icon{width:44px;height:44px;border-radius:50%;background:var(--red-light);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;flex-shrink:0;}
.confirm-body{display:flex;gap:14px;align-items:flex-start;}
.confirm-text .confirm-title{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px;}
.confirm-text .confirm-msg{font-size:13px;color:var(--muted);line-height:1.5;}
.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--red);color:white;border:none;border-radius:var(--radius-sm);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:opacity 0.15s,transform 0.1s;}
.btn-danger:hover{opacity:0.88;}
.btn-danger:active{transform:scale(0.97);}

/* ── Bouton Compléter (remise partielle) ── */
@media(max-width:768px){
  .btn-green[style*="amber"]{min-height:40px;font-size:12px !important;padding:9px 12px !important;}
}

/* ── Remise modal rows ── */
.remis-row{
  display:flex;align-items:center;gap:10px;
  background:white;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:8px 12px;
  transition:border-color .15s;
}
@media(max-width:768px){
  .remis-row{gap:8px;padding:6px 10px;}
  .remis-row input[type="number"]{font-size:16px !important;width:52px !important;}
  #remisModal .btn-outline,#remisModal .btn-primary{min-height:44px;font-size:14px !important;}
  #remisModal .modal-actions{flex-direction:column;}
  #remisModal .modal-actions .btn-primary{width:100%;justify-content:center;}
  #remisModal .modal-actions .btn-outline{width:100%;justify-content:center;}
}

/* ── Remise manuelle — tiles plus petits ── */
.mat-item-sm{font-size:11.5px !important;padding:7px 9px !important;}
.mat-item-sm .mat-check{width:14px !important;height:14px !important;font-size:8px !important;}

/* ── Remise manuelle — boutons panier ── */
.manuel-qty-btn{
  width:32px;height:32px;border-radius:50%;
  border:1.5px solid var(--border);background:none;
  font-size:18px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);flex-shrink:0;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  transition:background .15s,border-color .15s;
}
.manuel-qty-btn:hover{background:var(--navy-light);border-color:var(--navy);}
.manuel-qty-btn:active{transform:scale(0.92);}
.manuel-rm-btn{
  width:32px;height:32px;border:1.5px solid var(--border);border-radius:6px;
  background:none;color:var(--muted);font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  transition:background .15s,border-color .15s,color .15s;
}
.manuel-rm-btn:hover{background:var(--red-light);border-color:var(--red);color:var(--red);}

@media(max-width:768px){
  /* Grille : 2 cols sur mobile */
  #manuelMatsGrid{grid-template-columns:1fr 1fr !important;max-height:190px !important;}
  #manuelMatsGrid .mat-item-sm{font-size:11px !important;padding:7px 8px !important;}
  /* Actions en colonne */
  #remisManuelleModal .modal-actions{flex-direction:column;}
  #remisManuelleModal .modal-actions .btn-primary,
  #remisManuelleModal .modal-actions .btn-outline{width:100%;justify-content:center;min-height:50px;font-size:15px !important;}
  /* qty-input : no zoom iOS */
  #manuelSelList .qty-input{font-size:16px !important;}
  /* sel-item : plus d'espace pour les doigts */
  #manuelSelList .sel-item{padding:10px 12px !important;}
}

/* ══════════════════════════════════════════════════════════
   DESIGN SYSTEM v2 — stat cards, table rows, inventaire
   ══════════════════════════════════════════════════════════ */

/* ── Stat cards v2 ── */
.stat-card-v2{position:relative;background:#fff;border-radius:var(--radius-md);padding:1.2rem 1.4rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s,transform .2s;animation:fadeUp .4s ease both;}
.stat-card-v2:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.sc2-bar{position:absolute;left:0;top:0;bottom:0;width:4px;}
.stat-navy .sc2-bar{background:var(--navy-700);}
.stat-lime .sc2-bar{background:var(--lime-600);}
.stat-warn .sc2-bar{background:var(--warn);}
.sc2-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;}
.sc2-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-navy .sc2-icon{background:rgba(0,51,102,.07);color:var(--navy-700);}
.stat-lime .sc2-icon{background:rgba(58,170,53,.09);color:var(--lime-700);}
.stat-warn .sc2-icon{background:rgba(201,122,0,.09);color:var(--warn);}
.sc2-spark{display:flex;align-items:flex-end;gap:3px;height:32px;}
.sc2-spark span{width:5px;border-radius:3px 3px 0 0;min-height:4px;}
.stat-navy .sc2-spark span{background:var(--navy-700);opacity:.35;}
.stat-lime .sc2-spark span{background:var(--lime-600);opacity:.35;}
.stat-warn .sc2-spark span{background:var(--warn);opacity:.35;}
.sc2-value{font-size:38px;color:var(--ink-900);line-height:1;margin-bottom:3px;}
.sc2-label{font-size:12px;font-weight:600;color:var(--ink-500);margin-bottom:5px;}
.sc2-delta{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;}
.stat-navy .sc2-delta{color:var(--navy-600);}
.stat-lime .sc2-delta{color:var(--lime-700);}
.stat-warn .sc2-delta{color:var(--warn);}

/* ── Table v2 ── */
.tr-v2{display:grid;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);font-size:13px;cursor:pointer;transition:background .12s;animation:fadeUp .3s ease both;}
.tr-v2:hover{background:var(--ink-50);}
.tr-v2:last-child{border-bottom:none;}
.tr-v2.done-row{opacity:.75;}
.tr-cell-emp{display:flex;align-items:center;gap:10px;min-width:0;}
.tr-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--navy-700),var(--navy-600));color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tr-name{font-weight:600;color:var(--ink-900);font-size:13px;}
.tr-sub{font-size:11px;color:var(--ink-400);margin-top:1px;}
.tr-truck{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--navy-700);background:rgba(0,51,102,.07);border:1px solid rgba(0,51,102,.12);padding:3px 9px;border-radius:20px;}
.tr-articles{font-size:12px;color:var(--ink-500);line-height:1.5;}
.priority-flag{width:3px;height:24px;border-radius:3px;background:var(--warn);flex-shrink:0;}
.priority-flag.overdue-flag{background:var(--red);animation:pulse-flag 1.4s ease-in-out infinite;}
@keyframes pulse-flag{0%,100%{opacity:1;}50%{opacity:.35;}}
.tr-actions{display:flex;gap:5px;justify-content:flex-end;}
/* Status with dot */
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.status-pill.s-pending{background:rgba(204,34,0,.09);color:var(--red);border:1px solid rgba(204,34,0,.2);}
.status-pill.s-partial{background:var(--warn-50);color:var(--warn);}
.status-pill.s-done{background:var(--lime-50);color:var(--lime-700);}
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block;}
.s-pending .status-dot{background:var(--red);}
.s-partial .status-dot{background:var(--warn);}
.s-done .status-dot{background:var(--lime-600);}
/* Overdue rows */
.overdue-row{background:rgba(204,34,0,.025) !important;}
.overdue-days-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:800;color:var(--red);background:rgba(204,34,0,.1);border:1px solid rgba(204,34,0,.25);border-radius:4px;padding:2px 6px;}

/* ── Inventaire v2 ── */
.inv-row-v2{display:grid;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);font-size:13px;transition:background .12s;animation:fadeUp .3s ease both;cursor:pointer;}
.inv-row-v2:hover{background:var(--ink-50);}
.inv-row-v2:last-child{border-bottom:none;}
.inv-art-cell{display:flex;align-items:center;gap:10px;min-width:0;}
.inv-art-thumb{width:32px;height:32px;border-radius:8px;background:rgba(0,51,102,.07);display:flex;align-items:center;justify-content:center;color:var(--navy-700);flex-shrink:0;}
.inv-art-name{font-weight:600;color:var(--ink-900);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.inv-art-id{font-size:11px;color:var(--ink-400);margin-top:1px;}
.inv-qty{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;color:var(--ink-900);}
.inv-qty.muted{color:var(--ink-400);font-size:14px;}
.inv-stock-bar-wrap{height:6px;background:var(--ink-100);border-radius:99px;overflow:hidden;}
.inv-stock-bar{height:100%;border-radius:99px;transition:width .4s ease;}
.inv-alert-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.inv-alert-critical{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5;}
.inv-alert-low{background:var(--warn-50);color:var(--warn);border:1px solid #fcd38a;}
.inv-alert-ok{background:var(--lime-50);color:var(--lime-700);border:1px solid #86efac;}

/* ── Inventaire KPI mini (hero) ── */
.inv-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.inv-kpi{background:#fff;border-radius:var(--radius-md);padding:1rem 1.2rem;border:1px solid var(--border);box-shadow:var(--shadow-xs);}
.inv-kpi-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-400);margin-bottom:6px;}
.inv-kpi-val{font-size:36px;color:var(--ink-900);line-height:1;margin-bottom:3px;}
.inv-kpi-delta{font-size:10px;font-weight:600;padding:2px 7px;border-radius:99px;display:inline-block;margin-top:4px;}
.inv-kpi.kpi-lime .inv-kpi-val{color:var(--lime-700);}
.inv-kpi.kpi-lime .inv-kpi-delta{background:rgba(58,170,53,.09);color:var(--lime-700);}
.inv-kpi.kpi-warn .inv-kpi-val{color:var(--warn);}
.inv-kpi.kpi-warn .inv-kpi-delta{background:var(--warn-50);color:var(--warn);}
.inv-kpi.kpi-navy .inv-kpi-val{color:var(--navy-700);}
.inv-kpi.kpi-navy .inv-kpi-delta{background:rgba(0,51,102,.07);color:var(--navy-700);}

/* ── Inventaire tabs ── */
.inv-tabbar{display:flex;gap:4px;border-bottom:2px solid rgba(255,255,255,0.1);margin-bottom:1rem;}
.inv-tab{padding:9px 16px;border:none;background:none;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:rgba(255,255,255,0.45);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:7px;}
.inv-tab:hover{color:rgba(255,255,255,0.85);}
.inv-tab.active{color:#fff;border-bottom-color:var(--lime-500);}
.inv-tab-count{font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px;background:rgba(255,255,255,0.09);color:rgba(255,255,255,0.5);}
.inv-tab.active .inv-tab-count{background:var(--lime-600);color:#fff;}

/* ── Dashboard top bar ── */
.dash-topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 2rem;border-bottom:1px solid rgba(0,51,102,.1);background:rgba(255,255,255,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:10;}
.dash-crumbs{display:flex;align-items:center;gap:8px;font-size:13px;}
.dash-crumb-sep{color:var(--ink-300);}
.dash-date-chip{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:20px;font-size:11.5px;font-weight:600;color:var(--ink-500);}
.dash-icon-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-500);border:1px solid var(--border);background:#fff;cursor:pointer;transition:background .15s,color .15s;position:relative;}
.dash-icon-btn:hover{background:var(--ink-50);color:var(--navy-700);}
.notif-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--lime-600);border:1.5px solid #fff;}

/* ── Filter tabs (demandes) ── */
.filter-tabs{display:flex;gap:2px;background:var(--surface-2);border-radius:var(--radius-sm);padding:3px;}
.filter-tab{padding:6px 14px;border-radius:6px;border:none;background:none;font-family:'Barlow Condensed','Montserrat',sans-serif;font-size:12px;font-weight:700;color:var(--ink-500);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background .15s,color .15s;}
.filter-tab:hover{color:var(--navy-700);}
.filter-tab.active{background:#fff;color:var(--navy-700);box-shadow:var(--shadow-xs);}
.filter-tab-count{font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px;background:var(--surface-2);color:var(--muted);}
.filter-tab.active .filter-tab-count{background:var(--navy-700);color:#fff;}

/* ── Responsive: mobile overrides for v2 components ── */
@media(max-width:768px){
  .inv-kpi-row{grid-template-columns:repeat(2,1fr);}
  .stat-card-v2{padding:.9rem 1rem;}
  .sc2-value{font-size:28px;}

  /* Table rows: 2-col card layout on mobile */
  .tr-v2{
    grid-template-columns:1fr auto !important;
    grid-template-rows:auto auto;
    row-gap:6px;
    column-gap:8px !important;
    padding:10px 14px;
  }
  .tr-v2>div:nth-child(1){grid-column:1;grid-row:1;}   /* employee */
  .tr-v2>div:nth-child(2){grid-column:1;grid-row:2;}   /* truck badge */
  .tr-v2>div:nth-child(3){display:none;}               /* articles — hidden */
  .tr-v2>div:nth-child(4){grid-column:2;grid-row:1;align-self:start;} /* status */
  .tr-v2>div:nth-child(5){grid-column:2;grid-row:2;align-self:center;justify-self:end;} /* actions */
  .tr-actions{gap:4px;}
  .tr-actions .btn-green{font-size:10px !important;padding:5px 9px;}
  .tr-actions .btn-icon,.tr-actions .btn-del{padding:5px 7px;}
}

/* ═══════════════════════════════════════════════════
   SHARED PAGE HEADER BANNER
   ═══════════════════════════════════════════════════ */
.page-header{
  background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-700) 60%,var(--navy-600) 100%);
  padding:1.6rem 2rem 1.4rem;position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(180deg,rgba(255,255,255,.018) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay;pointer-events:none;
}
.page-header-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.page-header-badge{display:inline-flex;align-items:center;gap:7px;font-size:9.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:8px;}
.page-header-badge-dot{width:6px;height:6px;border-radius:99px;background:var(--lime-500);animation:pingDot 2s ease-out infinite;display:inline-block;}
.page-header h1{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:clamp(24px,3.5vw,40px);color:#fff;text-transform:uppercase;letter-spacing:-.005em;line-height:.92;margin-bottom:4px;}
.page-header h1 span{color:var(--lime-400);}
.page-header-sub{font-size:12px;color:rgba(255,255,255,.55);font-weight:500;}
.page-header-orn{position:absolute;right:-10px;top:-20px;opacity:.07;pointer-events:none;z-index:0;}

/* ═══════════════════════════════════════════════════
   APP BACKGROUND — Mission Control grid
   ═══════════════════════════════════════════════════ */
body{
  background:
    radial-gradient(900px 600px at 85% -5%,  rgba(58,170,53,0.09),  transparent 55%),
    radial-gradient(800px 700px at -10% 105%, rgba(0,168,156,0.06),  transparent 55%),
    radial-gradient(700px 500px at 50% 50%,  rgba(0,40,90,0.35),    transparent 65%),
    linear-gradient(160deg, #000e24 0%, #001838 55%, #002450 100%);
  background-attachment: fixed;
}
/* Grid overlay on page content areas — subtle white lines on dark */
#page-tableau,#page-inventaire,#page-camions,#page-employes,
#page-materiaux,#page-historique,#page-pieces,#page-reparations{
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 48px 48px,
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 48px 48px;
  min-height:100vh;
}

/* White cards float on dark — stronger shadow + light border glow */
.stat-card-v2,.table-wrap,.mat-cat-section,.inv-stat,.rep-stat,
.dash-panel,.dash-card,.inv-kpi{
  box-shadow:0 4px 20px rgba(0,0,0,.28),0 1px 4px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.12) !important;
  border-color:rgba(255,255,255,.1) !important;
}

/* ═══════════════════════════════════════════════════
   DASHBOARD HERO — CCTV chrome
   ═══════════════════════════════════════════════════ */
.dash-hero{
  position:relative;padding:38px 48px 34px;margin:18px 22px 0;
  border-radius:14px;
  background:#001022;
  border:1px solid rgba(82,196,78,.20);
  box-shadow:0 32px 80px rgba(0,20,60,.7),0 0 0 1px rgba(82,196,78,.06),inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
  display:grid;grid-template-columns:1fr 280px;align-items:center;gap:24px;
  min-height:290px;
}
/* ── Buse background image ── */
.dash-hero-bg{position:absolute;inset:0;z-index:0;background:#001022;overflow:hidden;}
.dash-hero-bg img{
  /* absolute positioning so the image floats at a fixed size — no object-fit edge issues */
  position:absolute;
  height:115%;width:auto;
  top:50%;left:58%;
  transform:translate(-50%,-50%);
  filter:brightness(1.20) saturate(1.0) contrast(1.02);
  animation:buseFloat 9s ease-in-out infinite;
  /* radial mask: percentages are relative to the image itself → always fades all 4 edges */
  mask-image:radial-gradient(
    ellipse 58% 58% at 42% 50%,
    black 30%,
    rgba(0,0,0,.80) 55%,
    rgba(0,0,0,.25) 78%,
    transparent 100%
  );
  -webkit-mask-image:radial-gradient(
    ellipse 58% 58% at 42% 50%,
    black 30%,
    rgba(0,0,0,.80) 55%,
    rgba(0,0,0,.25) 78%,
    transparent 100%
  );
}
.dash-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,
    rgba(0,16,34,.4) 0%,transparent 18%,transparent 82%,rgba(0,16,34,.4) 100%
  );
  pointer-events:none;
}
/* ── Gradient overlay gauche (lisibilité texte) ── */
.dash-hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to right,
    #001022 0%,#001428 18%,rgba(0,18,42,.92) 28%,
    rgba(0,18,42,.65) 38%,rgba(0,14,36,.30) 48%,
    transparent 58%
  );
}
/* ── Vignette haut/bas ── */
.dash-hero-vignette{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,10,28,.25) 0%,transparent 30%,transparent 65%,rgba(0,10,28,.45) 100%);
}
/* ── Halo vert robot ── */
.dash-hero-robot-glow{
  position:absolute;right:50px;top:50%;transform:translateY(-50%);
  width:300px;height:300px;
  background:radial-gradient(circle at center,rgba(82,196,78,.28) 0%,rgba(58,170,53,.12) 45%,transparent 72%);
  filter:blur(28px);z-index:2;pointer-events:none;
}
.dash-hero-scanlines{
  position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(180deg,rgba(255,255,255,.022) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay;z-index:1;
}
.dash-hero-corner{position:absolute;width:18px;height:18px;z-index:3;pointer-events:none;}
.dash-hero-hud{
  position:absolute;top:16px;right:28px;
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:700;letter-spacing:1.4px;
  color:rgba(255,255,255,.65);font-family:ui-monospace,monospace;z-index:3;
}
.dash-hero-hud-dot{width:7px;height:7px;border-radius:99px;background:#ff3b30;animation:pingDot 1.6s ease-in-out infinite;}
.dash-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--lime-400);padding:5px 12px 5px 10px;
  background:rgba(82,196,78,.12);border:1px solid rgba(82,196,78,.35);border-radius:99px;
  margin-bottom:16px;position:relative;z-index:2;
}
.dash-eyebrow-dot{width:7px;height:7px;border-radius:99px;background:var(--lime-500);animation:pingDot 2s ease-out infinite;flex-shrink:0;}
.dash-hero-left{max-width:580px;position:relative;z-index:5;animation:fadeUp .5s ease both;}
.dash-hero-right{position:relative;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeUp .6s ease .06s both;}
.dash-hero-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap;}
.dash-hero-cta{
  display:inline-flex;align-items:center;gap:7px;padding:10px 18px;
  background:var(--lime-600);color:#001a3d;border-radius:var(--radius-sm);border:none;
  font-weight:800;font-family:'Barlow Condensed',sans-serif;font-size:13px;
  letter-spacing:.4px;text-transform:uppercase;cursor:pointer;
  transition:background .15s,box-shadow .15s,transform .1s;
  box-shadow:0 3px 10px rgba(0,51,102,.18);
}
.dash-hero-cta:hover{background:var(--lime-500);transform:translateY(-1px);}
.dash-hero-ghost{
  display:inline-flex;align-items:center;gap:7px;padding:10px 16px;
  background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.22);
  color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:12.5px;
  letter-spacing:.3px;cursor:pointer;transition:all .15s;
}
.dash-hero-ghost:hover{background:rgba(255,255,255,.14);}

/* ═══════════════════════════════════════════════════
   DASHBOARD CONTENT GRID
   ═══════════════════════════════════════════════════ */
.dash-scroll-content{padding:22px 22px 40px;max-width:1500px;margin:0 auto;}
.dash-content-grid{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:16px;align-items:flex-start;}
.dash-side-col{display:flex;flex-direction:column;gap:14px;}

/* Panel (main card) */
.dash-panel{background:#fff;border:1px solid var(--ink-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;}
.dash-panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px 12px;border-bottom:1px solid var(--ink-100);gap:12px;flex-wrap:wrap;}
.dash-panel-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:21px;color:var(--navy-900);letter-spacing:.2px;}
.dash-panel-sub{font-size:11.5px;color:var(--ink-500);margin-top:2px;}
.dash-panel-toolbar{display:flex;gap:10px;padding:10px 20px 8px;align-items:center;flex-wrap:wrap;border-bottom:1px solid var(--ink-100);}
.dash-search-wrap{position:relative;flex:1;min-width:180px;}
.dash-search-ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-400);pointer-events:none;}
.dash-search{width:100%;padding:8px 12px 8px 33px;border:1.5px solid var(--ink-200);border-radius:var(--radius-sm);font-size:13px;outline:none;background:#fff;transition:border-color .15s,box-shadow .15s;font-family:'Open Sans',sans-serif;}
.dash-search:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px rgba(0,51,102,.08);}

/* Side cards */
.dash-card{background:#fff;border:1px solid var(--ink-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;}
.dash-card-head{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px 10px;border-bottom:1px solid var(--ink-100);}
.dash-card-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:17px;color:var(--navy-900);letter-spacing:.2px;}
.dash-card-sub{font-size:11px;color:var(--ink-400);margin-top:2px;}

/* ── Responsive ── */
@media(max-width:1100px){
  .dash-content-grid{grid-template-columns:1fr;}
  .dash-side-col{display:none;}
  .dash-hero{grid-template-columns:1fr;margin:12px 14px 0;padding:28px 28px 24px;}
  .dash-scroll-content{padding:16px 14px 32px;}
}
@media(max-width:768px){
  .dash-hero{display:none;}
  .dash-scroll-content{padding:10px 0 28px;}
  .dash-panel-toolbar{padding:8px 14px 6px;}
  .dash-panel-header{padding:12px 14px 10px;}
}
/* Scanner button: mobile-only in panel header, hidden in hero on desktop */
.mobile-scan-btn{display:none;}
@media(max-width:768px){.mobile-scan-btn{display:inline-flex !important;}}
@media(min-width:769px){.dash-scan-mobile{display:none !important;}}
