/* ══════════════════════════════════════════════════════
   LEGIS IMMO — Backend Design System v2
   Clair, chaleureux, responsive
   ══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Playfair+Display:wght@700&display=swap');

:root {
  /* Sidebar — marron lisible, pas trop sombre */
  --sb-bg:    #4A2C10;
  --sb-w:     230px;

  /* Palette */
  --brown:    #5C3A1E;
  --brown-d:  #3D2400;
  --brown-l:  #7A5030;
  --gold:     #C9A96E;
  --gold-d:   #A8844A;
  --gold-l:   #DCC08A;
  --gold-bg:  #FBF7F0;
  --gold-hv:  #F0E8D8;

  /* Fonds */
  --bg:       #FEFCF9;
  --surface:  #FFFFFF;
  --surf2:    #FEFCF9;
  --border:   #EAE0D0;
  --border-d: #D4C0A8;

  /* Textes */
  --text:     #2C1A08;
  --muted:    #7A6048;
  --light:    #A89070;

  /* États */
  --green:    #166534; --green-bg: #F0FDF4; --green-bd: #BBF7D0;
  --red:      #B91C1C; --red-bg:   #FFF5F5; --red-bd:   #FECACA;
  --amber:    #92400E; --amber-bg: #FFFBF0; --amber-bd: #FDE68A;
  --blue:     #1E40AF; --blue-bg:  #F0F5FF; --blue-bd:  #BFDBFE;

  --r:        8px;
  --r-lg:     14px;
  --shadow:   0 1px 3px rgba(92,58,30,.06), 0 2px 10px rgba(92,58,30,.04);
  --shadow-md:0 4px 20px rgba(92,58,30,.10);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
body{font-family:'Outfit',system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}

/* ════════════════════ LAYOUT ════════════════════ */
.app{display:flex;min-height:100vh}
.main{flex:1;margin-left:var(--sb-w);display:flex;flex-direction:column;min-width:0}

/* ════════════════════ SIDEBAR ════════════════════ */
.sidebar{
  width:var(--sb-w);height:100vh;position:fixed;top:0;left:0;
  background:var(--sb-bg);
  display:flex;flex-direction:column;z-index:100;
  will-change:transform;
  overflow-y:auto;scrollbar-width:none;
  /* Fond légèrement moins sombre = texte plus lisible */
}
.sidebar::-webkit-scrollbar{display:none}

.sb-logo{
  display:flex;align-items:center;gap:10px;
  padding:20px 18px 16px;
  border-bottom:1px solid rgba(201,169,110,.15);flex-shrink:0;
}
.sb-logo-mark{
  width:34px;height:34px;background:var(--gold);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--brown-d);font-size:.9rem;flex-shrink:0;
}
.sb-logo-name{font-size:.9rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.sb-logo-sub{font-size:.6rem;color:rgba(255,255,255,.5);margin-top:1px;letter-spacing:.05em;text-transform:uppercase}

.sb-section{
  font-size:.58rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(201,169,110,.55);
  padding:16px 18px 5px;
}

/* Liens sidebar — texte blanc bien lisible */
.sb-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 18px;
  color:rgba(255,255,255,.75); /* plus clair = plus lisible */
  font-size:.81rem;font-weight:500;
  transition:all .12s;position:relative;
}
.sb-link i{width:16px;text-align:center;font-size:.8rem;flex-shrink:0}
.sb-link span{flex:1}
.sb-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.sb-link.active{color:var(--gold);background:rgba(201,169,110,.14);font-weight:700}
.sb-link.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--gold);border-radius:0 3px 3px 0;
}
.sb-link.sb-danger{color:rgba(252,165,165,.6)}
.sb-link.sb-danger:hover{color:rgba(252,165,165,.9);background:rgba(252,165,165,.07)}

.sb-badge{
  margin-left:auto;background:var(--red);color:#fff;
  font-size:.54rem;font-weight:700;padding:2px 6px;
  border-radius:99px;min-width:18px;text-align:center;line-height:1.5;
}

