/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0c1525;--surface:#162032;--surface2:#1e2e42;--surface3:#162032;
  --border:#253347;--border2:#2e4060;--text:#e8f0fa;--muted:#6b85a0;
  --primary:#3b82f6;--primary-h:#2563eb;--danger:#ef4444;
  --radius:10px;--shadow:0 8px 40px rgba(0,0,0,0.55);
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px}
a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}

/* ===== LOGIN ===== */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#070d1a 0%,#0e2040 100%)}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:18px;
  padding:48px 40px;width:100%;max-width:400px;box-shadow:var(--shadow)}
.login-logo{text-align:center;margin-bottom:36px}
.logo-icon{font-size:38px}
.login-logo h1{font-size:28px;font-weight:900;letter-spacing:3px;color:#fff;margin-top:10px}
.login-logo p{color:var(--muted);font-size:13px;margin-top:4px}
#loginForm{display:flex;flex-direction:column;gap:16px}
.error-msg{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);color:#fca5a5;
  padding:10px 14px;border-radius:8px;font-size:13px}

/* ===== HEADER ===== */
.header{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;height:56px}
.header-left{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-brand{font-size:18px;font-weight:900;letter-spacing:2.5px;color:#fff;display:block}
.header-sub{font-size:10px;color:var(--muted);display:block;letter-spacing:.5px}

/* ===== TAB NAV ===== */
.tab-nav{display:flex;gap:2px;flex:1;justify-content:center}
.tab-nav-btn{background:none;border:none;color:var(--muted);padding:8px 14px;border-radius:8px;
  cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;white-space:nowrap}
.tab-nav-btn:hover{color:var(--text);background:var(--surface2)}
.tab-nav-btn.active{color:#fff;background:var(--primary);font-weight:600}

/* ===== TAB SECTIONS ===== */
.tab-section{display:none;padding:0}
.tab-section.active{display:block}
.page-header{display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px 10px;flex-wrap:wrap;gap:10px}
.page-header h2{font-size:18px;font-weight:700}

/* ===== TOOLBAR ===== */
.toolbar{display:flex;align-items:center;gap:10px;padding:8px 24px 12px;flex-wrap:wrap}
.search-input{flex:1;min-width:240px;background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:9px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s}
.search-input:focus{border-color:var(--primary)}
.filter-tabs{display:flex;gap:5px;flex-wrap:wrap}
.tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);
  padding:6px 12px;border-radius:20px;cursor:pointer;font-size:12px;transition:all .2s}
.tab:hover{border-color:var(--primary);color:var(--text)}
.tab.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}

/* ===== CONTENT AREA ===== */
.content-area{padding:0 24px 32px}

