/* ══════════════════════════════════════════════════════════════════
   EWYB Manager — Design System v2.1
   Tokens raffinés · sparklines · microinteractions · dark polish
   Rétro-compatible v2.0
   ══════════════════════════════════════════════════════════════════ */

/* ── 0. Tokens ─────────────────────────────────────────────────── */
:root {
  --s-0:#ffffff; --s-1:#fafaf9; --s-2:#f4f4f5; --s-3:#e7e5e4; --s-4:#d6d3d1;
  --ink-0:#09090b; --ink-1:#27272a; --ink-2:#52525b; --ink-3:#71717a; --ink-4:#a1a1aa;

  --brand:#0a0a0a; --brand-ink:#ffffff; --brand-hov:#1c1c1c;
  --acc:#16a34a; --acc-2:#059669; --acc-soft:#d1fae5;

  --pos:#047857; --pos-bg:#ecfdf5;
  --neg:#b91c1c; --neg-bg:#fef2f2;
  --warn:#a16207; --warn-bg:#fefce8;
  --info:#1d4ed8; --info-bg:#eff6ff;

  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-xl:16px;

  --sb-w:232px; --sb-w-collapsed:64px;

  --shadow-xs: 0 1px 1px rgba(10,10,10,.04);
  --shadow-sm: 0 1px 2px rgba(10,10,10,.05), 0 1px 1px rgba(10,10,10,.03);
  --shadow-md: 0 4px 12px -2px rgba(10,10,10,.06), 0 2px 4px -2px rgba(10,10,10,.04);
  --shadow-lg: 0 24px 48px -12px rgba(10,10,10,.18), 0 4px 8px -4px rgba(10,10,10,.06);

  --ease: cubic-bezier(.2,0,0,1);
  --dur-1:120ms; --dur-2:200ms; --dur-3:320ms;

  --ring: 0 0 0 3px rgba(9,9,11,.10);
  --ring-acc: 0 0 0 3px rgba(22,163,74,.18);

  --font-ui: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono: 'DM Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
  --font-display: 'Inter', system-ui, sans-serif;
}

[data-theme="dark"] {
  --s-0:#0a0a0a; --s-1:#111113; --s-2:#18181b; --s-3:#27272a; --s-4:#3f3f46;
  --ink-0:#fafafa; --ink-1:#e4e4e7; --ink-2:#a1a1aa; --ink-3:#71717a; --ink-4:#52525b;
  --brand:#fafafa; --brand-ink:#0a0a0a; --brand-hov:#e4e4e7;
  --acc:#34d399; --acc-2:#10b981; --acc-soft:#022c22;
  --pos-bg:#022c22; --neg-bg:#450a0a; --warn-bg:#422006; --info-bg:#172554;
  --shadow-xs: 0 1px 1px rgba(0,0,0,.4);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 4px 12px rgba(0,0,0,.5);
  --shadow-lg: 0 24px 48px rgba(0,0,0,.6);
  --ring: 0 0 0 3px rgba(250,250,250,.10);
}

/* ── 1. Reset / base ──────────────────────────────────────────── */
* { box-sizing: border-box; }
*::selection { background: var(--ink-0); color: var(--s-0); }

html { scroll-behavior: smooth; }
html, body {
  margin:0; padding:0;
  font-family: var(--font-ui);
  font-size:14px; line-height:1.5;
  color: var(--ink-1); background: var(--s-1);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'cv11','ss01','ss03';
  text-rendering: optimizeLegibility;
}
body { min-height:100vh; }