.sb-user{
  margin-top:auto;padding:14px 16px;
  border-top:1px solid rgba(201,169,110,.12);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.sb-av{
  width:32px;height:32px;background:var(--gold);color:var(--brown-d);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:800;flex-shrink:0;
}
.sb-name{font-size:.79rem;font-weight:700;color:#fff;line-height:1.3}
.sb-role{font-size:.62rem;color:rgba(255,255,255,.5);margin-top:1px}

/* Bouton hamburger mobile */
.sb-toggle{display:none;position:fixed;top:12px;right:12px;left:auto;z-index:200;
  width:38px;height:38px;border-radius:9px;background:var(--sb-bg);
  border:none;color:var(--gold);font-size:1rem;
  align-items:center;justify-content:center;box-shadow:var(--shadow-md)}

/* ════════════════════ TOPBAR ════════════════════ */
.topbar{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:14px 26px;display:flex;align-items:center;
  justify-content:space-between;gap:16px;flex-shrink:0;
  position:sticky;top:0;z-index:50;
}
.topbar h1{font-size:.96rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.topbar h1 i{color:var(--gold-d);font-size:.85rem}
.topbar p{font-size:.72rem;color:var(--muted);margin-top:2px}
.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ════════════════════ CONTENT ════════════════════ */
.content{padding:26px 28px;flex:1}

/* ════════════════════ KPI CARDS ════════════════════ */
.kpi-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));
  gap:12px;margin-bottom:22px;
}
.kpi-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 16px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);transition:all .15s;
}
.kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--gold-l)}
.kpi-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.kpi-ico.gold  {background:var(--gold-bg);color:var(--gold-d)}
.kpi-ico.brown {background:#F5EDE0;color:var(--brown)}
.kpi-ico.green {background:var(--green-bg);color:var(--green)}
.kpi-ico.red   {background:var(--red-bg);color:var(--red)}
.kpi-ico.amber {background:var(--amber-bg);color:var(--amber)}
.kpi-ico.blue  {background:var(--blue-bg);color:var(--blue)}
.kpi-val{font-size:1.55rem;font-weight:800;line-height:1;color:var(--text)}
.kpi-lbl{font-size:.65rem;color:var(--muted);margin-top:2px;font-weight:500}

/* ════════════════════ CARDS ════════════════════ */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden}
.card-header{
  padding:14px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--surf2);
}
.card-title{font-size:.86rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.card-title i{color:var(--gold-d);font-size:.82rem}
.card-body{padding:20px 24px}

/* ════════════════════ TABLE ════════════════════ */
.data-table{width:100%;border-collapse:collapse;font-size:.8rem}
.data-table th{
  background:var(--surf2);color:var(--muted);
  font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  padding:10px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;
}
.data-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr:hover td{background:var(--gold-bg)}
.td-bold{font-weight:600;font-size:.82rem}
.td-muted{font-size:.74rem;color:var(--muted);margin-top:1px}
.td-mono{font-family:monospace;font-size:.72rem;color:var(--muted)}

/* ════════════════════ BADGES ════════════════════ */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:99px;font-size:.67rem;font-weight:700;white-space:nowrap;border:1px solid;
}
.badge-green {background:var(--green-bg);color:var(--green);border-color:var(--green-bd)}
.badge-red   {background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}
.badge-amber {background:var(--amber-bg);color:var(--amber);border-color:var(--amber-bd)}
.badge-blue  {background:var(--blue-bg);color:var(--blue);border-color:var(--blue-bd)}
.badge-gold  {background:var(--gold-bg);color:var(--gold-d);border-color:var(--gold-l)}
.badge-brown {background:#F5EDE0;color:var(--brown);border-color:var(--border-d)}
.badge-gray  {background:#F3F4F6;color:#6B7280;border-color:#E5E7EB}
/* Alias */
.badge-ok    {background:var(--green-bg);color:var(--green);border-color:var(--green-bd)}
.badge-err   {background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}
.badge-warn  {background:var(--amber-bg);color:var(--amber);border-color:var(--amber-bd)}
.badge-sky   {background:var(--blue-bg);color:var(--blue);border-color:var(--blue-bd)}
.badge-royal {background:#F5EDE0;color:var(--brown);border-color:var(--border-d)}
.badge-muted {background:#F3F4F6;color:#6B7280;border-color:#E5E7EB}
.badge-loc   {background:#EFF6FF;color:#1E40AF;border-color:#BFDBFE}
.badge-vte   {background:#F5F3FF;color:#6D28D9;border-color:#DDD6FE}
.badge-enc   {background:var(--amber-bg);color:var(--amber);border-color:var(--amber-bd)}

/* ════════════════════ BOUTONS ════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 17px;border-radius:var(--r);font-size:.79rem;font-weight:600;
  border:none;cursor:pointer;transition:all .12s;white-space:nowrap;font-family:inherit;line-height:1;
}
.btn-primary{background:var(--brown);color:#fff}
.btn-primary:hover{background:var(--brown-d)}
.btn-gold{background:var(--gold);color:var(--brown-d);font-weight:700}
.btn-gold:hover{background:var(--gold-d);color:#fff}
.btn-outline{background:var(--surface);border:1px solid var(--border-d);color:var(--muted)}
.btn-outline:hover{border-color:var(--gold-d);color:var(--brown);background:var(--gold-bg)}
.btn-ghost{background:transparent;color:var(--muted);border:none}
.btn-ghost:hover{background:var(--gold-bg);color:var(--brown)}
.btn-ok     {background:var(--green-bg);color:var(--green);border:1px solid var(--green-bd)}
.btn-ok:hover{background:#DCFCE7}
.btn-err    {background:var(--red-bg);color:var(--red);border:1px solid var(--red-bd)}
.btn-err:hover{background:#FECACA}
.btn-success{background:var(--green-bg);color:var(--green);border:1px solid var(--green-bd)}
.btn-success:hover{background:#DCFCE7}
.btn-danger {background:var(--red-bg);color:var(--red);border:1px solid var(--red-bd)}
.btn-danger:hover{background:#FECACA}
.btn-amber  {background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-bd)}
.btn-amber:hover{background:#FDE68A}
.btn-sm{padding:6px 13px;font-size:.74rem;border-radius:7px}
.btn-xs{padding:4px 9px;font-size:.68rem;border-radius:6px}
.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--r);background:var(--surf2);border:1px solid var(--border-d);color:var(--muted)}
.btn-icon:hover{border-color:var(--gold-d);color:var(--brown);background:var(--gold-bg)}

/* ════════════════════ FORMULAIRES ════════════════════ */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:.72rem;font-weight:700;color:var(--muted);margin-bottom:6px;letter-spacing:.02em}
.form-ctrl{
  width:100%;padding:9px 13px;border:1px solid var(--border-d);border-radius:var(--r);
  font-size:.84rem;color:var(--text);background:var(--surface);outline:none;
  transition:border-color .12s,box-shadow .12s;
}
.form-ctrl:focus{border-color:var(--gold-d);box-shadow:0 0 0 3px rgba(201,169,110,.15)}
.form-ctrl::placeholder{color:var(--light)}
select.form-ctrl{cursor:pointer}

/* ════════════════════ FILTRES PILLS ════════════════════ */
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.filter-pill{
  padding:6px 15px;border-radius:99px;font-size:.75rem;font-weight:600;
  border:1px solid var(--border-d);color:var(--muted);background:var(--surface);
  transition:all .12s;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:5px;
}
.filter-pill:hover{border-color:var(--gold-d);color:var(--brown);background:var(--gold-bg)}
.filter-pill.on{background:var(--brown);color:#fff;border-color:var(--brown)}
.filter-pill .pill-count{
  background:rgba(255,255,255,.25);color:inherit;
  font-size:.6rem;padding:1px 6px;border-radius:99px;font-weight:700;
}
.filter-pill:not(.on) .pill-count{background:var(--border);color:var(--muted)}

/* ════════════════════ MODAL ════════════════════ */
.modal-ov,.modal-bg{
  position:fixed;inset:0;background:rgba(92,58,30,.28);z-index:200;
  display:none;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(3px);
}
.modal-ov.open,.modal-bg.open{display:flex}
.modal-box{
  background:var(--surface);border-radius:16px;width:100%;max-width:480px;
  max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md);
  animation:fadeUp .18s ease;border:1px solid var(--border);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px) scale(.98)}}
.modal-head{
  padding:18px 22px 14px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);background:var(--surf2);
}
.modal-title{font-size:.92rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.modal-close{background:none;border:none;color:var(--light);cursor:pointer;font-size:.9rem;padding:4px;border-radius:6px}
.modal-close:hover{background:var(--border);color:var(--text)}
.modal-body{padding:18px 22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:var(--surf2)}

/* ════════════════════ TOASTS ════════════════════ */
.toast-stack{position:fixed;bottom:22px;right:22px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  display:flex;align-items:center;gap:9px;padding:11px 16px;border-radius:10px;
  font-size:.8rem;font-weight:600;box-shadow:var(--shadow-md);pointer-events:all;
  animation:slideIn .18s ease;min-width:220px;border:1px solid;
}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}}
.toast.ok  {background:var(--green-bg);color:var(--green);border-color:var(--green-bd)}
.toast.err {background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}
.toast.warn{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-bd)}
.toast.info{background:var(--surface);color:var(--text);border-color:var(--border)}

