/* ============================================================
   TableFlow v7 — Design System Complet
   Police: Plus Jakarta Sans | Icons: Bootstrap Icons 1.11
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── VARIABLES ── */
:root {
  --bg:       #0b0b12;
  --surface:  #12121c;
  --s2:       #1a1a27;
  --s3:       #222233;
  --border:   rgba(255,255,255,.08);
  --accent:   #e63946;
  --a-dark:   #b91c28;
  --a-glow:   rgba(230,57,70,.18);
  --yellow:   #fbbf24;
  --green:    #22c55e;
  --blue:     #3b82f6;
  --purple:   #8b5cf6;
  --red:      #ef4444;
  --text:     #f1f1f8;
  --text2:    #c8c8d8;
  --muted:    #64648a;
  --r:        12px;
  --r-sm:     8px;
  --r-lg:     16px;
  --sidebar:  252px;
  --font:     'Plus Jakarta Sans', system-ui, sans-serif;
  --shadow:   0 4px 24px rgba(0,0,0,.45);
  --shadow-sm:0 2px 10px rgba(0,0,0,.3);
}

/* ── BASE ── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--bg); color:var(--text); min-height:100vh; display:flex; font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased; }
h1,h2,h3,h4,h5 { line-height:1.2; font-weight:800; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; }
button { font-family:var(--font); }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--s3); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--muted); }

/* ── SIDEBAR ── */
.sidebar {
  width:var(--sidebar); background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column; position:fixed; top:0; left:0; bottom:0;
  z-index:100; overflow-y:auto; transition:transform .28s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.sidebar-brand {
  display:flex; align-items:center; gap:10px; padding:20px 18px 16px;
  border-bottom:1px solid var(--border);
}
.brand-icon {
  width:36px; height:36px; background:var(--accent); border-radius:10px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:0 4px 14px rgba(230,57,70,.4);
}
.brand-icon i { color:#fff; font-size:1rem; }
.brand-name { font-size:1.15rem; font-weight:800; letter-spacing:-.02em; }
.brand-name span { color:var(--accent); }

.sidebar-resto {
  margin:12px 12px 6px; background:var(--s2); border:1px solid var(--border);
  border-radius:var(--r); padding:11px 12px; display:flex; align-items:center; gap:9px;
}
.resto-avatar {
  width:30px; height:30px; border-radius:8px; display:flex; align-items:center;
  justify-content:center; font-weight:800; font-size:.82rem; color:#fff; flex-shrink:0;
}
.resto-name  { font-size:.85rem; font-weight:700; color:var(--text); line-height:1.2; }
.resto-city  { font-size:.7rem; color:var(--muted); margin-top:1px; }

.nav-section { padding:8px 10px 4px; }
.nav-section-label { font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); padding:0 8px; margin-bottom:4px; }

.nav-item {
  display:flex; align-items:center; gap:10px; padding:9px 12px;
  border-radius:var(--r-sm); font-size:.85rem; color:var(--muted);
  transition:background .15s, color .15s; cursor:pointer; position:relative;
  font-weight:500;
}
.nav-item i { font-size:1rem; width:20px; text-align:center; flex-shrink:0; }
.nav-item:hover { background:var(--s2); color:var(--text2); }
.nav-item.active { background:var(--a-glow); color:var(--accent); font-weight:700; }
.nav-item.active i { color:var(--accent); }
.nav-badge {
  margin-left:auto; background:var(--accent); color:#fff;
  border-radius:20px; padding:2px 8px; font-size:.65rem; font-weight:800; min-width:20px; text-align:center;
  animation:badgePop .2s ease;
}
@keyframes badgePop { from{transform:scale(.7)} to{transform:scale(1)} }
.nav-divider { height:1px; background:var(--border); margin:6px 12px; }

.sidebar-footer {
  padding:12px; border-top:1px solid var(--border); margin-top:auto;
}
.user-card {
  display:flex; align-items:center; gap:10px; padding:9px 10px;
  border-radius:var(--r-sm); transition:.15s; text-decoration:none; margin-bottom:8px;
}
.user-card:hover { background:var(--s2); }
.user-av {
  width:34px; height:34px; border-radius:50%; background:var(--accent);
  display:flex; align-items:center; justify-content:center; font-weight:800;
  font-size:.85rem; color:#fff; flex-shrink:0;
}
.user-nm { font-size:.83rem; font-weight:700; color:var(--text); line-height:1.2; }
.user-rl { font-size:.68rem; color:var(--muted); text-transform:capitalize; }
.btn-logout {
  display:flex; align-items:center; justify-content:center; gap:7px;
  width:100%; padding:9px; border-radius:var(--r-sm); background:var(--s2);
  font-size:.82rem; color:var(--muted); transition:.15s; border:1px solid var(--border);
  cursor:pointer; font-family:var(--font); font-weight:600;
}
.btn-logout:hover { background:rgba(230,57,70,.12); color:var(--accent); border-color:rgba(230,57,70,.3); }
.btn-logout i { font-size:.9rem; }

/* ── MAIN CONTENT ── */
.main-content { margin-left:var(--sidebar); flex:1; padding:28px 28px 40px; min-height:100vh; }

/* ── MOBILE TOPBAR ── */
.mobile-bar {
  display:none; position:sticky; top:0; z-index:50;
  background:var(--surface); border-bottom:1px solid var(--border);
  padding:12px 16px; align-items:center; justify-content:space-between;
  gap:12px; backdrop-filter:blur(10px);
}
.mobile-bar-brand { font-size:1rem; font-weight:800; }
.mobile-bar-brand span { color:var(--accent); }
.hamburger { background:var(--s2); border:1px solid var(--border); color:var(--text); padding:7px 10px; border-radius:var(--r-sm); cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; }
.hamburger:hover { background:var(--s3); }
.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:99; backdrop-filter:blur(2px); }
.sidebar-overlay.open { display:block; }