/* Scrollbars discrètes */
*::-webkit-scrollbar { width:10px; height:10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: var(--s-3); border-radius:6px; border:2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover { background: var(--s-4); background-clip: padding-box; border:2px solid transparent; }

.num, .money, td.money, th.money, .mono { font-variant-numeric: tabular-nums; font-family: var(--font-mono); }

/* ── 2. Layout shell ───────────────────────────────────────────── */
.shell { display:flex; min-height:100vh; }

.sidebar {
  position:fixed; top:0; left:0; bottom:0;
  width: var(--sb-w);
  background: var(--s-0);
  border-right: 1px solid var(--s-3);
  display:flex; flex-direction:column;
  z-index:80;
  transition: transform var(--dur-2) var(--ease);
}

.sb-brand {
  padding: 18px 18px 14px;
  display:flex; align-items:center; gap:10px;
  border-bottom: 1px solid var(--s-2);
}
.sb-brand .logo {
  width:28px; height:28px; border-radius:6px;
  background: var(--brand); color: var(--brand-ink);
  display:grid; place-items:center;
  font-weight:700; font-size:14px;
  font-family: var(--font-display);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.sb-brand .name { font-weight:700; color: var(--ink-0); font-size:14px; letter-spacing:-0.01em; }
.sb-brand .sub { font-size:10.5px; color: var(--ink-3); letter-spacing:.08em; text-transform: uppercase; margin-top:1px; }

.sb-search { padding: 12px 14px 4px; }
.sb-search button {
  width:100%;
  display:flex; align-items:center; gap:8px;
  background: var(--s-1); border:1px solid var(--s-3);
  border-radius: var(--r-md);
  padding: 7px 10px;
  color: var(--ink-3); font-size:13px;
  cursor: pointer; transition: all var(--dur-1) var(--ease);
}
.sb-search button:hover { background: var(--s-2); color: var(--ink-1); border-color: var(--s-4); }
.sb-search button .kbd {
  margin-left:auto;
  font-family: var(--font-mono); font-size:11px;
  background: var(--s-0); border:1px solid var(--s-3);
  border-radius:4px; padding:1px 5px;
  color: var(--ink-2);
  box-shadow: 0 1px 0 var(--s-3);
}

.sb-nav { flex:1; padding: 8px 10px 12px; overflow-y:auto; }
.sb-section {
  padding: 12px 8px 4px;
  font-size:10.5px; font-weight:600;
  text-transform: uppercase; letter-spacing:.08em;
  color: var(--ink-4);
}
.sb-nav a {
  position: relative;
  display:flex; align-items:center; gap:10px;
  padding: 7px 10px;
  color: var(--ink-2);
  text-decoration:none;
  font-size:13.5px; font-weight:500;
  border-radius: var(--r-sm);
  transition: all var(--dur-1) var(--ease);
  margin-bottom:1px;
}
.sb-nav a i { font-size:15px; width:16px; text-align:center; color: var(--ink-3); transition: color var(--dur-1) var(--ease); }
.sb-nav a:hover { background: var(--s-2); color: var(--ink-0); }
.sb-nav a:hover i { color: var(--ink-1); }
.sb-nav a.active { background: var(--s-2); color: var(--ink-0); font-weight:600; }
.sb-nav a.active::before {
  content:''; position:absolute;
  left:-10px; top:6px; bottom:6px;
  width:2px; border-radius:0 2px 2px 0;
  background: var(--ink-0);
}
.sb-nav a.active i { color: var(--ink-0); }

.sb-foot {
  border-top: 1px solid var(--s-2);
  padding:12px;
  display:flex; align-items:center; gap:10px;
}
.sb-foot .avatar {
  width:28px; height:28px; border-radius:50%;
  background: var(--s-3); color: var(--ink-1);
  display:grid; place-items:center;
  font-size:11px; font-weight:600;
}
.sb-foot .info { flex:1; overflow:hidden; }
.sb-foot .info .n { font-size:12.5px; font-weight:600; color: var(--ink-0); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-foot .info .e { font-size:11px; color: var(--ink-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-foot .logout { color: var(--ink-3); padding:6px; border-radius: var(--r-sm); line-height:1; transition: all var(--dur-1) var(--ease); }
.sb-foot .logout:hover { color: var(--neg); background: var(--neg-bg); }

/* ── Topbar mobile ────────────────────────────────────────────── */
.topbar {
  display:none;
  position: sticky; top:0; z-index:60;
  background: color-mix(in srgb, var(--s-0) 92%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom:1px solid var(--s-3);
  padding: 10px 14px;
  align-items:center; gap:10px;
}
.topbar .menu-btn {
  background:none; border:none; padding:6px;
  color: var(--ink-1); font-size:20px; cursor:pointer;
  border-radius: var(--r-sm); transition: background var(--dur-1) var(--ease);
}
.topbar .menu-btn:hover { background: var(--s-2); }
.topbar .title { font-weight:600; color: var(--ink-0); }

.main { margin-left: var(--sb-w); flex:1; min-width:0; display:flex; flex-direction:column; }
.main-body { flex:1; padding: 24px 32px; max-width: 1440px; width:100%; }

/* ── 3. Page header ───────────────────────────────────────────── */
.ph {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:16px;
  padding-bottom:18px; margin-bottom:22px;
  border-bottom: 1px solid var(--s-3);
}
.ph-title { font-size:22px; font-weight:700; color: var(--ink-0); margin:0; letter-spacing:-0.02em; }
.ph-sub { font-size:13px; color: var(--ink-3); margin-top:3px; }
.ph-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.ph-eyebrow {
  font-size:10.5px; font-weight:600;
  color: var(--ink-3);
  letter-spacing:.12em; text-transform: uppercase;
  margin-bottom:6px;
  display:inline-flex; align-items:center; gap:6px;
}
.ph-eyebrow .dot {
  width:6px; height:6px; border-radius:50%;
  background: var(--acc); box-shadow: 0 0 0 3px var(--acc-soft);
  display:inline-block;
}

/* ── 4. Buttons ───────────────────────────────────────────────── */
.btn {
  font-family: var(--font-ui);
  display:inline-flex; align-items:center; gap:6px;
  padding: 7px 12px;
  font-size:13px; font-weight:500;
  border-radius: var(--r-md);
  border:1px solid transparent;
  cursor:pointer; text-decoration:none;
  transition: transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
  white-space:nowrap; line-height:1.3;
  user-select: none;
}
.btn:focus-visible { outline:none; box-shadow: var(--ring); }
.btn:active { transform: translateY(1px); }
.btn-sm { padding: 5px 10px; font-size:12px; border-radius: var(--r-sm); }
.btn-lg { padding: 10px 18px; font-size:14px; }

.btn-primary, .btn-navy {
  background: var(--brand); color: var(--brand-ink); border-color: var(--brand);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), var(--shadow-xs);
}
.btn-primary:hover, .btn-navy:hover { background: var(--brand-hov); color: var(--brand-ink); }

.btn-secondary, .btn-outline-secondary { background: var(--s-0); color: var(--ink-1); border-color: var(--s-3); }
.btn-secondary:hover, .btn-outline-secondary:hover { background: var(--s-2); border-color: var(--s-4); color: var(--ink-0); }

.btn-ghost { background: transparent; color: var(--ink-2); border-color: transparent; }
.btn-ghost:hover { background: var(--s-2); color: var(--ink-0); }

.btn-danger, .btn-outline-danger { background: var(--s-0); color: var(--neg); border-color: var(--s-3); }
.btn-danger:hover, .btn-outline-danger:hover { background: var(--neg-bg); border-color: var(--neg); }

.btn-success, .btn-outline-success { background: var(--s-0); color: var(--pos); border-color: var(--s-3); }
.btn-success:hover, .btn-outline-success:hover { background: var(--pos-bg); border-color: var(--pos); }

.btn-outline-primary { background: var(--s-0); color: var(--info); border-color: var(--s-3); }
.btn-outline-primary:hover { background: var(--info-bg); border-color: var(--info); }

.btn-accent { background: var(--brand); color: var(--brand-ink); border-color: var(--brand); }
.btn-accent:hover { background: var(--brand-hov); color: var(--brand-ink); }

.btn-icon { padding:5px; width:28px; height:28px; display:inline-grid; place-items:center; }
.btn-icon i { font-size:13px; }

/* ── 5. Cards & surfaces ─────────────────────────────────────── */
.card {
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-radius: var(--r-md);
  box-shadow:none;
  transition: border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.card.is-hoverable:hover { border-color: var(--s-4); box-shadow: var(--shadow-md); }

.card-header-navy, .card-header-dark {
  background: var(--s-0);
  color: var(--ink-0);
  font-weight:600; font-size:13px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--s-3);
  letter-spacing:-0.01em;
  display:flex; align-items:center;
}
.card-header-navy i, .card-header-dark i { font-size:14px; margin-right:7px; color: var(--ink-2); }

.card-body, .card > .card-body { padding:16px; }
.card-body.p-0 { padding:0; }

/* KPI cards */
.kpi {
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-radius: var(--r-md);
  padding: 16px 18px 22px;
  position:relative;
  transition: border-color var(--dur-1) var(--ease), transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
  overflow:hidden;
}
.kpi:hover { border-color: var(--s-4); }
.kpi[data-href] { cursor:pointer; }
.kpi[data-href]:hover { box-shadow: var(--shadow-sm); transform: translateY(-1px); }
.kpi[data-href]:active { transform: translateY(0); }
.kpi-lbl { font-size:11.5px; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color: var(--ink-3); margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.kpi-val {
  font-family: var(--font-display);
  font-size:26px; font-weight:700;
  color: var(--ink-0); line-height:1.1;
  letter-spacing:-0.02em;
  font-variant-numeric: tabular-nums;
}
.kpi-sub { font-size:12px; color: var(--ink-3); margin-top:5px; }
.kpi-ico { display:none; }
.kpi .trend {
  display:inline-flex; align-items:center; gap:3px;
  font-size:11.5px; font-weight:600;
  padding:2px 6px; border-radius:10px;
  font-variant-numeric: tabular-nums;
}
.kpi .trend.up { color: var(--pos); background: var(--pos-bg); }
.kpi .trend.dn { color: var(--neg); background: var(--neg-bg); }

/* Sparkline en bas de KPI */
.kpi .spark {
  position:absolute; left:0; right:0; bottom:0;
  height:36px; pointer-events:none;
  opacity:.55; transition: opacity var(--dur-2) var(--ease);
}
.kpi:hover .spark { opacity:1; }
.kpi .spark svg { width:100%; height:100%; display:block; }
.kpi .spark .area { fill: var(--ink-0); fill-opacity:.06; }
.kpi .spark .line { fill:none; stroke: var(--ink-0); stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.kpi .spark .dot { fill: var(--ink-0); }
.kpi.kpi--pos .spark .area { fill: var(--pos); fill-opacity:.10; }
.kpi.kpi--pos .spark .line { stroke: var(--pos); }
.kpi.kpi--pos .spark .dot { fill: var(--pos); }
.kpi.kpi--neg .spark .area { fill: var(--neg); fill-opacity:.10; }
.kpi.kpi--neg .spark .line { stroke: var(--neg); }
.kpi.kpi--neg .spark .dot { fill: var(--neg); }

/* ── 6. Tables ─────────────────────────────────────────────────── */
.table { width:100%; color: var(--ink-1); margin:0; border-collapse: collapse; }
.table th, .table td { padding: 11px 14px; }
.table thead th, .table-light th, .table .table-light th, thead.table-light th {
  background: var(--s-1);
  border-bottom:1px solid var(--s-3);
  border-top:1px solid var(--s-3);
  font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.05em;
  color: var(--ink-3);
  text-align:left; white-space:nowrap;
}
.table tbody td { border-bottom:1px solid var(--s-2); font-size:13px; vertical-align:middle; }
.table tbody tr:last-child td { border-bottom:none; }
.table-hover tbody tr { transition: background var(--dur-1) var(--ease); }
.table-hover tbody tr:hover { background: var(--s-1); }
.table-sm th, .table-sm td { padding: 8px 12px; }
.table-responsive { overflow-x:auto; }

.table-danger, tr.table-danger, .table tr.table-danger td { background: var(--neg-bg) !important; }
.table-success, tr.table-success, .table tr.table-success td { background: var(--pos-bg) !important; }
.table-dark, tr.table-dark, .table tr.table-dark td { background: var(--ink-0) !important; color: var(--s-0) !important; }

/* ── 7. Forms ──────────────────────────────────────────────────── */
.form-label { display:block; font-size:12px; font-weight:500; color: var(--ink-2); margin-bottom:4px; }
.form-control, .form-select, input[type=text], input[type=email],
input[type=password], input[type=number], input[type=date], input[type=search],
input[type=tel], input[type=url], textarea, select {
  font-family: var(--font-ui);
  width:100%;
  padding: 7px 10px;
  font-size:13.5px;
  color: var(--ink-0);
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-radius: var(--r-md);
  transition: border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
  line-height:1.4;
}
input[type=number], input[type=date] { font-variant-numeric: tabular-nums; }
.form-control:focus, .form-select:focus, input:focus, textarea:focus, select:focus {
  outline:none; border-color: var(--ink-1); box-shadow: var(--ring);
}
.form-control-sm, .form-select-sm, select.form-select-sm { padding: 5px 8px; font-size:12.5px; border-radius: var(--r-sm); }
textarea.form-control { min-height:60px; resize:vertical; }

.form-check { display:flex; align-items:center; gap:8px; }
.form-check-input { width:16px; height:16px; margin:0; flex-shrink:0; accent-color: var(--brand); }
.form-check-label { font-size:13px; color: var(--ink-1); cursor:pointer; }

.input-group { display:flex; gap:0; }
.input-group .form-control { border-radius: var(--r-md) 0 0 var(--r-md); }
.input-group .btn { border-radius: 0 var(--r-md) var(--r-md) 0; border-left:none; }

.input-search { position: relative; }
.input-search > i { position:absolute; left:10px; top:50%; transform:translateY(-50%); color: var(--ink-3); font-size:14px; pointer-events:none; }
.input-search > input { padding-left:32px !important; }

/* Segmented control (chips) */
.segmented {
  display:inline-flex; gap:0;
  background: var(--s-1);
  border:1px solid var(--s-3);
  padding:3px; border-radius: var(--r-md);
}
.segmented a, .segmented button {
  padding: 5px 10px;
  font-size:12.5px; font-weight:500;
  color: var(--ink-2);
  text-decoration:none;
  border:none; background:transparent;
  border-radius: var(--r-sm);
  cursor:pointer;
  transition: all var(--dur-1) var(--ease);
  white-space: nowrap;
}
.segmented a:hover, .segmented button:hover { color: var(--ink-0); }
.segmented a.active, .segmented button.active {
  background: var(--s-0); color: var(--ink-0);
  font-weight:600;
  box-shadow: var(--shadow-xs);
}

/* ── 8. Tags / badges ─────────────────────────────────────────── */
.tag {
  display:inline-flex; align-items:center; gap:4px;
  font-size:11.5px; font-weight:500;
  padding:2px 8px; border-radius:10px;
  line-height:1.5; white-space:nowrap;
}
.tag::before { content:''; width:5px; height:5px; border-radius:50%; }
.tag--neutral { background: var(--s-2); color: var(--ink-2); } .tag--neutral::before { background: var(--ink-3); }
.tag--success { background: var(--pos-bg); color: var(--pos); } .tag--success::before { background: var(--pos); }
.tag--danger  { background: var(--neg-bg); color: var(--neg); } .tag--danger::before { background: var(--neg); }
.tag--warning { background: var(--warn-bg); color: var(--warn); } .tag--warning::before { background: var(--warn); }
.tag--info    { background: var(--info-bg); color: var(--info); } .tag--info::before { background: var(--info); }

.badge { font-size:11px; font-weight:500; padding:3px 8px; border-radius:10px; }
.badge.bg-secondary { background: var(--s-2) !important; color: var(--ink-2) !important; }
.badge.bg-danger    { background: var(--neg-bg) !important; color: var(--neg) !important; }
.badge.bg-success   { background: var(--pos-bg) !important; color: var(--pos) !important; }
.badge.bg-warning   { background: var(--warn-bg) !important; color: var(--warn) !important; }
.badge.bg-primary   { background: var(--info-bg) !important; color: var(--info) !important; }
.badge.bg-light     { background: var(--s-2) !important; color: var(--ink-2) !important; }

/* ── 9. Flash ────────────────────────────────────────────────── */
.flash-wrap { position:fixed; top:16px; right:16px; z-index:9999; min-width:280px; max-width:380px; }
.flash {
  display:flex; align-items:flex-start; gap:10px;
  padding: 12px 14px;
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-left:3px solid var(--ink-2);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  font-size:13px;
  animation: slideIn var(--dur-3) var(--ease);
}
.flash--success { border-left-color: var(--pos); }
.flash--danger, .flash--error { border-left-color: var(--neg); }
.flash--warning { border-left-color: var(--warn); }
.flash i { font-size:15px; flex-shrink:0; line-height:1.2; margin-top:1px; }
.flash--success i { color: var(--pos); }
.flash--danger i, .flash--error i { color: var(--neg); }
.flash--warning i { color: var(--warn); }
.flash .close { background:none; border:none; color: var(--ink-3); cursor:pointer; padding:0; margin-left:auto; line-height:1; font-size:16px; }
.flash .close:hover { color: var(--ink-0); }
.flash.fade-out { animation: slideOut var(--dur-3) var(--ease) forwards; }

@keyframes slideIn  { from { transform: translateX(12px); opacity:0; } }
@keyframes slideOut { to   { transform: translateX(12px); opacity:0; } }

.alert { padding: 10px 14px; border-radius: var(--r-md); font-size:13px; margin-bottom:12px; }
.alert-success { background: var(--pos-bg); color: var(--pos); border:1px solid rgba(4,120,87,.2); }
.alert-warning { background: var(--warn-bg); color: var(--warn); border:1px solid rgba(161,98,7,.2); }
.alert-danger  { background: var(--neg-bg); color: var(--neg); border:1px solid rgba(185,28,28,.2); }
.alert-info    { background: var(--info-bg); color: var(--info); border:1px solid rgba(29,78,216,.2); }

/* ── 10. Modal ─────────────────────────────────────────────────── */
.mx {
  position:fixed; inset:0; z-index:100;
  background: rgba(9,9,11,.5);
  display:none; align-items:flex-start; justify-content:center;
  overflow-y:auto; padding: 40px 16px;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.mx.show { display:flex; }
.mx-dialog {
  width:100%; max-width:560px;
  background: var(--s-0);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  animation: popIn var(--dur-2) var(--ease);
}
.mx-dialog.lg { max-width:760px; }
@keyframes popIn { from { transform: translateY(-8px) scale(.98); opacity:0; } }

.mx-head { padding: 16px 20px; border-bottom:1px solid var(--s-2); display:flex; align-items:center; gap:10px; }
.mx-head .ttl { font-size:15px; font-weight:600; color: var(--ink-0); flex:1; }
.mx-head .close { background:none; border:none; color: var(--ink-3); font-size:20px; padding:4px; cursor:pointer; line-height:1; text-decoration:none; }
.mx-head .close:hover { color: var(--ink-0); }
.mx-body { padding: 20px; }
.mx-foot { padding: 14px 20px; border-top:1px solid var(--s-2); display:flex; gap:8px; justify-content:flex-end; background: var(--s-1); border-radius: 0 0 var(--r-lg) var(--r-lg); }

/* ── 11. Dropdown ──────────────────────────────────────────────── */
.dropdown-menu {
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding:4px; font-size:13px; min-width:180px;
}
.dropdown-item, .dropdown-menu button.dropdown-item {
  padding: 6px 10px;
  border-radius: var(--r-sm);
  color: var(--ink-1); font-size:13px;
  border:none; background:none;
  width:100%; text-align:left; cursor:pointer;
}
.dropdown-item:hover { background: var(--s-2); color: var(--ink-0); }
.dropdown-item.active { background: var(--s-2); color: var(--ink-0); font-weight:600; }

/* ── 12. Charges — Summary cards ──────────────────────────────── */
.sum-card {
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-left:3px solid var(--c, var(--ink-2));
  border-radius: var(--r-md);
  padding: 14px 16px;
}
.sum-card .lbl { font-size:11.5px; font-weight:600; color: var(--ink-3); text-transform:uppercase; letter-spacing:.05em; }
.sum-card .val { font-family: var(--font-mono); font-size:18px; font-weight:700; color: var(--pos); margin-top:4px; }
.sum-card .sub { font-size:11.5px; color: var(--ink-3); margin-top:2px; }

.cat-pill { display:inline-flex; align-items:center; gap:5px; padding:3px 10px; background: var(--s-2); color: var(--ink-1); font-size:11.5px; font-weight:500; border-radius:12px; }
.cat-pill i { font-size:12px; }

/* ── 13. Dashboard chart ───────────────────────────────────────── */
.chart-card { min-height:280px; }
.chart-svg { width:100%; height:220px; display:block; }
.chart-svg .bar { fill: var(--ink-4); transition: fill var(--dur-1) var(--ease); }
.chart-svg .bar:hover { fill: var(--ink-0); }
.chart-svg .bar.current { fill: var(--ink-0); }
.chart-svg .grid { stroke: var(--s-3); stroke-dasharray: 2 3; }
.chart-svg .axis-label { font-family: var(--font-mono); font-size:10px; fill: var(--ink-3); }
.chart-svg .area-line { fill:none; stroke: var(--ink-0); stroke-width:1.6; stroke-linejoin:round; stroke-linecap:round; }
.chart-svg .pt { fill: var(--ink-0); }
.chart-svg text { font-family: var(--font-mono); font-size:10px; fill: var(--ink-3); }

/* Mini ranking bar (top clients) */
.rank-row {
  padding: 11px 16px;
  border-bottom:1px solid var(--s-2);
  display:grid;
  grid-template-columns: 24px 1fr auto;
  gap:10px; align-items:center;
  position: relative;
}
.rank-row:last-child { border-bottom:none; }
.rank-row .pos {
  width:22px; height:22px; border-radius:50%;
  background: var(--s-2); color: var(--ink-2);
  font-size:11px; font-weight:600;
  display:grid; place-items:center;
  font-family: var(--font-mono);
}
.rank-row .name {
  font-size:13px; font-weight:600; color: var(--ink-0);
  text-decoration:none; display:block;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.rank-row .meta { font-size:11.5px; color: var(--ink-3); margin-top:2px; }
.rank-row .v { font-family: var(--font-mono); font-size:13px; font-weight:700; color: var(--ink-0); text-align:right; }
.rank-row .pct { font-family: var(--font-mono); font-size:11px; color: var(--ink-3); text-align:right; margin-top:2px; }
.rank-row .progress {
  grid-column: 1 / -1;
  height:3px; border-radius:2px;
  background: var(--s-2); overflow:hidden;
  margin-top:4px;
}
.rank-row .progress > span { display:block; height:100%; background: var(--ink-0); border-radius:2px; transition: width var(--dur-3) var(--ease); }

/* ── 14. Command palette ──────────────────────────────────────── */
.cmdk-overlay {
  position:fixed; inset:0; z-index:9999;
  background: rgba(9,9,11,.4);
  display:none;
  align-items:flex-start; justify-content:center;
  padding-top:12vh;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.cmdk-overlay.show { display:flex; animation: fadeIn var(--dur-2) var(--ease); }
@keyframes fadeIn { from { opacity:0; } }
.cmdk {
  width:100%; max-width:560px;
  background: var(--s-0);
  border:1px solid var(--s-3);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  overflow:hidden;
  animation: popIn var(--dur-2) var(--ease);
}
.cmdk-input { width:100%; border:none; border-bottom:1px solid var(--s-2); padding: 16px 20px; font-size:15px; background:transparent; outline:none; }
.cmdk-list { max-height:50vh; overflow-y:auto; padding:6px; }
.cmdk-item { display:flex; align-items:center; gap:10px; padding: 8px 12px; border-radius: var(--r-sm); text-decoration:none; color: var(--ink-1); cursor:pointer; font-size:13.5px; }
.cmdk-item i { color: var(--ink-3); font-size:15px; width:18px; }
.cmdk-item .sec { color: var(--ink-3); font-size:11.5px; margin-left:auto; }
.cmdk-item:hover, .cmdk-item.focused { background: var(--s-2); color: var(--ink-0); }
.cmdk-item:hover i, .cmdk-item.focused i { color: var(--ink-0); }
.cmdk-empty { padding:20px; text-align:center; color: var(--ink-3); font-size:13px; }

/* ── 15. Utilities ─────────────────────────────────────────────── */
.muted, .text-muted { color: var(--ink-3) !important; }
.subtle { color: var(--ink-4); }
.text-success, .pos { color: var(--pos) !important; }
.text-danger,  .neg { color: var(--neg) !important; }
.text-warning { color: var(--warn) !important; }
.text-primary { color: var(--info) !important; }
.text-white-50 { color: rgba(255,255,255,.6) !important; }

.fw-bold { font-weight:600 !important; }
.fw-semibold { font-weight:600 !important; }
.fw-normal { font-weight:400 !important; }

.hr { height:1px; background: var(--s-3); border:0; margin: 16px 0; }
.scroll-x { overflow-x:auto; }
.divider { height:1px; background: var(--s-3); margin: 16px 0; }
.bi { line-height:1; }

.reveal { opacity:0; transform: translateY(8px); transition: opacity var(--dur-3) var(--ease), transform var(--dur-3) var(--ease); }
.reveal.in { opacity:1; transform:none; }

/* Empty state */
.empty {
  text-align:center; padding: 40px 20px;
  color: var(--ink-3);
}
.empty .ico {
  width:44px; height:44px; border-radius: 50%;
  background: var(--s-2); color: var(--ink-3);
  display:inline-grid; place-items:center;
  font-size:18px; margin-bottom:10px;
}
.empty .ttl { font-size:14px; font-weight:600; color: var(--ink-1); margin-bottom:4px; }
.empty .desc { font-size:12.5px; max-width:320px; margin: 0 auto 12px; line-height:1.55; }

/* ── 16. Footer ───────────────────────────────────────────────── */
.sf {
  border-top:1px solid var(--s-3);
  padding: 14px 20px;
  font-size:11.5px; color: var(--ink-3);
  display:flex; justify-content:space-between; align-items:center;
}
.sf a { color: var(--ink-2); text-decoration:none; }
.sf a:hover { color: var(--ink-0); }

/* ── 17. Responsive ────────────────────────────────────────────── */
@media (max-width: 960px) {
  :root { --sb-w: 240px; }
  .sidebar { transform: translateX(-100%); box-shadow: var(--shadow-lg); }
  .sidebar.open { transform: translateX(0); }
  .main { margin-left:0; }
  .topbar { display:flex; }
  .main-body { padding:16px; }
  .ph { flex-direction:column; align-items:flex-start; }
  .ph-actions { width:100%; }
  .mx-dialog { max-width:100%; }
  .kpi-val { font-size:22px; }
  body.sidebar-open { overflow:hidden; }
  .sidebar-backdrop { display:none; position:fixed; inset:0; background: rgba(9,9,11,.4); z-index:70; animation: fadeIn var(--dur-2) var(--ease); }
  .sidebar-backdrop.show { display:block; }
}

/* ── 18. Print ─────────────────────────────────────────────────── */
@media print {
  .sidebar, .topbar, .no-print, .sf, .flash-wrap { display:none !important; }
  .main { margin-left:0 !important; }
  .main-body { padding:0 !important; max-width:100% !important; }
  .card { border:none !important; }
  body { background:#fff !important; }
}

/* ── 19. Lignes de facturation ─────────────────────────────────── */
.lr td { padding: 6px 8px !important; }
.lr .form-control, .lr .form-select { padding: 5px 8px; font-size:13px; }

.file-preview {
  background: var(--s-1);
  border:1px solid var(--s-3);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size:12.5px; color: var(--ink-2);
  margin-top:6px;
}
.file-preview strong { color: var(--ink-0); }

.kpi-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap:14px; }

/* Bootstrap shortcuts */
.d-flex { display:flex !important; }
.d-inline { display:inline !important; }
.d-none { display:none !important; }
.d-grid { display:grid !important; }
.flex-1 { flex:1 !important; }
.align-items-center { align-items:center !important; }
.justify-content-between { justify-content:space-between !important; }
.justify-content-end { justify-content:flex-end !important; }
.gap-1 { gap:4px !important; } .gap-2 { gap:8px !important; } .gap-3 { gap:12px !important; } .gap-4 { gap:16px !important; }
.mb-0 { margin-bottom:0 !important; } .mb-1 { margin-bottom:4px !important; } .mb-2 { margin-bottom:8px !important; } .mb-3 { margin-bottom:12px !important; } .mb-4 { margin-bottom:16px !important; }
.mt-1 { margin-top:4px !important; } .mt-2 { margin-top:8px !important; } .mt-3 { margin-top:12px !important; } .mt-4 { margin-top:16px !important; }
.ms-auto { margin-left:auto !important; }
.me-1 { margin-right:4px !important; } .me-2 { margin-right:8px !important; }
.py-0 { padding-top:0 !important; padding-bottom:0 !important; }
.py-4 { padding-top:16px !important; padding-bottom:16px !important; }
.py-5 { padding-top:22px !important; padding-bottom:22px !important; }
.px-1 { padding-left:4px !important; padding-right:4px !important; }
.p-0 { padding:0 !important; } .p-2 { padding:8px !important; } .p-3 { padding:12px !important; } .p-4 { padding:16px !important; }
.text-center { text-align:center !important; }
.text-end { text-align:right !important; }
.text-start { text-align:left !important; }
.w-100 { width:100% !important; } .h-100 { height:100% !important; }
.small { font-size:12px; }
.fs-5 { font-size:16px !important; } .fs-6 { font-size:14px !important; }
.text-decoration-none { text-decoration:none !important; }
.white-space-nowrap, .nowrap { white-space:nowrap !important; }
.border-top { border-top:1px solid var(--s-3) !important; }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}
