/* ============================================================
   AGP ASSURANCES — Design Premium v6
   Marine #062b55 | Vert #439831
   Nunito (chiffres) + Plus Jakarta Sans + Playfair Display
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Playfair+Display:wght@600;700;800&display=swap');

:root {
  --navy:         #062b55;
  --navy-dark:    #041d3a;
  --navy-light:   #0a3d78;
  --navy-mid:     #0d4a8f;
  --navy-glow:    rgba(6,43,85,.12);
  --green:        #439831;
  --green-dark:   #2d6b21;
  --green-light:  #5ec040;
  --green-pale:   #edf7e9;
  --green-glow:   rgba(67,152,49,.15);
  --white:        #ffffff;
  --bg:           #eef1f7;
  --bg2:          #f5f7fc;
  --card:         #ffffff;
  --text:         #0f1e35;
  --text-2:       #3d5068;
  --text-muted:   #7a8fa8;
  --border:       #dce3ef;
  --border-light: #edf0f7;
  --danger:       #e03131;
  --warning:      #e8970a;
  --info:         #0ea5e9;

  --sidebar-w:    272px;
  --topbar-h:     66px;
  --r:            14px;
  --r-sm:         9px;
  --r-xs:         6px;

  --shadow-xs: 0 1px 2px rgba(6,43,85,.06);
  --shadow-sm: 0 2px 8px rgba(6,43,85,.08), 0 1px 2px rgba(6,43,85,.04);
  --shadow:    0 4px 16px rgba(6,43,85,.1),  0 1px 3px rgba(6,43,85,.06);
  --shadow-md: 0 8px 24px rgba(6,43,85,.13), 0 2px 6px rgba(6,43,85,.07);
  --shadow-lg: 0 16px 48px rgba(6,43,85,.18),0 4px 12px rgba(6,43,85,.1);
  --shadow-g:  0 6px 20px rgba(67,152,49,.3);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Chiffres avec Nunito ── */
.num, .kpi-value, .stat-value, .ast-value,
.badge-num, .totaux-row span:last-child,
.totaux-final span:last-child, .totals-grand span:last-child,
td strong, .pi-amount strong, .invoice-ref {
  font-family: 'Nunito', sans-serif !important;
}

/* ================================================================
   LAYOUT
================================================================ */
.app-layout { display:flex; min-height:100vh; }

/* ================================================================
   SIDEBAR
================================================================ */
.sidebar {
  width: var(--sidebar-w);
  background: linear-gradient(180deg, var(--navy-dark) 0%, var(--navy) 100%);
  display: flex; flex-direction: column;
  position: fixed; top:0; left:0; height:100vh; z-index:200;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  overflow-y: auto; overflow-x: hidden;
  box-shadow: 4px 0 28px rgba(6,43,85,.35);
}
.sidebar::-webkit-scrollbar { width:4px; }
.sidebar::-webkit-scrollbar-track { background:transparent; }
.sidebar::-webkit-scrollbar-thumb { background:rgba(255,255,255,.15); border-radius:2px; }

/* ── Brand ── */
.sidebar-brand {
  display: flex; flex-direction: column; align-items: center;
  padding: 24px 20px 16px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  background: rgba(0,0,0,.15);
  position: relative;
}
.sidebar-brand::after {
  content:''; position:absolute; bottom:0; left:20%; right:20%; height:1px;
  background: linear-gradient(90deg, transparent, var(--green), transparent);
}
.sidebar-logo-box {
  background: white; border-radius: 12px;
  padding: 8px 16px; display:flex; align-items:center; justify-content:center;
  box-shadow: 0 4px 20px rgba(0,0,0,.3), 0 0 0 1px rgba(255,255,255,.1);
  width: 180px; height: 60px;
  transition: transform .2s;
}
.sidebar-logo-box:hover { transform: scale(1.02); }
.sidebar-logo-box img { height:44px; width:auto; object-fit:contain; }
.sidebar-tagline {
  font-size: 9.5px; text-transform:uppercase; letter-spacing:2px;
  color: rgba(255,255,255,.35); margin-top:10px; font-weight:600;
}

/* ── Menu ── */
.sidebar-menu { padding:16px 10px; flex:1; }
.menu-label {
  font-size:9.5px; text-transform:uppercase; letter-spacing:2px;
  color:rgba(255,255,255,.28); padding:0 10px; margin:14px 0 6px;
  font-weight:700;
}
.menu-item {
  display:flex; align-items:center; gap:11px;
  padding:10px 13px; border-radius:10px;
  color:rgba(255,255,255,.6); text-decoration:none;
  transition:all .2s; margin-bottom:2px;
  font-weight:500; font-size:13.5px; position:relative;
}
.menu-item:hover { background:rgba(255,255,255,.08); color:var(--white); padding-left:18px; }
.menu-item.active {
  background: linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%);
  color:var(--white); font-weight:700;
  box-shadow: 0 4px 14px rgba(67,152,49,.35);
}
.menu-item.active::before {
  content:''; position:absolute; left:0; top:25%; bottom:25%;
  width:3px; background:white; border-radius:0 2px 2px 0;
}
.menu-item.highlight {
  background:rgba(67,152,49,.15); color:#8de870;
  border:1px solid rgba(67,152,49,.3);
}
.menu-item.highlight:hover { background:var(--green); color:white; }
.menu-item i { font-size:16px; width:20px; flex-shrink:0; }

/* ── Role Badge ── */
.sidebar-role-badge { padding:6px 14px; }
.role-admin {
  background:rgba(224,49,49,.15); color:#ffa8a8;
  font-size:10.5px; font-weight:700; padding:5px 12px;
  border-radius:20px; text-align:center;
  border:1px solid rgba(224,49,49,.25);
}
.role-agent {
  background:rgba(67,152,49,.15); color:#8de870;
  font-size:10.5px; font-weight:700; padding:5px 12px;
  border-radius:20px; text-align:center;
  border:1px solid rgba(67,152,49,.25);
}

