/* v1773875889 */
/* ── ONGLETS ADMIN ── */
.admin-tabs-bar {
  background: #fff;
  border-bottom: 2px solid var(--border);
  display: flex;
  gap: 0;
  margin-bottom: 24px;
  overflow-x: auto;
  scrollbar-width: none;
}
.admin-tabs-bar::-webkit-scrollbar { display: none; }
.admin-tab-btn {
  padding: 14px 22px;
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
  transition: color .12s;
}
.admin-tab-btn:hover { color: var(--text); }
.admin-tab-btn.active {
  color: var(--primary);
  border-bottom-color: var(--primary);
}
.admin-tab-btn i { font-size: 13px; }
.admin-tab-pane { display: none; }
.admin-tab-pane.active { display: block; }

:root {
  --primary:#2563eb; --primary-dk:#1d4ed8; --surface:#f8fafc;
  --border:#e2e8f0; --text:#1e293b; --muted:#64748b;
  --success:#16a34a; --warning:#d97706; --danger:#dc2626; --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--surface);color:var(--text);min-height:100vh;}

.topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 24px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;}
.topbar-left{display:flex;align-items:center;gap:16px;}
.brand{font-size:18px;font-weight:700;color:var(--primary);}
.page-title{font-size:15px;font-weight:600;}
.sep{color:var(--border);font-size:20px;}
.topbar-right{display:flex;align-items:center;gap:10px;}

.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none;}
.btn-primary{background:var(--primary);color:#fff;} .btn-primary:hover{background:var(--primary-dk);}
.btn-ghost{background:none;color:var(--muted);border:1px solid var(--border);} .btn-ghost:hover{background:var(--surface);color:var(--text);}
.btn-sm{padding:6px 12px;font-size:12px;}
.btn-danger{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;} .btn-danger:hover{background:#fee2e2;}
.btn-ok{background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0;} .btn-ok:hover{background:#dcfce7;}

.page{max-width:1100px;margin:0 auto;padding:28px 24px;}

.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;}
.stat-card .val{font-size:28px;font-weight:700;color:var(--primary);}
.stat-card .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;}

.section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;overflow:hidden;}
.sec-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.sec-head h2{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;}

.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface);}
td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:#fafafa;}

.role-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.r-admin{background:#eff6ff;color:#1d4ed8;} .r-commercial{background:#f0fdf4;color:#15803d;}
.r-agent{background:#fef3c7;color:#92400e;} .r-adv{background:#f5f3ff;color:#5b21b6;}

.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;}
.dot-on{background:var(--success);} .dot-off{background:#cbd5e1;} .dot-exp{background:var(--danger);}

.avatar{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;}

.row-actions{display:flex;gap:6px;}

.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9999;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-box{background:#fff;border-radius:16px;padding:28px;width:92%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.modal-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:20px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg.full{grid-column:1/-1;}
.fg label{font-size:12px;font-weight:600;color:var(--text);}
.fg input,.fg select{padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:13px;outline:none;transition:border-color .15s;background:#fff;}
.fg input:focus,.fg select:focus{border-color:var(--primary);}
.modal-footer{display:flex;gap:10px;margin-top:20px;}
.modal-footer .btn{flex:1;justify-content:center;padding:11px;}

.perms-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;}
.perm-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;}
.perm-item input{width:15px;height:15px;cursor:pointer;accent-color:var(--primary);}

.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 16px;font-size:13px;color:#1d4ed8;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;line-height:1.5;}

.toast{position:fixed;bottom:24px;right:24px;z-index:99999;background:#1e293b;color:#fff;padding:12px 18px;border-radius:10px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:su .25s ease;}
.toast.success{background:var(--success);} .toast.error{background:var(--danger);}
@keyframes su{from{transform:translateY(16px);opacity:0;}to{transform:translateY(0);opacity:1;}}

.loader{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--muted);gap:10px;}
.spin{animation:sp .8s linear infinite;} @keyframes sp{to{transform:rotate(360deg);}}
.empty td{text-align:center;padding:32px;color:var(--muted);}

.filter-btn{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);transition:all .15s;}
.filter-btn:hover{border-color:var(--primary);color:var(--primary);}
.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;}

.page-btn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:#fff;font-size:12px;cursor:pointer;color:var(--text);}
.page-btn:hover{background:var(--surface);}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;}

/* ── ONGLET LÉGAL ── */
.legal-sub-btn {
  padding: 10px 18px;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  transition: color .12s;
}
.legal-sub-btn:hover { color: var(--text); }
.legal-sub-btn.active { color: var(--primary); border-bottom-color: var(--primary); }
.legal-pane { display: none; }
.legal-pane.active { display: block; }

@media(max-width:768px){.stats-row{grid-template-columns:1fr 1fr;}.form-grid{grid-template-columns:1fr;}.perms-grid{grid-template-columns:1fr;}}

nav.nav-tabs,nav.nav-tabs *{display:none!important;height:0!important;min-height:0!important;padding:0!important;margin:0!important;border:none!important;overflow:hidden!important;}

/* ── STYLES EXTRAITS DE HTML (Simulateur & Auth) ── */
#auth-hide { display: none !important; }

.sim-input {
  height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0 10px;
  font-size: 13px;
  color: #1e293b;
  background: #fff;
  width: 100%;
  box-sizing: border-box;
}
.sim-input:focus {
  outline: none;
  border-color: var(--primary);
}