/* ════════════════════ EMPTY STATE ════════════════════ */
.empty-state{text-align:center;padding:52px 20px;color:var(--light)}
.empty-state i{font-size:2.2rem;margin-bottom:14px;display:block;opacity:.22}
.empty-state h3{font-size:.94rem;font-weight:700;color:var(--muted);margin-bottom:6px}
.empty-state p{font-size:.78rem}

/* ════════════════════ GRILLES ════════════════════ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.col-main{display:grid;grid-template-columns:1fr 290px;gap:18px;align-items:start}

/* ════════════════════ AVATAR ════════════════════ */
.avatar{
  width:32px;height:32px;border-radius:50%;background:var(--gold-bg);color:var(--brown);
  display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;
  flex-shrink:0;border:1px solid var(--border-d);
}

/* ════════════════════ UTILITAIRES ════════════════════ */
.text-muted{color:var(--muted)!important}
.text-light{color:var(--light)!important}
.text-gold{color:var(--gold-d)}
.text-brown{color:var(--brown)}
.font-mono{font-family:'Courier New',monospace;font-size:.88em}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-16{margin-top:16px}
.mt-20{margin-top:20px}

/* ══════════════════════════════════════════════════════
   RESPONSIVE — Mobile-first
   ══════════════════════════════════════════════════════ */