/* ── Footer ── */
.sidebar-footer {
  padding:14px 16px; border-top:1px solid rgba(255,255,255,.07);
  display:flex; align-items:center; gap:10px;
  background:rgba(0,0,0,.12);
}
.user-avatar {
  width:38px; height:38px;
  background: linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:13px; color:white; flex-shrink:0;
  font-family:'Nunito',sans-serif;
  box-shadow: 0 3px 10px rgba(67,152,49,.4);
}
.user-name { font-size:13px; font-weight:600; color:white; }
.user-role { font-size:10.5px; color:rgba(255,255,255,.38); }
.logout-btn { margin-left:auto; color:rgba(255,255,255,.3); font-size:18px; text-decoration:none; transition:color .2s; }
.logout-btn:hover { color:#ff6b6b; }

/* ================================================================
   TOPBAR
================================================================ */
.topbar {
  position:fixed; top:0;
  left:var(--sidebar-w); right:0;
  height:var(--topbar-h);
  background:var(--white);
  border-bottom:1px solid var(--border-light);
  display:flex; align-items:center; gap:16px;
  padding:0 28px; z-index:100;
  box-shadow: 0 1px 0 var(--border-light), 0 2px 8px rgba(6,43,85,.04);
}
.btn-sidebar-toggle { background:none; border:none; font-size:22px; color:var(--text-muted); cursor:pointer; display:none; }
.topbar-title { font-weight:700; font-size:15px; color:var(--navy); flex:1; }
.topbar-role-badge { font-size:11px; font-weight:700; padding:4px 12px; border-radius:20px; }
.admin-badge { background:rgba(6,43,85,.07); color:var(--navy); border:1.5px solid rgba(6,43,85,.15); }
.agent-badge { background:var(--green-pale); color:var(--green-dark); border:1.5px solid rgba(67,152,49,.25); }

/* ================================================================
   MAIN CONTENT
================================================================ */
.main-content {
  margin-left:var(--sidebar-w);
  margin-top:var(--topbar-h);
  padding:28px;
  min-height:calc(100vh - var(--topbar-h));
  flex:1;
}

/* ================================================================
   PAGE HEADER
================================================================ */
.page-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  margin-bottom:28px; gap:16px; flex-wrap:wrap;
}
.page-title {
  font-family:'Playfair Display',serif;
  font-size:28px; font-weight:800; color:var(--navy); line-height:1.1;
}
.page-subtitle { color:var(--text-muted); font-size:13px; margin-top:4px; }
.page-actions { display:flex; gap:10px; flex-wrap:wrap; }

/* ================================================================
   BUTTONS
================================================================ */
.btn-primary-custom {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  color:white; padding:10px 22px; border-radius:var(--r-sm);
  text-decoration:none; font-weight:700; font-size:13px;
  border:none; cursor:pointer; transition:all .22s;
  box-shadow: 0 3px 10px rgba(6,43,85,.25);
}
.btn-primary-custom:hover {
  background:linear-gradient(135deg, var(--green-dark) 0%, var(--green) 100%);
  color:white; transform:translateY(-1px); box-shadow:var(--shadow-g);
}
.btn-secondary-custom {
  display:inline-flex; align-items:center; gap:8px;
  background:white; color:var(--navy);
  padding:10px 22px; border-radius:var(--r-sm);
  border:1.5px solid rgba(6,43,85,.2);
  text-decoration:none; font-weight:700; font-size:13px;
  cursor:pointer; transition:all .22s;
}
.btn-secondary-custom:hover { background:var(--navy); color:white; border-color:var(--navy); }
.btn-success-custom {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--green) 0%, var(--green-dark) 100%);
  color:white; padding:10px 22px; border-radius:var(--r-sm); border:none;
  font-weight:700; font-size:13px; cursor:pointer; transition:all .22s;
  box-shadow:var(--shadow-g);
}
.btn-success-custom:hover { filter:brightness(1.1); transform:translateY(-1px); }
.btn-back { display:inline-flex; align-items:center; gap:8px; color:var(--text-muted); text-decoration:none; font-size:13px; font-weight:600; transition:color .2s; }
.btn-back:hover { color:var(--navy); }
.btn-link { color:var(--navy); text-decoration:none; font-size:13px; font-weight:700; display:inline-flex; align-items:center; gap:4px; }
.btn-link:hover { color:var(--green); }
.btn-add-ligne {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--navy); color:white; border:none;
  padding:8px 16px; border-radius:var(--r-sm);
  font-size:12px; font-weight:700; cursor:pointer; transition:all .2s;
}
.btn-add-ligne:hover { background:var(--green); }
.btn-remove-ligne { background:none; border:none; color:var(--danger); font-size:18px; cursor:pointer; transition:transform .2s; }
.btn-remove-ligne:hover { transform:scale(1.2); }
.btn-search {
  background:var(--navy); color:white; border:none;
  padding:9px 20px; border-radius:var(--r-sm);
  font-size:13px; font-weight:700; cursor:pointer; transition:background .2s;
  flex-shrink:0;
}
.btn-search:hover { background:var(--green); }

.btn-action {
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:var(--r-xs);
  background:rgba(6,43,85,.06); color:var(--navy);
  text-decoration:none; transition:all .2s; margin-right:3px;
  border:none; cursor:pointer;
}
.btn-action:hover { background:var(--navy); color:white; }
.btn-action-green { background:rgba(67,152,49,.08); color:var(--green-dark); }
.btn-action-green:hover { background:var(--green); color:white; }
.btn-action-red { background:rgba(224,49,49,.07); color:var(--danger); }
.btn-action-red:hover { background:var(--danger); color:white; }
.btn-action-amber { background:rgba(232,151,10,.08); color:#965f00; }
.btn-action-amber:hover { background:var(--warning); color:white; }

/* ================================================================
   KPI CARDS — ADMIN
================================================================ */
.kpi-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }

.kpi-card {
  background:var(--card);
  border-radius:var(--r);
  padding:20px 16px;
  box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden;
  transition:transform .22s, box-shadow .22s;
  border:1px solid var(--border-light);
}
.kpi-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
  border-radius:var(--r) var(--r) 0 0;
}
.kpi-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.kpi-card::after {
  content:''; position:absolute;
  right:-20px; bottom:-20px;
  width:80px; height:80px; border-radius:50%;
  opacity:.06;
}
.kpi-navy::before  { background:var(--navy); }
.kpi-navy::after   { background:var(--navy); }
.kpi-green::before { background:var(--green); }
.kpi-green::after  { background:var(--green); }
.kpi-blue::before  { background:#3b82f6; }
.kpi-blue::after   { background:#3b82f6; }
.kpi-gold::before  { background:var(--green-light); }
.kpi-gold::after   { background:var(--green-light); }
.kpi-indigo::before{ background:#6366f1; }
.kpi-indigo::after { background:#6366f1; }
.kpi-amber::before { background:var(--warning); }
.kpi-amber::after  { background:var(--warning); }

.kpi-icon {
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:19px; flex-shrink:0; margin-bottom:12px;
}
.kpi-navy  .kpi-icon { background:rgba(6,43,85,.08);   color:var(--navy); }
.kpi-green .kpi-icon { background:rgba(67,152,49,.1);  color:var(--green-dark); }
.kpi-blue  .kpi-icon { background:rgba(59,130,246,.1); color:#3b82f6; }
.kpi-gold  .kpi-icon { background:rgba(94,192,64,.1);  color:var(--green-dark); }
.kpi-indigo .kpi-icon{ background:rgba(99,102,241,.1); color:#6366f1; }
.kpi-amber .kpi-icon { background:rgba(232,151,10,.1); color:#965f00; }

.kpi-value {
  font-family:'Nunito',sans-serif !important;
  font-size:24px; font-weight:900; color:var(--navy); line-height:1;
  letter-spacing:-0.5px;
}
.kpi-label { font-size:11.5px; color:var(--text-muted); margin-top:4px; font-weight:600; }
.kpi-sparkline { position:absolute; top:18px; right:16px; font-size:18px; }

/* ================================================================
   CHART CARDS
================================================================ */
.chart-card { background:var(--card); border-radius:var(--r); box-shadow:var(--shadow-sm); overflow:hidden; border:1px solid var(--border-light); }
.chart-header { display:flex; align-items:flex-start; justify-content:space-between; padding:18px 22px 14px; border-bottom:1px solid var(--border-light); }
.chart-title { font-size:14px; font-weight:800; color:var(--navy); margin:0; }
.chart-subtitle { font-size:11.5px; color:var(--text-muted); margin-top:2px; }
.chart-badge { background:rgba(6,43,85,.06); color:var(--navy); font-size:11px; font-weight:700; padding:3px 10px; border-radius:20px; white-space:nowrap; }
.chart-body { padding:18px 22px; }
.chart-legend { display:flex; flex-wrap:wrap; gap:10px; padding:8px 22px 16px; }
.legend-item { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-2); }
.legend-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.legend-val { font-family:'Nunito',sans-serif; font-weight:800; margin-left:2px; color:var(--navy); }

/* ================================================================
   CONTENT CARDS
================================================================ */
.content-card { background:var(--card); border-radius:var(--r); box-shadow:var(--shadow-sm); overflow:hidden; border:1px solid var(--border-light); }
.card-header-custom { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border-light); }
.card-header-custom h3 { font-size:14px; font-weight:800; color:var(--navy); margin:0; }

/* ================================================================
   TABLE
================================================================ */
.table-custom { width:100%; border-collapse:collapse; }
.table-custom thead tr { background:linear-gradient(135deg,#f0f4fa 0%,#f5f8ff 100%); }
.table-custom th {
  padding:12px 18px; text-align:left;
  font-size:10.5px; font-weight:800; text-transform:uppercase;
  letter-spacing:.9px; color:var(--navy);
  border-bottom:2px solid var(--border);
}
.table-custom td { padding:14px 18px; border-bottom:1px solid var(--border-light); vertical-align:middle; }
.table-custom tbody tr { transition:background .15s; }
.table-custom tbody tr:hover { background:#f4f8ff; }
.table-custom tbody tr:last-child td { border-bottom:none; }

/* ================================================================
   FORMS
================================================================ */
.form-card { background:var(--card); border-radius:var(--r); padding:28px; box-shadow:var(--shadow-sm); border:1px solid var(--border-light); }
.form-label { font-size:12.5px; font-weight:700; color:var(--text); margin-bottom:6px; display:block; }
.form-control, .form-select {
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  padding:10px 13px; font-size:13.5px; width:100%;
  transition:border-color .2s, box-shadow .2s, transform .15s;
  font-family:'Plus Jakarta Sans',sans-serif;
  background:white; color:var(--text);
}
.form-control:focus, .form-select:focus {
  border-color:var(--green); box-shadow:0 0 0 3px rgba(67,152,49,.13); outline:none;
  transform:translateY(-1px);
}
.form-section-title {
  font-size:14px; font-weight:800; color:var(--navy);
  margin-bottom:20px; padding-bottom:12px;
  border-bottom:2px solid var(--green-pale);
  display:flex; align-items:center;
}
.form-divider {
  font-size:10.5px; font-weight:800; text-transform:uppercase;
  letter-spacing:1.2px; color:var(--text-muted);
  padding:4px 0; border-bottom:1px dashed var(--border); margin-top:4px;
}

/* ================================================================
   SEARCH BAR
================================================================ */
.search-form { display:flex; gap:10px; align-items:center; flex:1; max-width:540px; }
.input-icon { position:relative; flex:1; }
.input-icon i { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:14px; pointer-events:none; }
.input-icon .form-control { padding-left:38px; }
.results-count { font-family:'Nunito',sans-serif; font-size:12.5px; color:var(--text-muted); font-weight:700; margin-left:auto; }

/* ================================================================
   BADGES
================================================================ */
.badge-num {
  font-family:'Nunito',sans-serif !important;
  font-size:12px; font-weight:800;
  background:rgba(6,43,85,.07); color:var(--navy);
  padding:3px 9px; border-radius:var(--r-xs); white-space:nowrap;
  letter-spacing:0.2px;
}
.badge-proforma {
  background:rgba(232,151,10,.1); color:#7a4d00;
  border:1.5px solid rgba(232,151,10,.3);
  font-size:10.5px; font-weight:800; padding:3px 10px;
  border-radius:var(--r-xs); text-transform:uppercase; letter-spacing:.8px;
}
.badge-definitive {
  background:rgba(67,152,49,.1); color:var(--green-dark);
  border:1.5px solid rgba(67,152,49,.28);
  font-size:10.5px; font-weight:800; padding:3px 10px;
  border-radius:var(--r-xs); text-transform:uppercase; letter-spacing:.8px;
}
.badge-proforma-sm { background:rgba(232,151,10,.1); color:#7a4d00; font-size:10px; font-weight:800; padding:2px 7px; border-radius:4px; white-space:nowrap; }
.badge-definitive-sm { background:rgba(67,152,49,.08); color:var(--green-dark); font-size:10px; font-weight:800; padding:2px 7px; border-radius:4px; white-space:nowrap; }

/* ================================================================
   QUICK ACTIONS
================================================================ */
.quick-actions { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.quick-card {
  background:var(--card); border-radius:var(--r);
  padding:22px 16px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:10px;
  text-decoration:none; color:var(--text); box-shadow:var(--shadow-sm);
  border:1.5px solid var(--border-light); transition:all .25s; text-align:center;
}
.quick-card i { font-size:28px; color:var(--navy); transition:transform .2s; }
.quick-card span { font-size:13px; font-weight:700; }
.quick-card:hover { border-color:var(--green); transform:translateY(-4px); box-shadow:var(--shadow-md); color:var(--navy); }
.quick-card:hover i { transform:scale(1.15) rotate(-5deg); color:var(--green); }
.quick-card.highlight { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%); color:white; border-color:transparent; box-shadow:var(--shadow-md); }
.quick-card.highlight i { color:var(--green-light); }
.quick-card.highlight span { color:white; }
.quick-card.highlight:hover { background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 100%); }
.quick-card.highlight:hover i { color:white; transform:scale(1.15) rotate(-5deg); }

/* ================================================================
   STATS SIMPLES
================================================================ */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.stat-card { background:var(--card); border-radius:var(--r); padding:22px; display:flex; align-items:center; gap:16px; box-shadow:var(--shadow-sm); border:1px solid var(--border-light); border-top:3px solid transparent; }
.stat-blue   { border-top-color:var(--navy); }
.stat-green  { border-top-color:var(--green); }
.stat-amber  { border-top-color:var(--warning); }
.stat-indigo { border-top-color:#6366f1; }
.stat-icon { width:50px; height:50px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; }
.stat-blue  .stat-icon { background:rgba(6,43,85,.07); color:var(--navy); }
.stat-green .stat-icon { background:rgba(67,152,49,.1); color:var(--green-dark); }
.stat-amber .stat-icon { background:rgba(232,151,10,.1); color:#965f00; }
.stat-indigo .stat-icon { background:rgba(99,102,241,.1); color:#6366f1; }
.stat-value { font-family:'Nunito',sans-serif !important; font-size:28px; font-weight:900; color:var(--navy); line-height:1; }
.stat-label { font-size:12px; color:var(--text-muted); margin-top:4px; font-weight:600; }

/* ================================================================
   AGENT DASHBOARD
================================================================ */
.agent-welcome {
  background:linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-light) 100%);
  border-radius:var(--r); padding:26px 30px;
  display:flex; align-items:center; gap:22px;
  box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.agent-welcome::before {
  content:''; position:absolute; right:-60px; top:-60px;
  width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle,rgba(67,152,49,.2) 0%,transparent 70%);
}
.agent-welcome::after {
  content:''; position:absolute; left:200px; bottom:-80px;
  width:180px; height:180px; border-radius:50%;
  background:radial-gradient(circle,rgba(67,152,49,.12) 0%,transparent 70%);
}
.welcome-avatar {
  width:62px; height:62px;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:22px; font-weight:900; color:white; flex-shrink:0;
  font-family:'Nunito',sans-serif;
  box-shadow:0 4px 14px rgba(67,152,49,.45);
  border:2px solid rgba(255,255,255,.2);
  position:relative; z-index:1;
}
.welcome-text { position:relative; z-index:1; }
.welcome-text h2 { font-size:21px; font-weight:800; color:white; margin:0; font-family:'Playfair Display',serif; }
.welcome-text p { font-size:13px; color:rgba(255,255,255,.55); margin:4px 0 0; }
.welcome-text span { color:var(--green-light); font-weight:600; }
.welcome-actions { margin-left:auto; display:flex; gap:10px; flex-wrap:wrap; position:relative; z-index:1; }

.agent-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.agent-stat-card {
  background:var(--card); border-radius:var(--r);
  padding:18px 20px; box-shadow:var(--shadow-sm);
  display:flex; align-items:center; gap:14px;
  border:1px solid var(--border-light);
  border-left:4px solid transparent; transition:all .2s;
}
.agent-stat-card:nth-child(1) { border-left-color:var(--navy); }
.agent-stat-card:nth-child(2) { border-left-color:#6366f1; }
.agent-stat-card:nth-child(3) { border-left-color:var(--warning); }
.agent-stat-card:nth-child(4) { border-left-color:var(--green); }
.agent-stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.ast-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:19px; flex-shrink:0; }
.ast-blue   { background:rgba(6,43,85,.07);  color:var(--navy); }
.ast-indigo { background:rgba(99,102,241,.1);color:#6366f1; }
.ast-amber  { background:rgba(232,151,10,.1);color:#965f00; }
.ast-green  { background:rgba(67,152,49,.1); color:var(--green-dark); }
.ast-info { flex:1; }
.ast-value { font-family:'Nunito',sans-serif !important; font-size:24px; font-weight:900; color:var(--navy); line-height:1; }
.ast-label { font-size:11.5px; color:var(--text-muted); font-weight:600; }
.ast-link { color:var(--text-muted); font-size:17px; text-decoration:none; transition:color .2s; }
.ast-link:hover { color:var(--green); }

/* ================================================================
   LISTS AGENT
================================================================ */
.proforma-list { display:flex; flex-direction:column; }
.proforma-item { display:flex; align-items:center; gap:10px; padding:13px 18px; border-bottom:1px solid var(--border-light); transition:background .15s; }
.proforma-item:hover { background:var(--green-pale); }
.pi-left { display:flex; align-items:center; min-width:190px; }
.pi-client { flex:1; font-size:13px; color:var(--text-muted); }
.pi-amount { font-family:'Nunito',sans-serif !important; font-size:13.5px; font-weight:800; color:var(--navy); min-width:150px; text-align:right; }
.pi-actions { display:flex; gap:5px; margin-left:10px; }
.client-mini-list { display:flex; flex-direction:column; }
.client-mini-item { display:flex; align-items:center; gap:12px; padding:11px 18px; border-bottom:1px solid var(--border-light); transition:background .15s; }
.client-mini-item:hover { background:#f4f8ff; }
.cmi-avatar { width:36px; height:36px; background:rgba(6,43,85,.08); color:var(--navy); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; flex-shrink:0; font-family:'Nunito',sans-serif; }
.cmi-info { flex:1; }
.cmi-info strong { display:block; font-size:13.5px; font-weight:700; }
.cmi-info span { font-size:11.5px; color:var(--text-muted); font-family:'Nunito',sans-serif; }
.cmi-polices { margin-right:4px; }
.cmi-actions { display:flex; gap:4px; }
.empty-state { text-align:center; padding:44px 20px; display:flex; flex-direction:column; align-items:center; gap:12px; }
.empty-state > i { font-size:44px; color:var(--border); }
.empty-state > p { color:var(--text-muted); font-size:13px; margin:0; }

/* ================================================================
   TYPE SELECTORS
================================================================ */
.type-facture-selector { display:flex; align-items:stretch; background:var(--card); border-radius:var(--r); box-shadow:var(--shadow-sm); overflow:hidden; border:1.5px solid var(--border-light); }
.type-btn { display:flex; align-items:center; gap:14px; padding:18px 26px; cursor:pointer; flex:1; transition:all .25s; border:none; background:none; text-align:left; }
.type-btn strong { display:block; font-size:14px; font-weight:800; color:var(--text); }
.type-btn span { display:block; font-size:12px; color:var(--text-muted); margin-top:2px; }
.type-btn i { font-size:26px; color:var(--text-muted); flex-shrink:0; }
.type-btn:hover { background:rgba(6,43,85,.03); }
.type-btn.active { background:var(--navy); }
.type-btn.active strong { color:white; }
.type-btn.active span { color:rgba(255,255,255,.55); }
.type-btn.active i { color:var(--green-light); }
.type-divider { width:44px; display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:18px; flex-shrink:0; }

.type-client-selector { display:flex; gap:16px; }
.type-client-btn { display:flex; align-items:center; gap:14px; padding:18px 22px; cursor:pointer; flex:1; background:var(--card); border-radius:var(--r); box-shadow:var(--shadow-sm); border:2px solid var(--border-light); transition:all .25s; }
.type-client-btn strong { display:block; font-size:14px; font-weight:800; color:var(--text); }
.type-client-btn span { display:block; font-size:12px; color:var(--text-muted); margin-top:2px; }
.type-client-btn i { font-size:28px; color:var(--text-muted); flex-shrink:0; }
.type-client-btn:hover { border-color:var(--green); }
.type-client-btn.active { border-color:var(--navy); background:var(--navy); }
.type-client-btn.active strong { color:white; }
.type-client-btn.active span { color:rgba(255,255,255,.55); }
.type-client-btn.active i { color:var(--green-light); }

/* ================================================================
   ACTION BOXES PROFORMA/DÉFINITIVE
================================================================ */
.form-actions { display:flex; flex-direction:column; gap:12px; }
.action-box { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 22px; border-radius:var(--r); border:1.5px solid; }
.action-proforma  { background:rgba(232,151,10,.05); border-color:rgba(232,151,10,.3); }
.action-definitive{ background:rgba(67,152,49,.05);  border-color:rgba(67,152,49,.28); }
.action-info { display:flex; align-items:center; gap:14px; }
.action-info > i { font-size:30px; }
.action-proforma  .action-info > i { color:var(--warning); }
.action-definitive .action-info > i { color:var(--green); }
.action-info strong { display:block; font-size:13.5px; font-weight:800; color:var(--text); }
.action-info span  { display:block; font-size:12px; color:var(--text-muted); }
.btn-proforma-submit { display:inline-flex; align-items:center; gap:8px; white-space:nowrap; background:var(--warning); color:white; border:none; padding:10px 22px; border-radius:var(--r-sm); font-weight:800; font-size:13px; cursor:pointer; transition:all .2s; flex-shrink:0; }
.btn-proforma-submit:hover { background:#c57d00; transform:translateY(-1px); }
.btn-definitive-submit { display:inline-flex; align-items:center; gap:8px; white-space:nowrap; background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%); color:white; border:none; padding:10px 22px; border-radius:var(--r-sm); font-weight:800; font-size:13px; cursor:pointer; transition:all .2s; flex-shrink:0; box-shadow:var(--shadow-g); }
.btn-definitive-submit:hover { filter:brightness(1.1); transform:translateY(-1px); }

/* ================================================================
   PROFORMA BANNER
================================================================ */
.proforma-banner { display:flex; align-items:center; gap:14px; background:rgba(232,151,10,.06); border:1.5px solid rgba(232,151,10,.28); border-radius:var(--r); padding:14px 20px; color:#7a4d00; }
.proforma-banner i { font-size:20px; flex-shrink:0; }
.proforma-banner strong { display:block; font-size:13px; font-weight:800; }
.proforma-banner span { font-size:12px; opacity:.8; }

/* ================================================================
   FACTURE TABS
================================================================ */
.facture-tabs { display:flex; gap:6px; }
.facture-tab { display:flex; align-items:center; gap:8px; padding:9px 18px; border-radius:var(--r-sm); text-decoration:none; color:var(--text-muted); font-size:13px; font-weight:700; background:var(--card); border:1.5px solid var(--border-light); transition:all .2s; }
.facture-tab:hover { border-color:var(--navy); color:var(--navy); }
.facture-tab.active { background:var(--navy); color:white; border-color:var(--navy); box-shadow:0 3px 10px rgba(6,43,85,.25); }
.tab-count { font-family:'Nunito',sans-serif; font-size:11px; font-weight:900; padding:1px 7px; border-radius:20px; }
.facture-tab:not(.active) .tab-count { background:rgba(6,43,85,.07); color:var(--navy); }
.facture-tab.active .tab-count { background:rgba(255,255,255,.2); color:white; }
.proforma-count  { background:rgba(232,151,10,.13) !important; color:#7a4d00 !important; }
.definitive-count{ background:rgba(67,152,49,.12) !important; color:var(--green-dark) !important; }

/* ================================================================
   LIGNE FACTURE
================================================================ */
.ligne-facture { background:linear-gradient(135deg,#f5f9f3 0%,#edf7e9 100%); border:1.5px solid #c5dfc0; border-radius:var(--r); padding:18px; margin-bottom:14px; }
.ligne-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.ligne-num { font-size:11px; font-weight:800; color:var(--navy); text-transform:uppercase; letter-spacing:.8px; font-family:'Nunito',sans-serif; }

/* ================================================================
   TOTAUX
================================================================ */
.totaux-card { background:white; border:1.5px solid var(--border); border-radius:var(--r); overflow:hidden; width:340px; margin-left:auto; box-shadow:var(--shadow-xs); }
.totaux-row { display:flex; justify-content:space-between; padding:11px 18px; border-bottom:1px solid var(--border-light); font-size:13.5px; }
.totaux-row span:last-child { font-family:'Nunito',sans-serif; font-weight:800; }
.totaux-row:last-child { border-bottom:none; }
.totaux-final { background:var(--navy); color:white; font-weight:800; font-size:15px; }
.totaux-final span:first-child { color:rgba(255,255,255,.75); }
.totaux-final span:last-child { font-family:'Nunito',sans-serif; font-size:16px; font-weight:900; }

/* ================================================================
   CLIENT PROFILE
================================================================ */
.client-profile { text-align:center; padding:22px; border-bottom:1px solid var(--border-light); }
.avatar-lg { width:74px; height:74px; background:var(--navy); color:white; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:26px; font-weight:900; margin:0 auto 12px; font-family:'Nunito',sans-serif; box-shadow:0 4px 16px rgba(6,43,85,.25); }
.avatar-sm { width:36px; height:36px; background:rgba(6,43,85,.08); color:var(--navy); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; flex-shrink:0; font-family:'Nunito',sans-serif; }
.client-name { display:flex; align-items:center; gap:10px; }
.info-list { padding:0 18px 18px; }
.info-item { display:flex; align-items:flex-start; gap:10px; padding:9px 0; border-bottom:1px solid var(--border-light); font-size:13.5px; }
.info-item i { color:var(--green); width:16px; flex-shrink:0; margin-top:2px; }
.police-item { padding:13px 18px; border-bottom:1px solid var(--border-light); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.facture-item { padding:13px 18px; border-bottom:1px solid var(--border-light); display:flex; align-items:center; justify-content:space-between; }
.client-info-box { background:var(--green-pale); border:1px solid #c5dfc0; border-radius:var(--r-sm); padding:12px; }
.police-mini { display:flex; justify-content:space-between; font-size:12px; padding:4px 0; color:var(--text-muted); font-family:'Nunito',sans-serif; }

/* ================================================================
   INVOICE PREVIEW
================================================================ */
.invoice-preview { background:white; border-radius:var(--r); box-shadow:var(--shadow-lg); overflow:hidden; max-width:900px; border:1px solid var(--border-light); }
.invoice-header { background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 100%); padding:28px 38px; display:flex; justify-content:space-between; align-items:center; }
.invoice-brand { display:flex; align-items:center; gap:18px; color:white; }
.invoice-logo { width:56px; height:56px; border-radius:10px; background:white; padding:5px; overflow:hidden; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 10px rgba(0,0,0,.3); }
.invoice-logo img { width:100%; height:100%; object-fit:contain; }
.invoice-brand h2 { font-family:'Playfair Display',serif; font-size:20px; color:white; }
.invoice-brand p { font-size:11px; color:rgba(255,255,255,.5); }
.invoice-meta { text-align:right; }
.invoice-type-badge { font-size:11px; font-weight:800; padding:4px 12px; border-radius:var(--r-xs); text-transform:uppercase; letter-spacing:1px; display:inline-block; margin-bottom:6px; }
.badge-pro { background:rgba(232,151,10,.25); color:#ffd166; border:1px solid rgba(232,151,10,.5); }
.badge-def { background:rgba(67,152,49,.2); color:var(--green-light); border:1px solid rgba(67,152,49,.4); }
.invoice-ref { font-family:'Nunito',sans-serif !important; font-size:20px; font-weight:900; color:white; margin:4px 0; letter-spacing:0.5px; }
.invoice-dates { font-size:12px; color:rgba(255,255,255,.6); }
.invoice-dates strong { color:white; font-family:'Nunito',sans-serif; }
.invoice-parties { display:grid; grid-template-columns:1fr 1fr; gap:24px; padding:24px 38px; border-bottom:1px solid var(--border-light); }
.party-label { font-size:9.5px; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-bottom:8px; font-weight:800; }
.invoice-from, .invoice-to { font-size:13.5px; line-height:1.8; }
.invoice-to { background:rgba(6,43,85,.03); padding:14px 16px; border-radius:var(--r-sm); border:1px solid var(--border); }
.invoice-table { width:100%; border-collapse:collapse; }
.invoice-table th { background:#f0f4fa; padding:12px 26px; text-align:left; font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.9px; color:var(--navy); border-bottom:2px solid var(--border); }
.invoice-table td { padding:14px 26px; border-bottom:1px solid var(--border-light); font-size:13.5px; }
.invoice-table td strong { font-family:'Nunito',sans-serif; font-weight:800; }
.invoice-table tbody tr:hover { background:#f4f8ff; }
.invoice-totals { width:310px; margin:0 38px 0 auto; padding:20px 0; }
.totals-row { display:flex; justify-content:space-between; padding:9px 0; font-size:13.5px; color:var(--text-muted); border-bottom:1px solid var(--border-light); }
.totals-row span:last-child { font-family:'Nunito',sans-serif; font-weight:800; color:var(--text); }
.totals-grand { background:var(--navy); color:white; font-weight:800; font-size:16px; padding:13px 16px; border-radius:var(--r-sm); margin-top:8px; display:flex; justify-content:space-between; align-items:center; }
.totals-grand span:last-child { font-family:'Nunito',sans-serif; font-size:18px; font-weight:900; }
.invoice-specific-details { padding:12px 26px; background:var(--green-pale); border-top:1px solid #c5dfc0; border-bottom:1px solid #c5dfc0; }
.specific-label { font-size:9.5px; text-transform:uppercase; letter-spacing:1.5px; color:var(--green-dark); font-weight:800; margin-bottom:10px; }
.specific-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:8px; }
.specific-grid > div { background:white; border:1px solid #c5dfc0; border-radius:var(--r-sm); padding:9px 13px; }
.specific-grid > div.full { grid-column:1/-1; }
.specific-grid span { display:block; font-size:9.5px; text-transform:uppercase; color:var(--text-muted); letter-spacing:.6px; margin-bottom:2px; font-weight:700; }
.specific-grid strong { font-size:13.5px; color:var(--text); font-family:'Nunito',sans-serif; font-weight:800; }
.invoice-notes { padding:14px 38px; font-size:13px; color:var(--text-muted); border-top:1px solid var(--border-light); }
.invoice-footer-note { text-align:center; padding:13px; background:rgba(6,43,85,.03); font-size:12px; color:var(--text-muted); border-top:1px solid var(--border-light); }

/* ================================================================
   SIGNATURE
================================================================ */
.signature-section { padding:22px 26px; border-top:1px solid var(--border-light); background:#fafcff; }
.signature-title { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:1.2px; color:var(--navy); margin-bottom:16px; }
.signature-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.signature-box { background:white; border:1.5px dashed #b0c4de; border-radius:var(--r); padding:13px; text-align:center; }
.sig-label { font-size:10.5px; font-weight:800; color:var(--text-muted); text-transform:uppercase; letter-spacing:.6px; margin-bottom:10px; }
.sig-canvas { display:block; width:100%; height:100px; border:1px solid var(--border); border-radius:var(--r-xs); cursor:crosshair; background:white; touch-action:none; }
.sig-image { max-width:100%; max-height:100px; border-radius:var(--r-xs); border:1px solid var(--border); }
.sig-actions { display:flex; gap:8px; justify-content:center; margin-top:9px; }
.btn-clear-sig { background:none; border:1px solid var(--border); color:var(--text-muted); padding:4px 11px; border-radius:var(--r-xs); font-size:11px; cursor:pointer; transition:all .2s; }
.btn-clear-sig:hover { border-color:var(--danger); color:var(--danger); }
.btn-save-sig { background:var(--navy); color:white; border:none; padding:4px 14px; border-radius:var(--r-xs); font-size:11px; cursor:pointer; transition:all .2s; font-weight:700; }
.btn-save-sig:hover { background:var(--green); }
.sig-name { font-size:11.5px; color:var(--text-muted); margin-top:7px; font-style:italic; }
.sig-timestamp { text-align:center; margin-top:12px; font-size:11.5px; color:var(--green-dark); font-weight:700; }
.sig-saved-msg { text-align:center; margin-top:10px; padding:9px 16px; background:var(--green-pale); color:var(--green-dark); border-radius:var(--r-xs); font-size:12.5px; font-weight:700; }

/* ================================================================
   LOGIN PAGE
================================================================ */
.login-page { min-height:100vh; background:var(--bg); display:flex; align-items:stretch; }
.login-wrapper { display:flex; min-height:100vh; width:100%; }

.login-left {
  width:480px; flex-shrink:0;
  background:linear-gradient(160deg, var(--navy-dark) 0%, var(--navy) 60%, var(--navy-light) 100%);
  display:flex; flex-direction:column; position:relative; overflow:hidden;
}
.login-left::before { content:''; position:absolute; bottom:-100px; right:-100px; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(67,152,49,.22) 0%,transparent 70%); }
.login-left::after  { content:''; position:absolute; top:-80px;  left:-80px;  width:280px; height:280px; border-radius:50%; background:radial-gradient(circle,rgba(67,152,49,.14) 0%,transparent 70%); }
/* Accent vert en bas */
.login-left-bottom-bar { position:absolute; bottom:0; left:0; right:0; height:4px; background:linear-gradient(90deg,transparent,var(--green),var(--green-light),transparent); }

.login-left-inner { position:relative; z-index:2; display:flex; flex-direction:column; height:100%; padding:38px 40px; }
.login-logo-area { margin-bottom:44px; }
.login-logo-img { height:68px; width:auto; background:white; border-radius:14px; padding:7px 16px; object-fit:contain; box-shadow:0 6px 24px rgba(0,0,0,.3); display:block; }

.login-slogan { flex:1; display:flex; flex-direction:column; justify-content:center; }
.login-slogan h1 { font-family:'Playfair Display',serif; font-size:38px; line-height:1.2; color:white; margin-bottom:10px; }
.login-slogan h1 span { color:var(--green-light); }
.login-green-bar { width:52px; height:4px; background:linear-gradient(90deg,var(--green),var(--green-light)); border-radius:2px; margin:14px 0; }
.login-slogan p { font-size:15px; color:rgba(255,255,255,.5); line-height:1.75; max-width:360px; }

.login-features { display:flex; flex-direction:column; gap:13px; margin-top:28px; }
.login-feature-item { display:flex; align-items:center; gap:14px; color:rgba(255,255,255,.72); font-size:13.5px; font-weight:500; }
.login-feature-icon { width:38px; height:38px; flex-shrink:0; background:rgba(67,152,49,.18); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:17px; color:var(--green-light); border:1px solid rgba(67,152,49,.28); transition:all .2s; }
.login-feature-item:hover .login-feature-icon { background:rgba(67,152,49,.3); transform:scale(1.05); }

.login-contact { margin-top:auto; padding-top:28px; border-top:1px solid rgba(255,255,255,.1); }
.login-contact-row { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.login-contact-icon { width:34px; height:34px; background:rgba(67,152,49,.18); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:15px; color:var(--green-light); }
.login-contact-info p { font-size:10px; color:rgba(255,255,255,.38); text-transform:uppercase; letter-spacing:1px; font-weight:700; }
.login-contact-info strong { font-family:'Nunito',sans-serif; font-size:16px; color:var(--green-light); font-weight:900; }
.login-contact-info small { font-size:11.5px; color:rgba(255,255,255,.38); }

/* Formulaire droit */
.login-right { flex:1; display:flex; align-items:center; justify-content:center; padding:40px; background:var(--bg); }
.login-card { background:white; border-radius:22px; padding:46px 44px; width:100%; max-width:430px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden; }
.login-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--navy),var(--green)); }

.login-card-header { margin-bottom:32px; }
.login-card-logo-wrap { display:inline-flex; align-items:center; justify-content:center; width:62px; height:62px; background:var(--navy); border-radius:16px; margin-bottom:20px; overflow:hidden; padding:7px; box-shadow:0 4px 14px rgba(6,43,85,.3); }
.login-card-logo-wrap img { width:100%; height:100%; object-fit:contain; }
.login-card-header h2 { font-family:'Playfair Display',serif; font-size:28px; font-weight:800; color:var(--navy); }
.login-card-header p { color:var(--text-muted); font-size:13.5px; margin-top:5px; }

.form-group-custom { margin-bottom:20px; }
.form-group-custom label { font-size:12.5px; font-weight:800; color:var(--text); margin-bottom:7px; display:block; text-transform:uppercase; letter-spacing:.5px; }

.btn-login {
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);
  color:white; border:none; padding:15px 24px; border-radius:12px;
  font-size:15px; font-weight:800; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:10px;
  transition:all .28s; width:100%;
  box-shadow:0 4px 18px rgba(6,43,85,.3);
}
.btn-login:hover {
  background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 100%);
  transform:translateY(-2px); box-shadow:0 8px 28px rgba(67,152,49,.4);
}
.login-demo-badge { display:flex; align-items:center; gap:10px; background:var(--green-pale); border:1px solid #c5dfc0; border-radius:var(--r-sm); padding:11px 14px; margin-top:20px; font-size:12.5px; color:var(--green-dark); }
.login-demo-badge i { font-size:15px; color:var(--green); }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width:1400px) { .kpi-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:1100px) { .kpi-grid { grid-template-columns:repeat(2,1fr); } .stats-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .main-content { margin-left:0; padding:16px; }
  .topbar { left:0; }
  .btn-sidebar-toggle { display:block; }
  .login-left { display:none; }
  .type-facture-selector,.type-client-selector { flex-direction:column; }
  .signature-grid { grid-template-columns:1fr; }
  .facture-tabs { flex-wrap:wrap; }
  .totaux-card { width:100%; }
  .invoice-parties { grid-template-columns:1fr; }
  .agent-welcome { flex-direction:column; text-align:center; }
  .welcome-actions { justify-content:center; }
  .kpi-grid,.agent-stats-grid,.quick-actions { grid-template-columns:repeat(2,1fr); }
}
