/* v1773875889 */
/* ── ONGLETS ADMIN ── */
.admin-tabs-bar {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 0 8px;
  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;
  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(--accent);
  border-bottom-color: var(--accent);
}
.admin-tab-btn i { font-size: 13px; }
.admin-tab-pane { display: none; }
.admin-tab-pane.active { display: block; }

/* Alias legacy → tokens du Design System (akmous-ds).
   On NE redéfinit plus --border/--text/--bg : on hérite des tokens DS
   (clair ET sombre selon [data-theme]). */
:root {
  --primary: var(--accent);
  --primary-dk: var(--accent-hover);
  --surface: var(--bg-secondary);
  --muted: var(--text-secondary);
}

.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(--accent);color:var(--text-on-accent);} .btn-primary:hover{background:var(--accent-hover);}
.btn-ghost{background:none;color:var(--muted);border:1px solid var(--border);} .btn-ghost:hover{background:var(--bg-hover);color:var(--text);}
.btn-sm{padding:6px 12px;font-size:12px;}
.btn-danger{background:var(--danger-subtle);color:var(--danger-text);border:1px solid var(--danger-border);} .btn-danger:hover{background:var(--danger-subtle);}
.btn-ok{background:var(--success-subtle);color:var(--success-text);border:1px solid var(--success-border);} .btn-ok:hover{background:var(--success-subtle);}

.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:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);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:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);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(--bg-tertiary);}
td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text);}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--bg-hover);}

.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:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:28px;width:92%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-overlay);}
.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:var(--radius-md);font-size:13px;outline:none;transition:border-color .15s;background:var(--bg-tertiary);color:var(--text);}
.fg input:focus,.fg select:focus{border-color:var(--accent);box-shadow:var(--ring);}
.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:var(--radius-full);border:1px solid var(--border);background:var(--bg-elevated);font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);transition:all .15s;}
.filter-btn:hover{border-color:var(--accent);color:var(--accent);}
.filter-btn.active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent);}

.page-btn{padding:5px 10px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elevated);font-size:12px;cursor:pointer;color:var(--text);}
.page-btn:hover{background:var(--bg-hover);}
.page-btn.active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent);}

/* ── 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(--accent); border-bottom-color: var(--accent); }
.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;}

  /* Admin tabs scroll horizontal */
  .admin-tabs-bar{overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap;}
  .admin-tabs-bar::-webkit-scrollbar{display:none;}
  .admin-tab-btn{flex-shrink:0;padding:12px 14px;font-size:12px;}

  /* Legal sub-tabs scroll */
  .legal-sub-btn{flex-shrink:0;font-size:12px;}

  .page{padding:16px 12px;}
}
@media(max-width:480px){
  .stats-row{grid-template-columns:1fr;}
  .admin-tab-btn{padding:10px 12px;font-size:11px;}
}

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: var(--radius-md);
  padding: 0 10px;
  font-size: 13px;
  color: var(--text);
  background: var(--bg-tertiary);
  width: 100%;
  box-sizing: border-box;
}
.sim-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: var(--ring);
}