/* ── Topbar mobile fixe ── */
.mob-topbar {
  display:none;
  position:fixed;top:0;left:0;right:0;height:52px;
  background:var(--surface);border-bottom:1px solid var(--border);
  z-index:180;
  align-items:center;justify-content:space-between;
  padding:0 14px 0 16px;
  box-shadow:0 1px 6px rgba(92,58,30,.07);
}
.mob-topbar-title {
  font-size:.88rem;font-weight:700;color:var(--text);
  display:flex;align-items:center;gap:7px;
}
.mob-topbar-title i { color:var(--gold-d);font-size:.82rem; }
.mob-burger {
  width:36px;height:36px;border-radius:9px;
  background:var(--sb-bg);border:none;color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;cursor:pointer;flex-shrink:0;
}

/* ── 900px : sidebar cachée ── */
@media(max-width:900px){
  :root{--sb-w:0px}
  .sidebar{
    transform:translateX(-100%);
    transition:transform .25s cubic-bezier(.4,0,.2,1);
    width:260px!important; /* fixe, pas --sb-w qui vaut 0 sur mobile */
    box-shadow:var(--shadow-lg);
  }
  .sidebar.open{transform:translateX(0);z-index:300}
  .main{margin-left:0;padding-top:52px} /* hauteur du mob-topbar */
  .topbar{display:none} /* masquer le topbar de bureau */
  .mob-topbar{display:flex}
  .col-main{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .kpi-grid[style*="repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  .kpi-grid[style*="repeat(5"]{grid-template-columns:repeat(3,1fr)!important}
  .kpi-grid[style*="repeat(3"]{grid-template-columns:repeat(3,1fr)!important}
  .content{padding:14px}
  .sidebar-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.4);z-index:250;
  }
  .sidebar-overlay.open{display:block}
}

/* ── 640px : KPIs 2×2 ── */
@media(max-width:640px){
  .content{padding:12px}
  .kpi-grid{grid-template-columns:1fr 1fr!important}
  .kpi-card{padding:12px;gap:10px}
  .kpi-val{font-size:1.2rem}
  .kpi-lbl{font-size:.62rem}
  .mob-hide{display:none!important}

  /* Messages + Demandes footer — TOUJOURS sur une ligne */
  .msg-footer,.dem-footer{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:space-between!important;
    flex-wrap:nowrap!important;
    gap:6px;padding:10px 14px;
  }
  .msg-left,.msg-right,
  .dem-actions,.dem-right{
    display:flex;flex-wrap:wrap;gap:4px;align-items:center;
  }
  .msg-left,.dem-actions{flex-shrink:0}
  .msg-right,.dem-right{flex-shrink:0}
}

/* ── 480px ── */
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr!important}
  .kpi-card{padding:10px;gap:8px}
  .kpi-ico{width:32px;height:32px;font-size:.78rem}
  .kpi-val{font-size:1.1rem}
}