/* ===== DASHBOARD ===== */
.dash-kpis{display:flex;gap:10px;padding:16px 24px 8px;flex-wrap:wrap}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 20px;min-width:120px;text-align:center;flex:1}
.kpi-n{font-size:22px;font-weight:800;color:var(--primary)}
.kpi-label{font-size:10px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:8px 24px 32px}
.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.dash-card-wide{grid-column:1/-1}
.dash-card-title{font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:600;margin-bottom:14px}
.statut-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bar-track{flex:1;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px;transition:width .4s}
.bar-n{font-size:12px;color:var(--muted);min-width:20px;text-align:right}
.fourn-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.fourn-row:last-child{border-bottom:none}
.fourn-rank{width:20px;height:20px;background:var(--surface2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.fourn-nom{flex:1;font-size:13px}
.fourn-total{font-weight:600;color:var(--primary)}
.empty-inline{color:var(--muted);font-size:13px;padding:12px 0}

/* ===== ORDER CARDS ===== */
.order-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:8px;overflow:hidden;transition:border-color .15s}
.order-card:hover{border-color:var(--border2)}
.order-card-selected{border-color:var(--primary)!important;background:color-mix(in srgb,var(--primary) 8%,var(--surface))}
.col-select{width:28px;flex-shrink:0;align-items:center;justify-content:center}
.order-row{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;transition:background .15s}
.order-row:hover{background:var(--surface2)}
.expand-icon{color:var(--muted);font-size:10px;width:12px;flex-shrink:0}
.ocol{display:flex;flex-direction:column;gap:3px}
.col-fac{min-width:140px;flex:1}
.col-client{min-width:140px;flex:1.2}
.col-fourn{flex:2;flex-direction:row;flex-wrap:wrap;gap:5px;align-items:center}
.col-total{min-width:100px;align-items:flex-end}
.col-statut{min-width:130px;align-items:flex-end}
.col-actions{min-width:72px;flex-direction:row;gap:3px;align-items:center;justify-content:flex-end}
.o-main{font-weight:600;font-size:14px}
.o-sub{font-size:11px;color:var(--muted)}
.shine-ref{font-size:11px;color:#60a5fa;font-family:monospace}
.tag{background:var(--surface2);border:1px solid var(--border2);border-radius:6px;
  padding:3px 9px;font-size:12px;font-weight:500}
.tag-sm{background:var(--surface2);border:1px solid var(--border);border-radius:4px;
  padding:2px 7px;font-size:11px}

/* ===== LINES PANEL ===== */
.lines-panel{border-top:1px solid var(--border);background:rgba(0,0,0,.2)}
.lines-empty{padding:14px 20px;color:var(--muted);font-size:13px}

/* ===== SUPPLIERS LIST (in lines-panel) ===== */
.suppliers-list{padding:12px 16px;display:flex;flex-direction:column;gap:10px}

.supplier-block{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;overflow:hidden}
.supplier-block-header{display:flex;align-items:center;justify-content:space-between;
  padding:9px 14px;background:rgba(0,0,0,.15);border-bottom:1px solid var(--border)}
.supplier-block-header strong{font-size:13px;font-weight:700;color:var(--text)}
.supplier-meta{font-size:11px;color:var(--muted)}
.supplier-articles{padding:8px 14px;display:flex;flex-direction:column;gap:4px}
.supplier-article-row{display:flex;align-items:center;justify-content:space-between;font-size:13px}
.article-desc{color:var(--text)}
.article-price{color:var(--muted);font-size:12px;white-space:nowrap;margin-left:8px}
.supplier-block-footer{display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.supplier-total{font-size:12px;color:var(--primary);font-weight:600}

.lines-panel-actions{display:flex;gap:8px;padding:4px 0 6px}
.lines-totals{display:flex;gap:16px;padding:6px 0;border-top:1px solid var(--border);margin-top:4px;
  font-size:13px;color:var(--muted)}
.lines-totals strong{color:var(--text)}

/* ===== DATA TABLE ===== */
.data-table{width:100%;border-collapse:collapse;background:var(--surface);
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.data-table thead th{background:var(--surface2);padding:11px 14px;text-align:left;
  font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.data-table tbody td{padding:12px 14px;border-top:1px solid var(--border);vertical-align:middle}
.data-table tbody tr:hover{background:var(--surface2)}

/* ===== SIMPLE TABLE (dashboard) ===== */
.simple-table{width:100%;border-collapse:collapse}
.simple-table thead th{padding:8px 12px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--border)}
.simple-table tbody td{padding:10px 12px;border-bottom:1px solid rgba(37,51,71,.4);font-size:13px}
.simple-table tbody tr:last-child td{border-bottom:none}

/* ===== BADGE ===== */
.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;white-space:nowrap}
.badge-btn{border:none;cursor:pointer;transition:opacity .15s,transform .1s}
.badge-btn:hover{opacity:.85;transform:scale(1.03)}
.badge-sm{padding:3px 9px;font-size:11px}

/* ===== STATUT POPUP ===== */
.statut-popup{display:none;position:absolute;z-index:500;background:var(--surface);
  border:1px solid var(--border2);border-radius:10px;box-shadow:var(--shadow);min-width:175px;padding:5px}
.statut-popup.active{display:block}
.statut-opt{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;
  color:var(--text);padding:8px 10px;border-radius:7px;cursor:pointer;font-size:13px;text-align:left;transition:background .15s}
.statut-opt:hover{background:var(--surface2)}
.statut-opt.active{background:var(--surface2);font-weight:600}
.sdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}

/* ===== BUTTONS ===== */
.btn{padding:9px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-h)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text);border-color:var(--border2)}
.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border)}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-full{width:100%;margin-top:6px;padding:12px}
.btn-icon{background:none;border:none;cursor:pointer;padding:5px 7px;border-radius:6px;font-size:15px;opacity:.75;transition:opacity .2s}
.btn-icon:hover{opacity:1;background:var(--surface2)}
.btn-remove{background:none;border:none;color:var(--danger);cursor:pointer;font-size:12px;padding:3px 8px;border-radius:5px;opacity:.7;transition:opacity .15s}
.btn-remove:hover{opacity:1;background:rgba(239,68,68,.1)}