/* ── PAGE HEADER ── */
.page-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  margin-bottom:24px; gap:16px; flex-wrap:wrap;
}
.page-header-left { flex:1; min-width:0; }
.page-title {
  font-size:1.4rem; font-weight:800; color:var(--text);
  display:flex; align-items:center; gap:10px; line-height:1.2;
}
.page-title i { color:var(--accent); font-size:1.2rem; }
.page-sub { font-size:.8rem; color:var(--muted); margin-top:4px; }
.page-actions { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

/* ── REFRESH BAR ── */
.refresh-bar { height:2px; background:var(--s2); margin:-28px -28px 24px; position:relative; overflow:hidden; }
.refresh-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--yellow)); transition:width 1s linear; }

/* ── STAT CARDS ── */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:22px; }
.stat-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:18px 16px; position:relative; overflow:hidden; transition:.2s;
}
.stat-card:hover { border-color:rgba(255,255,255,.14); transform:translateY(-1px); }
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
}
.stat-red::before    { background:linear-gradient(90deg,var(--accent),#ff6b6b); }
.stat-yellow::before { background:linear-gradient(90deg,var(--yellow),#fde68a); }
.stat-green::before  { background:linear-gradient(90deg,var(--green),#86efac); }
.stat-blue::before   { background:linear-gradient(90deg,var(--blue),#93c5fd); }
.stat-icon-wrap {
  width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-size:1.15rem; margin-bottom:12px;
}
.stat-red    .stat-icon-wrap { background:rgba(230,57,70,.15);   color:var(--accent); }
.stat-yellow .stat-icon-wrap { background:rgba(251,191,36,.15);  color:var(--yellow); }
.stat-green  .stat-icon-wrap { background:rgba(34,197,94,.15);   color:var(--green); }
.stat-blue   .stat-icon-wrap { background:rgba(59,130,246,.15);  color:var(--blue); }
.stat-label  { font-size:.72rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.07em; margin-bottom:5px; }
.stat-value  { font-size:1.75rem; font-weight:800; color:var(--text); line-height:1; }
.stat-delta  { font-size:.72rem; color:var(--green); margin-top:6px; display:flex; align-items:center; gap:3px; }

/* ── CARDS ── */
.card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r);
  padding:20px; margin-bottom:14px;
}
.card:last-child { margin-bottom:0; }
.card-header {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-bottom:16px; flex-wrap:wrap;
}
.card-title {
  font-size:.92rem; font-weight:700; color:var(--text);
  display:flex; align-items:center; gap:7px;
}
.card-title i { color:var(--accent); font-size:.95rem; }

/* ── GRILLES ── */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }

/* ── BOUTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:6px; padding:9px 17px;
  border-radius:var(--r-sm); border:none; font-family:var(--font); font-size:.84rem;
  font-weight:600; cursor:pointer; transition:.18s; white-space:nowrap; line-height:1;
  text-decoration:none;
}
.btn i { font-size:.88rem; line-height:1; }
.btn:disabled { opacity:.45; cursor:not-allowed; }
.btn-primary  { background:var(--accent); color:#fff; box-shadow:0 2px 10px rgba(230,57,70,.3); }
.btn-primary:hover:not(:disabled) { background:var(--a-dark); box-shadow:0 4px 18px rgba(230,57,70,.4); }
.btn-success  { background:var(--green); color:#0b0b12; }
.btn-success:hover:not(:disabled) { filter:brightness(1.1); }
.btn-warning  { background:rgba(251,191,36,.15); color:var(--yellow); border:1px solid rgba(251,191,36,.3); }
.btn-warning:hover:not(:disabled) { background:rgba(251,191,36,.25); }
.btn-danger   { background:rgba(230,57,70,.12); color:var(--accent); border:1px solid rgba(230,57,70,.25); }
.btn-danger:hover:not(:disabled) { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-ghost    { background:var(--s2); color:var(--text2); border:1px solid var(--border); }
.btn-ghost:hover:not(:disabled) { background:var(--s3); color:var(--text); }
.btn-outline  { background:transparent; color:var(--text2); border:1px solid var(--border); }
.btn-outline:hover:not(:disabled) { border-color:var(--accent); color:var(--accent); }
.btn-sm  { padding:6px 12px; font-size:.78rem; border-radius:7px; }
.btn-xs  { padding:4px 9px;  font-size:.72rem; border-radius:6px; }
.btn-lg  { padding:12px 24px; font-size:.92rem; }
.btn-full { width:100%; justify-content:center; }
.btn-icon { width:34px; height:34px; padding:0; justify-content:center; border-radius:var(--r-sm); }
.btn-icon-sm { width:28px; height:28px; padding:0; justify-content:center; border-radius:6px; font-size:.78rem; }

/* ── FORMULAIRES ── */
.form-group { margin-bottom:14px; }
.form-group:last-child { margin-bottom:0; }
.form-label { font-size:.75rem; font-weight:600; color:var(--muted); display:block; margin-bottom:6px; text-transform:uppercase; letter-spacing:.05em; }
.form-control {
  width:100%; background:var(--s2); border:1.5px solid var(--border);
  border-radius:var(--r-sm); color:var(--text); padding:10px 13px;
  font-family:var(--font); font-size:.87rem; outline:none; transition:.18s;
  appearance:none;
}
.form-control::placeholder { color:var(--muted); }
.form-control:focus { border-color:var(--accent); background:var(--s3); box-shadow:0 0 0 3px rgba(230,57,70,.1); }
.form-control:disabled { opacity:.5; cursor:not-allowed; }
select.form-control { cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%2364648a' d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:34px; }
textarea.form-control { resize:vertical; min-height:90px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-row-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.form-helper { font-size:.72rem; color:var(--muted); margin-top:4px; }
.form-actions { display:flex; gap:10px; align-items:center; padding-top:4px; flex-wrap:wrap; }

/* Input avec icône */
.input-group { position:relative; }
.input-group i { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--muted); font-size:.9rem; pointer-events:none; }
.input-group .form-control { padding-left:38px; }

/* ── FLASH ── */
.flash {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:11px 14px; border-radius:var(--r-sm); margin-bottom:18px;
  font-size:.85rem; font-weight:500; animation:slideDown .2s ease;
}
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.flash i { font-size:.9rem; flex-shrink:0; }
.flash-close { background:none; border:none; cursor:pointer; color:inherit; opacity:.6; padding:2px; font-size:1rem; }
.flash-close:hover { opacity:1; }
.flash-success { background:rgba(34,197,94,.1);  color:var(--green); border:1px solid rgba(34,197,94,.25); }
.flash-error   { background:rgba(230,57,70,.1);  color:var(--accent); border:1px solid rgba(230,57,70,.25); }
.flash-info    { background:rgba(59,130,246,.1); color:var(--blue);   border:1px solid rgba(59,130,246,.25); }
.flash-warning { background:rgba(251,191,36,.1); color:var(--yellow); border:1px solid rgba(251,191,36,.25); }

/* ── TABLEAU ── */
.table-wrapper { overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:var(--r); }
.data-table { width:100%; border-collapse:collapse; min-width:500px; }
.data-table thead tr { border-bottom:1px solid var(--border); }
.data-table th { padding:10px 14px; font-size:.7rem; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.07em; text-align:left; white-space:nowrap; }
.data-table td { padding:12px 14px; border-bottom:1px solid var(--border); font-size:.86rem; vertical-align:middle; }
.data-table tbody tr:last-child td { border-bottom:none; }
.data-table tbody tr:hover td { background:rgba(255,255,255,.02); }
.actions { display:flex; gap:5px; align-items:center; }

/* Responsive table → cards */
@media(max-width:600px) {
  .table-responsive thead { display:none; }
  .table-responsive tr { display:block; background:var(--s2); border:1px solid var(--border); border-radius:var(--r); margin-bottom:10px; padding:12px; }
  .table-responsive td { display:flex; justify-content:space-between; align-items:center; padding:5px 0; border:none; font-size:.84rem; }
  .table-responsive td::before { content:attr(data-label); font-size:.7rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em; min-width:90px; }
  .table-responsive td.td-actions { justify-content:flex-end; padding-top:10px; border-top:1px solid var(--border); margin-top:6px; }
  .table-responsive td.td-actions::before { display:none; }
}

/* ── BADGES ── */
.badge { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:20px; font-size:.7rem; font-weight:700; white-space:nowrap; }
.badge i { font-size:.68rem; }
.badge-nouvelle    { background:rgba(230,57,70,.12);  color:var(--accent); border:1px solid rgba(230,57,70,.25); }
.badge-preparation { background:rgba(251,191,36,.12); color:var(--yellow); border:1px solid rgba(251,191,36,.25); }
.badge-prete       { background:rgba(34,197,94,.12);  color:var(--green);  border:1px solid rgba(34,197,94,.25); }
.badge-servie      { background:rgba(100,100,138,.1); color:var(--muted);  border:1px solid rgba(100,100,138,.2); }
.badge-annulee     { background:rgba(230,57,70,.06);  color:var(--muted);  border:1px solid var(--border); }
.badge-actif       { background:rgba(34,197,94,.12);  color:var(--green);  border:1px solid rgba(34,197,94,.25); }
.badge-inactif     { background:rgba(100,100,138,.1); color:var(--muted);  border:1px solid rgba(100,100,138,.2); }

/* ── TABLES VISUELLES ── */
.tables-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:10px; }
.table-card {
  border:2px solid var(--border); border-radius:var(--r); padding:14px 10px;
  text-align:center; cursor:pointer; transition:.2s; user-select:none;
}
.table-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.table-card.libre   { border-color:rgba(34,197,94,.5); }
.table-card.occupee { border-color:rgba(230,57,70,.5); }
.table-card.attente { border-color:rgba(251,191,36,.5); }
.tc-icon { font-size:1.3rem; margin-bottom:6px; }
.tc-num  { font-size:1rem; font-weight:800; margin-bottom:2px; }
.tc-zone { font-size:.66rem; color:var(--muted); }
.tc-status { font-size:.68rem; font-weight:700; margin-top:5px; }
.table-card.libre   .tc-status { color:var(--green); }
.table-card.occupee .tc-status { color:var(--accent); }
.table-card.attente .tc-status { color:var(--yellow); }

/* ── KANBAN CUISINE ── */
.kanban { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.k-col  { display:flex; flex-direction:column; gap:10px; overflow-y:auto; }
.k-col-header {
  font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em;
  padding:8px 13px; border-radius:var(--r-sm); text-align:center; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; gap:7px;
}
.kh-red    { background:rgba(230,57,70,.12);  color:var(--accent); border:1px solid rgba(230,57,70,.2); }
.kh-yellow { background:rgba(251,191,36,.12); color:var(--yellow); border:1px solid rgba(251,191,36,.2); }
.kh-green  { background:rgba(34,197,94,.12);  color:var(--green);  border:1px solid rgba(34,197,94,.2); }
.kh-badge  { background:rgba(0,0,0,.35); border-radius:20px; padding:1px 7px; font-size:.65rem; font-weight:800; }

.ticket {
  background:var(--s2); border:1.5px solid var(--border); border-radius:var(--r);
  padding:13px; animation:fadeUp .2s ease; transition:.2s;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(7px)} to{opacity:1;transform:none} }
.ticket.urgent { border-color:rgba(230,57,70,.6); box-shadow:0 0 0 2px rgba(230,57,70,.12); }
.ticket-hd { display:flex; justify-content:space-between; align-items:center; margin-bottom:9px; }
.ticket-table { font-weight:800; font-size:.92rem; display:flex; align-items:center; gap:6px; }
.ticket-time { font-size:.72rem; color:var(--muted); display:flex; align-items:center; gap:4px; }
.ticket-time.late { color:var(--accent); font-weight:700; }
.ticket-items { display:flex; flex-direction:column; gap:5px; margin-bottom:10px; }
.ticket-line { display:flex; gap:8px; font-size:.83rem; align-items:baseline; }
.t-qty { font-weight:800; min-width:24px; }
.t-note-line { font-size:.73rem; color:var(--yellow); padding-left:30px; }
.client-note { background:rgba(251,191,36,.07); border:1px solid rgba(251,191,36,.2); border-radius:var(--r-sm); padding:7px 10px; font-size:.76rem; color:var(--yellow); margin-bottom:9px; display:flex; gap:7px; align-items:flex-start; }
.empty-col { text-align:center; padding:28px 16px; color:var(--muted); font-size:.82rem; border:1px dashed rgba(255,255,255,.06); border-radius:var(--r); }
.empty-col i { font-size:1.8rem; display:block; margin-bottom:8px; opacity:.3; }

/* ── MODAL ── */
.modal-bg {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.72); z-index:300;
  align-items:center; justify-content:center; padding:16px;
  backdrop-filter:blur(4px);
}
.modal-bg.open { display:flex; animation:fadeIn .18s ease; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.modal-box {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:26px; width:100%; max-width:490px; max-height:90vh; overflow-y:auto;
  position:relative; animation:modalIn .2s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 24px 60px rgba(0,0,0,.6);
}
@keyframes modalIn { from{transform:scale(.95) translateY(10px);opacity:0} to{transform:none;opacity:1} }
.modal-title { font-size:1rem; font-weight:800; margin-bottom:20px; display:flex; align-items:center; gap:8px; }
.modal-title i { color:var(--accent); }
.modal-close {
  position:absolute; top:16px; right:16px; background:var(--s2);
  border:1px solid var(--border); color:var(--muted); width:30px; height:30px;
  border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:.85rem; transition:.15s;
}
.modal-close:hover { color:var(--text); background:var(--s3); }

/* ── CART MODAL ── */
.cart-line { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border); font-size:.86rem; gap:10px; }
.cart-line:last-child { border-bottom:none; }
.cart-total { display:flex; justify-content:space-between; align-items:center; padding:13px 0 6px; font-weight:800; font-size:1.05rem; }

/* ── IMAGE UPLOAD ── */
.img-upload-zone {
  width:100%; height:160px; background:var(--s2); border-radius:var(--r);
  display:flex; align-items:center; justify-content:center; flex-direction:column;
  gap:8px; border:2px dashed var(--border); cursor:pointer; transition:.2s; overflow:hidden; position:relative;
}
.img-upload-zone:hover { border-color:var(--accent); background:var(--s3); }
.img-upload-zone img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.img-upload-zone .overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center; gap:6px; color:#fff; font-size:.82rem; font-weight:600; opacity:0; transition:.2s; }
.img-upload-zone:hover .overlay { opacity:1; }
.img-placeholder { display:flex; flex-direction:column; align-items:center; gap:7px; color:var(--muted); }
.img-placeholder i { font-size:2rem; opacity:.5; }
.img-placeholder span { font-size:.78rem; }

/* ── LIVE ── */
.live-badge {
  display:inline-flex; align-items:center; gap:5px; font-size:.74rem; font-weight:700;
  color:var(--green); background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.2);
  border-radius:20px; padding:4px 10px;
}
.live-dot { width:6px; height:6px; background:var(--green); border-radius:50%; animation:blink 1.5s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ── EMPTY STATE ── */
.empty-state { text-align:center; padding:40px 20px; color:var(--muted); }
.empty-state i { font-size:2.5rem; display:block; margin-bottom:12px; opacity:.3; }
.empty-state p { font-size:.88rem; line-height:1.7; }
.empty-state a, .empty-state .btn { margin-top:14px; }

/* ── FILTRE TABS ── */
.filter-tabs { display:flex; gap:4px; background:var(--s2); padding:4px; border-radius:var(--r-sm); flex-wrap:wrap; }
.filter-tab {
  padding:6px 14px; border-radius:6px; border:none; background:transparent;
  color:var(--muted); font-size:.79rem; font-weight:600; cursor:pointer; transition:.15s;
  display:inline-flex; align-items:center; gap:5px; font-family:var(--font); white-space:nowrap;
}
.filter-tab.active { background:var(--accent); color:#fff; box-shadow:0 2px 8px rgba(230,57,70,.3); }
.filter-tab:hover:not(.active) { color:var(--text); background:var(--s3); }
.filter-count { background:rgba(255,255,255,.2); border-radius:10px; padding:0 6px; font-size:.65rem; }
.filter-tab:not(.active) .filter-count { background:var(--s3); color:var(--muted); }

/* ── CAT BAR ── */
.cat-bar { display:flex; gap:7px; overflow-x:auto; padding-bottom:6px; -webkit-overflow-scrolling:touch; }
.cat-bar::-webkit-scrollbar { height:3px; }
.cat-pill {
  display:inline-flex; align-items:center; gap:5px; padding:7px 14px;
  border-radius:20px; border:1.5px solid var(--border); font-size:.8rem; font-weight:600;
  white-space:nowrap; cursor:pointer; background:transparent; color:var(--text2);
  transition:.18s; font-family:var(--font); flex-shrink:0;
}
.cat-pill:hover { border-color:rgba(255,255,255,.2); color:var(--text); }
.cat-pill.active { color:#fff; border-color:transparent; }

/* ── PLAT CARDS ── */
.plat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:13px; }
.plat-card { background:var(--s2); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; transition:.2s; }
.plat-card:hover { border-color:rgba(255,255,255,.16); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.plat-img { height:130px; background:var(--s3); display:flex; align-items:center; justify-content:center; font-size:2.5rem; overflow:hidden; position:relative; }
.plat-img img { width:100%; height:100%; object-fit:cover; }
.plat-img-badge { position:absolute; top:7px; right:7px; font-size:.63rem; font-weight:800; padding:2px 7px; border-radius:20px; }
.plat-body { padding:12px; }
.plat-name { font-weight:700; font-size:.87rem; line-height:1.3; margin-bottom:3px; }
.plat-desc { font-size:.73rem; color:var(--muted); line-height:1.4; margin-bottom:8px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.plat-footer { display:flex; justify-content:space-between; align-items:center; margin-bottom:9px; }
.plat-price { font-weight:800; font-size:.9rem; color:var(--yellow); }
.plat-time { font-size:.7rem; color:var(--muted); display:flex; align-items:center; gap:3px; }
.plat-actions { display:flex; gap:5px; }
.plat-actions .btn { flex:1; justify-content:center; }

/* ── ICON PICKER ── */
.icon-picker-grid { display:grid; grid-template-columns:repeat(8,1fr); gap:5px; }
.icon-opt {
  width:36px; height:36px; border-radius:7px; border:1.5px solid var(--border);
  background:var(--s2); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:.15s; font-size:1rem; color:var(--muted);
}
.icon-opt:hover { border-color:rgba(255,255,255,.25); color:var(--text); background:var(--s3); }
.icon-opt.selected { border-color:var(--accent); background:var(--a-glow); color:var(--accent); }

/* ── CLIENT MENU ── */
body.client { background:var(--bg); display:block; }
.client-wrap { max-width:490px; margin:0 auto; padding:14px 12px 110px; }
.resto-header { border-radius:var(--r-lg); padding:22px 18px; text-align:center; color:#fff; margin-bottom:14px; position:relative; overflow:hidden; }
.resto-header::before { content:''; position:absolute; inset:0; background:rgba(0,0,0,.15); }
.resto-header > * { position:relative; }
.rh-name { font-size:1.3rem; font-weight:800; line-height:1.2; }
.rh-sub  { font-size:.83rem; opacity:.85; margin-top:5px; display:flex; align-items:center; justify-content:center; gap:6px; }

/* Menu cards client */
.menu-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; display:flex; transition:.18s; margin-bottom:10px; }
.menu-card:hover { border-color:rgba(255,255,255,.15); }
.mc-img { width:90px; min-height:90px; flex-shrink:0; background:var(--s2); display:flex; align-items:center; justify-content:center; font-size:2rem; overflow:hidden; }
.mc-img img { width:100%; height:100%; object-fit:cover; }
.mc-body { flex:1; padding:12px; min-width:0; }
.mc-name  { font-weight:700; font-size:.91rem; line-height:1.3; margin-bottom:3px; }
.mc-desc  { font-size:.75rem; color:var(--muted); line-height:1.4; margin-bottom:7px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.mc-row   { display:flex; justify-content:space-between; align-items:center; }
.mc-price { font-weight:800; font-size:.9rem; color:var(--yellow); }
.mc-time  { font-size:.7rem; color:var(--muted); display:flex; align-items:center; gap:3px; }
.qty-ctrl { display:flex; align-items:center; gap:8px; margin-top:8px; }
.qty-btn  { width:28px; height:28px; border-radius:50%; border:none; background:var(--s2); color:var(--text); font-size:.85rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.15s; }
.qty-btn:hover { color:#fff; }
.qty-num  { font-weight:800; min-width:18px; text-align:center; font-size:.9rem; }

/* Page tabs client */
.page-tabs { display:flex; background:var(--s2); border-radius:var(--r); padding:4px; gap:3px; margin-bottom:14px; position:sticky; top:6px; z-index:20; box-shadow:0 4px 16px rgba(0,0,0,.5); }
.page-tab  { flex:1; padding:10px 6px; border:none; border-radius:9px; background:transparent; color:var(--muted); font-family:var(--font); font-size:.78rem; font-weight:700; cursor:pointer; transition:.18s; display:flex; flex-direction:column; align-items:center; gap:3px; }
.page-tab i { font-size:1.05rem; }
.page-tab.active { color:#fff; box-shadow:0 2px 12px rgba(0,0,0,.35); }
.tab-page { display:none; animation:fadeUp .22s ease; }
.tab-page.active { display:block; }
@keyframes fadeUp { from{opacity:0;transform:translateY(7px)} to{opacity:1;transform:none} }

/* Cart float */
.cart-float {
  position:fixed; bottom:16px; left:50%; transform:translateX(-50%);
  border-radius:14px; padding:13px 20px; display:flex; justify-content:space-between; align-items:center;
  min-width:310px; max-width:calc(100vw - 24px); cursor:pointer;
  transition:.3s; border:none; color:#fff; z-index:50; font-family:var(--font);
  box-shadow:0 8px 28px rgba(0,0,0,.55);
}
.cart-float.hidden { opacity:0; pointer-events:none; transform:translateX(-50%) translateY(16px); }

/* ── JEU QUIZ ── */
.quiz-wrap { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:18px; }
.quiz-score-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; flex-wrap:wrap; gap:6px; }
.quiz-pill { background:var(--s2); border-radius:20px; padding:5px 13px; font-size:.81rem; font-weight:700; display:inline-flex; align-items:center; gap:5px; }
.prog-bg { height:4px; background:var(--s2); border-radius:4px; margin-bottom:14px; overflow:hidden; }
.prog-fill { height:100%; border-radius:4px; transition:width .4s ease; }
.q-card { background:var(--s2); border-radius:var(--r); padding:16px; margin-bottom:12px; }
.q-img { width:100%; height:150px; object-fit:cover; border-radius:var(--r-sm); margin-bottom:10px; display:none; }
.q-img.loaded { display:block; }
.q-text { font-weight:700; font-size:.92rem; line-height:1.5; margin-bottom:13px; display:flex; align-items:flex-start; gap:8px; }
.q-text i { color:var(--accent); flex-shrink:0; margin-top:2px; }
.opts { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.opt { padding:11px 9px; border-radius:9px; border:1.5px solid var(--border); background:transparent; color:var(--text); font-family:var(--font); font-size:.82rem; font-weight:500; cursor:pointer; transition:.18s; text-align:center; line-height:1.4; }
.opt:hover:not(:disabled) { border-color:rgba(255,255,255,.25); background:var(--s3); }
.opt.correct { background:rgba(34,197,94,.15); border-color:var(--green); color:var(--green); font-weight:700; }
.opt.wrong   { background:rgba(230,57,70,.12); border-color:var(--accent); color:var(--accent); }
.opt:disabled { cursor:not-allowed; }
.q-result-ok { padding:9px 13px; border-radius:var(--r-sm); background:rgba(34,197,94,.1); color:var(--green); font-size:.84rem; font-weight:700; margin:8px 0; display:flex; align-items:center; gap:7px; }
.q-result-ko { padding:9px 13px; border-radius:var(--r-sm); background:rgba(230,57,70,.1); color:var(--accent); font-size:.84rem; font-weight:700; margin:8px 0; display:flex; align-items:center; gap:7px; }

/* ── SERVEUR ── */
.order-layout { display:grid; grid-template-columns:1fr 340px; gap:16px; align-items:start; }
.menu-row { display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--border); }
.menu-row:last-child { border-bottom:none; }
.mr-img { width:52px; height:52px; border-radius:var(--r-sm); background:var(--s2); display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; }
.mr-img img { width:100%; height:100%; object-fit:cover; }
.mr-img i { color:var(--muted); font-size:1.3rem; }
.qty-sm-input { width:54px; text-align:center; padding:7px 6px; background:var(--s2); border:1.5px solid var(--border); border-radius:var(--r-sm); color:var(--text); font-family:var(--font); font-size:.87rem; }
.qty-sm-input:focus { border-color:var(--accent); outline:none; }
.order-panel { position:sticky; top:16px; }
.table-selector { display:grid; grid-template-columns:repeat(3,1fr); gap:7px; margin-bottom:14px; }
.ts-btn { padding:9px 6px; border-radius:var(--r-sm); border:1.5px solid var(--border); background:transparent; color:var(--text); cursor:pointer; font-family:var(--font); font-size:.78rem; text-align:center; transition:.18s; }
.ts-btn:hover { border-color:rgba(255,255,255,.2); }
.ts-btn.selected { background:var(--a-glow); border-color:var(--accent); color:var(--accent); font-weight:800; }
.ts-btn.occupee { border-color:rgba(230,57,70,.3); opacity:.7; }
.ts-btn.attente  { border-color:rgba(251,191,36,.35); }
.summary-item { display:flex; justify-content:space-between; align-items:center; padding:7px 0; border-bottom:1px solid var(--border); font-size:.85rem; gap:10px; }
.summary-item:last-child { border-bottom:none; }
.summary-total { display:flex; justify-content:space-between; padding:12px 0 0; font-weight:800; font-size:1.05rem; }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .order-layout { grid-template-columns:1fr; }
  .order-panel { position:static; }
}
@media(max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); box-shadow:var(--shadow); }
  .main-content { margin-left:0; padding:0; }
  .mobile-bar { display:flex; }
  .page-content { padding:16px 14px 32px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
  .kanban { grid-template-columns:1fr; }
  .form-row, .form-row-3 { grid-template-columns:1fr; }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .filter-tabs { overflow-x:auto; flex-wrap:nowrap; }
  .refresh-bar { margin:-16px -14px 16px; }
  .page-header { gap:12px; }
  .plat-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:480px) {
  .stats-row { grid-template-columns:1fr 1fr; gap:10px; }
  .stat-value { font-size:1.4rem; }
  .tables-grid { grid-template-columns:repeat(3,1fr); }
  .plat-grid { grid-template-columns:1fr 1fr; }
  .modal-box { padding:18px; border-radius:var(--r); }
}

/* ── UTILITAIRES ── */
.mt-0{margin-top:0}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.gap-8{gap:8px}.gap-12{gap:12px}
.text-muted{color:var(--muted)}.text-green{color:var(--green)}.text-red{color:var(--accent)}.text-yellow{color:var(--yellow)}
.font-bold{font-weight:700}.font-black{font-weight:800}
.d-flex{display:flex}.align-center{align-items:center}.justify-between{justify-content:space-between}
.spin { animation:spinAnim .6s linear infinite; display:inline-block; }
@keyframes spinAnim { to{transform:rotate(360deg)} }

/* ============================================================
   Responsive Gérant — Compléments v7
   ============================================================ */

/* Page content wrapper adaptatif */
.page-content { padding: 24px 28px 40px; }

/* Stat cards 2 colonnes sur mobile */
@media(max-width:600px) {
  .stats-row { grid-template-columns: 1fr 1fr !important; gap: 10px; }
  .stat-value { font-size: 1.35rem; }
  .stat-icon-wrap { width: 34px; height: 34px; font-size: 1rem; margin-bottom: 8px; }
  .page-content { padding: 14px 13px 32px; }
  .page-header { gap: 10px; }
  .page-title { font-size: 1.15rem; }
  .page-actions { gap: 6px; }
  .page-actions .btn { padding: 7px 11px; font-size: .78rem; }
  .card { padding: 14px; }
  .card-header { flex-wrap: wrap; gap: 8px; }
  .filter-tabs { gap: 3px; }
  .filter-tab { padding: 6px 10px; font-size: .75rem; }
  .modal-box { padding: 18px 16px; max-height: 95vh; }
  .form-row { grid-template-columns: 1fr; }
  .plat-grid { grid-template-columns: 1fr; }
}

/* Tables visuelles responsive */
@media(max-width:480px) {
  .tables-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .table-card { padding: 11px 6px; }
  .tc-num { font-size: .9rem; }
  .tc-zone { font-size: .6rem; }
  .tc-status { font-size: .62rem; }
}

/* Commandes responsive */
@media(max-width:700px) {
  .data-table.table-responsive thead { display: none; }
  .data-table.table-responsive tr { display: block; background: var(--s2); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 10px; padding: 12px; }
  .data-table.table-responsive td { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; border: none; font-size: .84rem; }
  .data-table.table-responsive td::before { content: attr(data-label); font-size: .69rem; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; min-width: 80px; flex-shrink: 0; }
  .data-table.table-responsive td.td-actions { justify-content: flex-end; padding-top: 10px; border-top: 1px solid var(--border); margin-top: 6px; }
  .data-table.table-responsive td.td-actions::before { display: none; }
}

/* Dashboard grid sur mobile */
@media(max-width:768px) {
  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .refresh-bar { margin: -14px -13px 14px; }
}

/* Kanban cuisine responsive */
@media(max-width:768px) {
  .kanban { grid-template-columns: 1fr !important; }
}

/* Ordre layout serveur responsive */
@media(max-width:900px) {
  .order-layout { grid-template-columns: 1fr; }
  .order-panel { position: static !important; }
}

/* Fix overflow mobile global */
@media(max-width:768px) {
  body { overflow-x: hidden; }
  .main-content { overflow-x: hidden; }
}

/* Admin tabs responsive */
@media(max-width:600px) {
  .tab-nav { gap: 2px; }
  .tab-btn { padding: 7px 10px; font-size: .76rem; }
  .sec-stats { grid-template-columns: 1fr 1fr; }
}

/* Sidebar fermée par défaut sur mobile — bouton d'accès rapide flottant */
@media(max-width:768px) {
  .main-content { padding: 0; }
}