/* ══════════════════════════════════════════════════════
   MOB-CARD — Chaque <tr> devient un bloc carte indépendant
   Usage: class="mob-card" sur <table>
          data-label="..." sur chaque <td> sauf le 1er
   ══════════════════════════════════════════════════════ */
@media(max-width:900px){

  /* Conteneur devient flex vertical avec GAPS = blocs séparés */
  .mob-card { width:100%; border-collapse:separate; }
  .mob-card thead { display:none; }
  .mob-card tbody {
    display:flex;
    flex-direction:column;
    gap:10px;        /* ← C'est ce gap qui sépare les blocs */
    width:100%;
  }

  /* Chaque ligne = carte indépendante */
  .mob-card tbody tr {
    display:block;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    overflow:hidden;
    box-shadow:var(--shadow);
    /* IMPORTANT: pas de margin — le gap du tbody suffit */
  }
  .mob-card tbody tr:hover td { background:transparent; }

  /* Chaque td = ligne label | valeur */
  .mob-card tbody td {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:9px 14px;
    border-bottom:1px solid var(--border);
    font-size:.8rem;
    min-height:40px;
    box-sizing:border-box;
    width:100%;
  }
  .mob-card tbody td:last-child { border-bottom:none; }

  /* Label automatique */
  .mob-card tbody td[data-label]::before {
    content:attr(data-label);
    font-size:.62rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.05em;
    color:var(--muted);
    flex-shrink:0;min-width:68px;line-height:1.2;
  }

  /* Premier td = en-tête du bloc */
  .mob-card tbody td:first-child {
    background:var(--surf2);
    padding:11px 14px;
    font-weight:600;
    justify-content:flex-start;
    gap:10px;min-height:46px;
    border-radius:var(--r-lg) var(--r-lg) 0 0;
  }
  .mob-card tbody td:first-child::before { display:none; }

  /* Dernier td = actions — tout sur une ligne */
  .mob-card tbody td:last-child {
    flex-wrap:nowrap;          /* une seule ligne */
    gap:6px;
    justify-content:space-between;
    align-items:center;
    padding:10px 14px;
    min-height:auto;
    overflow:visible;
  }
  /* Label "Actions" à gauche, boutons à droite — même ligne */
  .mob-card tbody td:last-child[data-label]::before {
    width:auto;             /* pas de width:100% qui forcerait un saut */
    flex-shrink:0;
    margin-bottom:0;
  }
  /* Groupe de boutons à droite */
  .mob-card tbody td:last-child > div,
  .mob-card tbody td:last-child > a,
  .mob-card tbody td:last-child > button,
  .mob-card tbody td:last-child > span {
    flex-shrink:0;
  }
  /* Wrapper des boutons — pas de wrap */
  .mob-card tbody td:last-child > div {
    display:flex;gap:5px;flex-wrap:nowrap;align-items:center;
    margin-left:auto;
  }

  /* Supprimer overflow-x sur le wrapper — inutile en mob-card */
  .mob-card-wrap { overflow-x:visible!important; }

  /* Colonnes cachées */
  .mob-card .mob-hide { display:none!important; }
}

/* ── Sur mobile, le wrapper overflow ne bloque plus les blocs ── */
@media(max-width:640px){
  .mob-card-wrap{overflow-x:visible!important;overflow:visible!important}
  /* Séparateur fin entre les td (lignes internes) */
  .mob-card tbody td{border-bottom:1px solid var(--border)}
}

/* ── Messages footer — toujours sur 1 ligne, wrap naturel ── */
.msg-footer{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}
.msg-left{display:flex;gap:5px;align-items:center;flex-wrap:wrap;flex:1}
.msg-right{display:flex;gap:5px;align-items:center;flex-wrap:wrap;justify-content:flex-end}

/* ── Demandes footer — idem ── */
.dem-footer{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}
.dem-actions{display:flex;gap:5px;align-items:center;flex-wrap:wrap;flex:1}
.dem-right{display:flex;gap:5px;align-items:center;flex-wrap:wrap;justify-content:flex-end}