/* ===== FORMS ===== */
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:9px 12px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-group select option{background:var(--surface2)}
.inline-input{background:var(--surface2);border:1px solid var(--border);border-radius:6px;
  padding:5px 8px;color:var(--text);font-size:13px;width:110px;text-align:right;outline:none}
.inline-input:focus{border-color:var(--primary)}
.form-grid{display:grid;gap:12px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g5{grid-template-columns:repeat(5,1fr)}
.g-span2{grid-column:span 2}

/* ===== MODAL ===== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:200;
  align-items:flex-start;justify-content:center;padding:30px 16px;overflow-y:auto}
.modal-overlay.active{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;
  width:100%;max-width:600px;box-shadow:var(--shadow);margin:auto}
.modal-xl{max-width:960px}
.modal-sm{max-width:520px}
.modal-header{display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px 14px;border-bottom:1px solid var(--border)}
.modal-header h2{font-size:16px;font-weight:700}
.modal-close{background:none;border:none;color:var(--muted);font-size:17px;cursor:pointer;
  padding:4px 8px;border-radius:6px}
.modal-close:hover{background:var(--surface2);color:var(--text)}
.modal-body{padding:20px 24px;max-height:72vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 24px;border-top:1px solid var(--border)}
.modal-total-bar{font-size:14px;font-weight:700;color:var(--primary);text-align:right;min-height:20px}

/* ===== LINE BLOCK ===== */
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:600}
.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.hint{font-size:11px;color:var(--muted)}
.line-block{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:14px 16px;margin-top:10px}
.line-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.line-label{font-size:12px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}

/* ===== ARTICLES SECTION (in supplier block of modal) ===== */
.articles-section{margin-top:12px;background:rgba(0,0,0,.15);border-radius:8px;padding:10px 12px}
.articles-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.articles-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600}

.articles-mini-table{width:100%;border-collapse:collapse}
.articles-mini-table thead th{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;
  padding:4px 6px;border-bottom:1px solid var(--border);text-align:left}
.articles-mini-table tbody td{padding:4px 4px;border-bottom:1px solid rgba(37,51,71,.3)}
.articles-mini-table tbody tr:last-child td{border-bottom:none}

.article-row{}
.art-input{background:var(--surface);border:1px solid var(--border);border-radius:5px;
  padding:5px 7px;color:var(--text);font-size:12px;outline:none;width:100%;transition:border-color .15s}
.art-input:focus{border-color:var(--primary)}
.art-qty{width:54px;text-align:center}
.art-price{width:90px;text-align:right}
.art-subtotal{font-size:12px;color:var(--muted);text-align:right;padding:4px 8px;white-space:nowrap}

/* supplier total in modal */
.supplier-total{margin-top:8px;font-size:12px;color:var(--muted);text-align:right}
.supplier-total strong{color:var(--primary)}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:60px;color:var(--muted);font-size:15px}

/* ===== MISC ===== */
.mono{font-family:monospace;font-size:12px;color:var(--muted)}
.text-right{text-align:right}
.text-muted{color:var(--muted)}

/* ===== FRAIS DE PORT ===== */
.fp-calc-box{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:18px;margin-top:12px}
.fp-result-grid{display:flex;gap:20px;flex-wrap:wrap;align-items:center;margin-top:12px}
.fp-result-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 18px;min-width:180px;flex:1}
.fp-result-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.fp-result-price{font-size:20px;font-weight:700}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .tab-nav{gap:0}.tab-nav-btn{padding:8px 10px;font-size:12px}
  .g4{grid-template-columns:1fr 1fr}
  .g5{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .header{height:auto;flex-wrap:wrap;padding:10px 14px;gap:8px}
  .tab-nav{order:3;width:100%;overflow-x:auto;justify-content:flex-start;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .tab-nav::-webkit-scrollbar{display:none}
  .tab-nav-btn{flex-shrink:0;min-height:40px}
  .dash-grid{grid-template-columns:1fr}
  .col-fourn,.col-total{display:none}
  .g4{grid-template-columns:1fr 1fr}
  .g5{grid-template-columns:1fr 1fr}
  .g3{grid-template-columns:1fr 1fr}
  .g-span2{grid-column:auto}
  .page-header{padding:14px 16px 8px}
  .toolbar{padding:8px 16px 10px}
  .content-area{padding:0 12px 24px}
  .modal-overlay{padding:0;align-items:flex-end}
  .modal{border-radius:18px 18px 0 0;margin:0;max-width:100%}
  .modal-body{max-height:65vh}
  .data-table thead{display:none}
  .data-table tbody tr{display:block;border-bottom:1px solid var(--border);padding:8px 0}
  .data-table tbody td{display:flex;justify-content:space-between;align-items:center;padding:5px 14px;border:none;font-size:13px}
  .data-table tbody td::before{content:attr(data-label);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;margin-right:8px;flex-shrink:0}
}
@media(max-width:480px){
  .g4,.g5,.g3,.g2{grid-template-columns:1fr}
  .g-span2{grid-column:auto}
  .filter-tabs{gap:4px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .tab{padding:6px 11px;font-size:11px;flex-shrink:0;white-space:nowrap}
  /* Form inputs larger for touch (prevents iOS zoom) */
  .form-group input,.form-group select,.form-group textarea{font-size:16px;padding:11px 12px}
  .inline-input{font-size:14px}
  /* Order card compact */
  .col-client{display:none}
  .col-statut{min-width:0}
  .col-actions{min-width:60px}
  .o-main{font-size:13px}
  .order-row{padding:10px 12px;gap:7px}
  /* Header */
  .header-brand{font-size:16px}
  .tab-nav-btn{font-size:11px;padding:7px 9px}
  /* Buttons touch targets */
  .btn-icon{padding:8px;font-size:16px}
  .btn{min-height:42px}
  /* Page header */
  .page-header{flex-direction:column;align-items:flex-start;gap:8px}
  .page-header h2{font-size:16px}
  /* Dashboard KPIs */
  .dash-kpis{padding:12px 12px 6px;gap:8px}
  .kpi-card{padding:12px 14px;min-width:calc(50% - 4px)}
  /* Dash grid */
  .dash-grid{padding:8px 12px 24px;gap:12px}
}
@media(max-width:360px){
  .kpi-card{min-width:100%;flex:1 1 100%}
  .tab-nav-btn span.tab-text{display:none}
}

/* ===== DEMANDES PIECES ===== */
.demande-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:8px;overflow:hidden;transition:border-color .15s}
.demande-card:hover{border-color:var(--border2)}
.demande-card.new-badge{border-left:3px solid #3b82f6}
.demande-row{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;flex-wrap:wrap}
.demande-col-main{flex:1;min-width:180px}
.demande-col-vehicule{flex:1;min-width:160px}
.demande-col-pieces{flex:2;min-width:200px}
.demande-col-statut{min-width:120px;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.demande-nom{font-weight:700;font-size:14px}
.demande-contact{font-size:12px;color:var(--muted);margin-top:3px}
.demande-vehicule{font-size:13px;font-weight:600;color:var(--primary)}
.demande-desc{font-size:13px;color:var(--text);margin-top:4px;line-height:1.5}
.demande-date{font-size:11px;color:var(--muted)}
.badge-nouveau{background:#3b82f6}
.badge-en-cours{background:#f59e0b}
.badge-traite{background:#22c55e}
.badge-annule{background:#64748b}
.notif-dot{display:inline-block;width:8px;height:8px;background:#ef4444;border-radius:50%;margin-left:4px;vertical-align:middle;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@media(max-width:480px){
  .demande-col-vehicule{display:none}
  .demande-row{gap:8px;padding:12px}
}

/* ===== BOTTOM NAV (mobile only) ===== */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;
  background:rgba(18,26,42,.97);border-top:1px solid var(--border);z-index:151;
  padding-bottom:env(safe-area-inset-bottom);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.bottom-nav-scroll{display:flex;height:56px;overflow-x:auto;
  scrollbar-width:none;-webkit-overflow-scrolling:touch}
.bottom-nav-scroll::-webkit-scrollbar{display:none}
.bnav-btn{flex:1;min-width:58px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;background:none;border:none;
  color:var(--muted);cursor:pointer;padding:8px 4px;transition:color .15s;
  position:relative;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.bnav-btn.active{color:var(--primary)}
.bnav-icon{font-size:19px;line-height:1}
.bnav-label{font-size:9px;font-weight:500;white-space:nowrap;letter-spacing:.1px}
.bnav-notif{position:absolute;top:4px;left:calc(50% + 6px);
  width:7px;height:7px;background:#ef4444;border-radius:50%;animation:pulse 1.5s infinite}

/* ===== RESPONSIVE MOBILE AMÉLIORÉ ===== */
@media(max-width:768px){
  body{padding-bottom:calc(56px + env(safe-area-inset-bottom))}
  .bottom-nav{display:block}
  .tab-nav{display:none !important}
  .header{height:50px;padding:0 14px}
  .header-sub{display:none}
  /* Modal plein écran depuis le bas */
  .modal{max-height:92vh !important;display:flex;flex-direction:column}
  .modal-body{flex:1;max-height:none !important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .modal-overlay{padding:0 0 calc(56px + env(safe-area-inset-bottom)) !important}
  /* Boutons modal empilés */
  .modal-footer{flex-direction:column-reverse;gap:8px;padding:12px 16px}
  .modal-footer .btn{width:100%;text-align:center;min-height:44px}
}
@media(max-width:480px){
  /* Order card: grille 2 lignes — affiche client + total */
  .order-row{
    display:grid !important;
    grid-template-columns:16px 1fr auto auto;
    grid-template-rows:auto auto;
    align-items:center;
    gap:2px 8px;
    padding:10px 12px !important
  }
  .expand-icon{grid-column:1;grid-row:1/3;align-self:center}
  .col-fac{grid-column:2;grid-row:1;display:flex !important;min-width:0}
  .col-client{grid-column:2;grid-row:2;display:flex !important;min-width:0}
  .col-client .o-main{font-size:12px;color:var(--muted);font-weight:500}
  .col-client .o-sub{display:none}
  .col-fourn{display:none !important}
  .col-total{grid-column:3;grid-row:2;display:flex !important;min-width:0;align-items:flex-end}
  .col-total .o-main{font-size:12px;color:var(--primary);font-weight:700}
  .col-total .o-sub{display:none}
  .col-statut{grid-column:3;grid-row:1;min-width:0;align-items:flex-end}
  .col-actions{grid-column:4;grid-row:1/3;align-self:center;flex-direction:column;gap:2px}
  /* Articles table: scroll horizontal dans modal */
  .articles-section{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .articles-mini-table{min-width:330px}
  /* Supplier block header */
  .supplier-block-header{flex-wrap:wrap;gap:4px}
  .supplier-meta{font-size:10px;width:100%}
  .supplier-article-row{flex-wrap:wrap;gap:2px}
  .article-price{width:100%;margin-left:0}
  /* Lines panel */
  .lines-panel-actions{flex-wrap:wrap;gap:6px}
  .lines-totals{flex-wrap:wrap;gap:6px}
  /* Frais de port: 2 colonnes */
  .fp-result-card{min-width:0;flex:1 1 calc(50% - 5px)}
  /* Login */
  .login-box{padding:32px 20px;border-radius:14px}
}
