/* ============================================================
   BURGER SHOT MDT — Feuille de style principale
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@500;700&family=Inter:wght@300;400;500;600&display=swap');

/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --bs-red:        #C8152A;
  --bs-red-dark:   #8B0E1C;
  --bs-red-light:  #E8384A;
  --bs-yellow:     #F5C842;
  --bs-yellow-dk:  #C49B1A;
  --bs-bg:         #0E0C0C;
  --bs-surf:       #1A1614;
  --bs-surf2:      #221E1C;
  --bs-surf3:      #2A2422;
  --bs-border:     rgba(200,21,42,0.20);
  --bs-border2:    rgba(200,21,42,0.40);
  --bs-text:       #F0EBE8;
  --bs-muted:      #9A8E89;
  --bs-dim:        #6A5E5A;
  --radius:        10px;
  --radius-lg:     14px;
}

html, body { height:100%; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--bs-bg);
  color: var(--bs-text);
  font-size: 14px;
  line-height: 1.5;
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font-family: inherit; }
img { max-width: 100%; }

/* ── Auth Pages ────────────────────────────────────────────── */
.auth-page { display:flex; align-items:center; justify-content:center; min-height:100vh; position:relative; overflow:hidden; }

.auth-bg {
  position:fixed; inset:0; z-index:0;
  background: radial-gradient(ellipse at center, #1a0a0d 0%, #0E0C0C 70%);
}
.auth-bg::after {
  content:'';
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(0deg,  transparent, transparent 40px, rgba(200,21,42,.03) 40px, rgba(200,21,42,.03) 41px),
    repeating-linear-gradient(90deg, transparent, transparent 40px, rgba(200,21,42,.03) 40px, rgba(200,21,42,.03) 41px);
}

.auth-center {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:1.5rem;
  width:100%; max-width:420px; padding:1.5rem;
}

.auth-logo { display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.auth-logo-title {
  font-family:'Rajdhani',sans-serif;
  font-size:28px; font-weight:700;
  text-transform:uppercase; letter-spacing:3px;
  color:var(--bs-yellow);
}

.auth-card {
  width:100%;
  background:var(--bs-surf);
  border:1px solid var(--bs-border2);
  border-radius:var(--radius-lg);
  padding:2rem;
}

.auth-title {
  font-family:'Rajdhani',sans-serif;
  font-size:24px; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
  color:var(--bs-yellow);
  text-align:center; margin-bottom:.3rem;
}

.auth-sub { text-align:center; color:var(--bs-muted); font-size:13px; margin-bottom:1.5rem; }

/* ── Discord preview ─────────────────────────────────────── */
.discord-preview {
  display:flex; align-items:center; gap:12px;
  background:var(--bs-surf2); border-radius:var(--radius);
  padding:12px 14px; border:1px solid var(--bs-border);
  margin-bottom:1.25rem;
}
.discord-avatar-img { width:42px; height:42px; border-radius:50%; object-fit:cover; }
.discord-name { font-weight:600; font-size:14px; }
.discord-tag  { color:var(--bs-muted); font-size:12px; }

/* ── Discord Button ──────────────────────────────────────── */
.btn-discord {
  display:flex; align-items:center; justify-content:center; gap:10px;
  width:100%; padding:14px;
  background:#5865F2; border:none; border-radius:var(--radius);
  color:#fff; font-size:15px; font-weight:600;
  cursor:pointer; transition:background .2s, transform .15s;
}
.btn-discord:hover { background:#4752c4; transform:translateY(-1px); }
.btn-discord svg { width:22px; height:22px; }

/* ── Code input ─────────────────────────────────────────── */
.code-row { display:flex; gap:8px; justify-content:center; margin-bottom:1rem; }
.code-digit {
  width:52px; height:60px;
  background:var(--bs-surf2); border:2px solid var(--bs-border2);
  border-radius:var(--radius); color:var(--bs-text);
  font-size:26px; font-weight:700; text-align:center;
  font-family:'Rajdhani',sans-serif;
  transition:border-color .2s; outline:none;
}
.code-digit:focus { border-color:var(--bs-red); }

/* ── Buttons ────────────────────────────────────────────── */
.btn-primary {
  display:block; width:100%; padding:13px;
  background:var(--bs-red); border:none; border-radius:var(--radius);
  color:#fff; font-size:14px; font-weight:600;
  cursor:pointer; transition:background .2s; margin-top:.5rem;
}
.btn-primary:hover { background:var(--bs-red-light); }

.btn-secondary {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px;
  background:var(--bs-surf2); border:1px solid var(--bs-border2);
  border-radius:var(--radius); color:var(--bs-text); font-size:13px; font-weight:500;
  cursor:pointer; transition:all .15s;
}
.btn-secondary:hover { background:var(--bs-surf3); }

.btn-danger {
  padding:6px 12px;
  background:rgba(200,21,42,.15); border:1px solid var(--bs-border2);
  border-radius:6px; color:var(--bs-red-light); font-size:12px; font-weight:600;
  cursor:pointer; transition:all .15s;
}
.btn-danger:hover { background:rgba(200,21,42,.3); }

.btn-sm {
  padding:5px 10px; border-radius:6px;
  font-size:12px; font-weight:600; cursor:pointer;
  border:none; transition:all .15s;
}

.back-link { display:block; text-align:center; color:var(--bs-muted); font-size:13px; margin-top:1rem; }
.back-link:hover { color:var(--bs-text); }

/* ── Alerts ─────────────────────────────────────────────── */
.alert {
  padding:11px 14px; border-radius:var(--radius);
  font-size:13px; margin-bottom:1rem;
  display:flex; align-items:center; gap:8px;
}
.alert-error   { background:rgba(200,21,42,.12); border:1px solid var(--bs-border2); color:var(--bs-red-light); }
.alert-success { background:rgba(100,200,100,.1); border:1px solid rgba(100,200,100,.25); color:#7ECF7E; }
.alert-info    { background:rgba(100,150,255,.1); border:1px solid rgba(100,150,255,.25); color:#7BA8FF; }
.alert-warning { background:rgba(245,200,66,.1);  border:1px solid rgba(245,200,66,.25);  color:var(--bs-yellow); }

/* ── Form elements ──────────────────────────────────────── */
.form-group { margin-bottom:1rem; }
.form-label {
  display:block; margin-bottom:6px;
  font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.8px;
  color:var(--bs-muted);
}
.form-input, .form-select {
  width:100%; padding:10px 12px;
  background:var(--bs-surf2); border:1px solid var(--bs-border2);
  border-radius:var(--radius); color:var(--bs-text); font-size:14px;
  outline:none; transition:border-color .2s;
}
.form-input:focus, .form-select:focus { border-color:var(--bs-red); }
.form-select { cursor:pointer; }

/* ── App Layout ─────────────────────────────────────────── */
.app-layout { display:flex; min-height:100vh; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar {
  width:220px; min-width:220px;
  background:var(--bs-surf);
  border-right:1px solid var(--bs-border);
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh;
  padding:1.25rem 0;
  overflow-y:auto;
}

.sidebar-logo {
  display:flex; align-items:center; gap:10px;
  padding:0 1.25rem 1.25rem;
  border-bottom:1px solid var(--bs-border);
  margin-bottom:.75rem;
}
.sidebar-logo-img {
  width:42px; height:42px; border-radius:50%;
  flex-shrink:0; overflow:hidden;
}
.sidebar-logo-img img { width:100%; height:100%; object-fit:cover; }
.logo-brand {
  font-family:'Rajdhani',sans-serif;
  font-size:18px; font-weight:700;
  color:var(--bs-yellow); letter-spacing:1px; text-transform:uppercase;
}
.logo-sub { font-size:10px; color:var(--bs-dim); text-transform:uppercase; letter-spacing:.5px; }

.nav-section {
  font-size:10px; font-weight:600;
  text-transform:uppercase; letter-spacing:1.5px;
  color:var(--bs-dim); padding:.75rem 1.25rem .3rem;
}

.nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 1.25rem; cursor:pointer;
  color:var(--bs-muted); font-size:13.5px; font-weight:500;
  border-left:2px solid transparent;
  transition:all .15s; text-decoration:none;
}
.nav-item:hover  { color:var(--bs-text); background:rgba(200,21,42,.08); }
.nav-item.active { color:var(--bs-yellow); border-left-color:var(--bs-red); background:rgba(200,21,42,.12); }
.nav-icon { width:20px; text-align:center; font-size:14px; }

.sidebar-footer {
  margin-top:auto; padding:1rem 1.25rem;
  border-top:1px solid var(--bs-border);
}
.sidebar-user { display:flex; align-items:center; gap:10px; }
.sidebar-avatar {
  width:34px; height:34px; border-radius:50%;
  object-fit:cover; flex-shrink:0;
}
.sidebar-avatar-fallback {
  width:34px; height:34px; border-radius:50%;
  background:linear-gradient(135deg,#5865F2,#7289da);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:13px; color:#fff; flex-shrink:0;
}
.sidebar-uname { font-size:13px; font-weight:600; color:var(--bs-text); }
.sidebar-grade { margin-top:2px; }
.btn-logout {
  background:none; border:none; color:var(--bs-dim);
  font-size:12px; cursor:pointer; margin-top:8px;
  transition:color .2s; text-align:left;
}
.btn-logout:hover { color:var(--bs-red-light); }

/* ── Grade badges ───────────────────────────────────────── */
.badge {
  display:inline-block; font-size:10px; font-weight:600;
  padding:2px 8px; border-radius:4px;
  text-transform:uppercase; letter-spacing:.5px;
}
.badge-patronne  { background:rgba(245,200,66,.15); color:var(--bs-yellow);    border:1px solid rgba(245,200,66,.3); }
.badge-copatron  { background:rgba(245,200,66,.10); color:#D4A830;             border:1px solid rgba(212,168,48,.3); }
.badge-manageur  { background:rgba(200,21,42,.15);  color:var(--bs-red-light); border:1px solid rgba(200,21,42,.3); }
.badge-employe   { background:rgba(100,150,255,.15);color:#7BA8FF;             border:1px solid rgba(100,150,255,.3); }
.badge-stagiaire { background:rgba(100,200,100,.10);color:#7ECF7E;             border:1px solid rgba(100,200,100,.25); }

/* ── Service Bar ────────────────────────────────────────── */
.service-bar {
  display:flex; align-items:center; gap:14px;
  background:var(--bs-surf); border-bottom:1px solid var(--bs-border);
  padding:.7rem 2rem; position:sticky; top:0; z-index:10;
}
.svc-dot {
  width:8px; height:8px; border-radius:50%;
  background:#555; flex-shrink:0; transition:background .3s;
}
.svc-dot.on { background:#4CAF50; box-shadow:0 0 6px rgba(76,175,80,.6); }
.svc-label  { font-size:13px; font-weight:500; color:var(--bs-muted); }
.svc-timer  {
  font-family:'Rajdhani',sans-serif;
  font-size:20px; font-weight:700; letter-spacing:1px; color:var(--bs-text);
}
.btn-svc {
  padding:7px 16px; border-radius:8px;
  font-size:12px; font-weight:600; cursor:pointer; border:none;
  transition:all .2s;
}
.btn-svc.start { background:#1E6B30; color:#7ECF7E; }
.btn-svc.start:hover { background:#27833C; }
.btn-svc.stop  { background:rgba(200,21,42,.2); color:var(--bs-red-light); border:1px solid var(--bs-border2); }
.btn-svc.stop:hover  { background:rgba(200,21,42,.3); }
.svc-salary { margin-left:auto; display:flex; align-items:center; gap:10px; font-size:12px; color:var(--bs-muted); }
.salary-val {
  font-family:'Rajdhani',sans-serif;
  font-size:20px; font-weight:700; color:var(--bs-yellow);
}

/* ── Main Content ───────────────────────────────────────── */
.main-content { flex:1; overflow-y:auto; }
.page-content { padding:2rem; max-width:1200px; }

.page-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1.75rem;
}
.page-title {
  font-family:'Rajdhani',sans-serif;
  font-size:26px; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
}
.page-title span { color:var(--bs-red); }

/* ── Stat Cards ─────────────────────────────────────────── */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(155px,1fr));
  gap:12px; margin-bottom:1.75rem;
}
.stat-card {
  background:var(--bs-surf); border:1px solid var(--bs-border);
  border-radius:var(--radius); padding:1rem 1.15rem;
  position:relative; overflow:hidden;
}
.stat-card::after {
  content:''; position:absolute;
  top:0; left:0; right:0; height:2px;
  background:var(--bs-red); opacity:.6;
}
.stat-card.yellow::after { background:var(--bs-yellow); }
.stat-label {
  font-size:10px; text-transform:uppercase; letter-spacing:1px;
  color:var(--bs-muted); margin-bottom:6px; font-weight:600;
}
.stat-val {
  font-family:'Rajdhani',sans-serif;
  font-size:26px; font-weight:700; line-height:1;
}
.stat-sub { font-size:11px; color:var(--bs-dim); margin-top:4px; }

/* ── Section Cards ──────────────────────────────────────── */
.section-card {
  background:var(--bs-surf); border:1px solid var(--bs-border);
  border-radius:var(--radius-lg); padding:1.5rem; margin-bottom:1.5rem;
}
.section-title {
  font-family:'Rajdhani',sans-serif;
  font-size:15px; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px;
  margin-bottom:1.25rem;
  display:flex; align-items:center; gap:8px;
}
.section-title::before {
  content:''; width:3px; height:16px;
  background:var(--bs-red); border-radius:2px;
}

/* ── Table ──────────────────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; font-size:13px; }
.data-table th {
  text-align:left; padding:9px 12px;
  font-size:10px; text-transform:uppercase; letter-spacing:1px;
  color:var(--bs-dim); border-bottom:1px solid var(--bs-border); font-weight:600;
}
.data-table td {
  padding:11px 12px; border-bottom:1px solid rgba(200,21,42,.06); color:var(--bs-text);
}
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(200,21,42,.04); }

/* ── User row in table ──────────────────────────────────── */
.user-cell { display:flex; align-items:center; gap:10px; }
.tbl-avatar {
  width:30px; height:30px; border-radius:50%;
  object-fit:cover; flex-shrink:0;
}
.tbl-avatar-fallback {
  width:30px; height:30px; border-radius:50%;
  background:linear-gradient(135deg,#5865F2,#7289da);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:#fff; flex-shrink:0;
}
.tbl-name { font-size:13px; font-weight:600; }
.tbl-tag  { font-size:11px; color:var(--bs-muted); }

/* ── Products ───────────────────────────────────────────── */
.products-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(155px,1fr));
  gap:14px;
}
.product-card {
  background:var(--bs-surf2); border:1px solid var(--bs-border);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color .2s;
}
.product-card:hover { border-color:var(--bs-border2); }
.product-thumb {
  width:100%; height:108px;
  background:var(--bs-surf3);
  display:flex; align-items:center; justify-content:center;
  font-size:44px; overflow:hidden;
}
.product-thumb img { width:100%; height:100%; object-fit:cover; }
.product-body { padding:10px 12px; }
.product-name { font-weight:600; font-size:13px; margin-bottom:4px; }
.product-price {
  font-family:'Rajdhani',sans-serif;
  font-size:18px; font-weight:700; color:var(--bs-yellow);
}
.product-actions { margin-top:8px; }

/* ── Add product placeholder ────────────────────────────── */
.btn-add-product {
  width:100%; padding:13px;
  background:rgba(200,21,42,.08);
  border:1px dashed var(--bs-border2); border-radius:var(--radius-lg);
  color:var(--bs-red-light); font-size:13px; font-weight:600;
  cursor:pointer; margin-top:14px; transition:all .2s;
}
.btn-add-product:hover { background:rgba(200,21,42,.16); }

/* ── Code gen ───────────────────────────────────────────── */
.code-gen-box {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--bs-surf2); border:1px solid var(--bs-border);
  border-radius:var(--radius); padding:1rem 1.25rem; margin-bottom:1rem;
}
.gen-code-val {
  font-family:'Rajdhani',sans-serif;
  font-size:28px; font-weight:700; letter-spacing:4px; color:var(--bs-yellow);
}
.gen-code-info { font-size:12px; color:var(--bs-muted); margin-top:4px; }
.btn-gen {
  padding:10px 18px; background:var(--bs-red);
  border:none; border-radius:var(--radius);
  color:#fff; font-size:13px; font-weight:600;
  cursor:pointer; transition:all .2s; white-space:nowrap;
}
.btn-gen:hover { background:var(--bs-red-light); }

/* ── Member rows ────────────────────────────────────────── */
.member-row {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px; background:var(--bs-surf2);
  border-radius:var(--radius); margin-bottom:8px;
  border:1px solid var(--bs-border);
}
.member-avatar {
  width:36px; height:36px; border-radius:50%;
  object-fit:cover; flex-shrink:0;
}
.member-avatar-fallback {
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg,#5865F2,#7289da);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:13px; color:#fff; flex-shrink:0;
}
.member-name { font-size:14px; font-weight:600; flex:1; }
.member-tag  { font-size:11px; color:var(--bs-muted); }

/* ── Grade select ───────────────────────────────────────── */
.grade-select {
  background:var(--bs-surf); border:1px solid var(--bs-border2);
  border-radius:6px; color:var(--bs-text); font-size:12px;
  padding:5px 8px; cursor:pointer; outline:none;
}

/* ── Modal ──────────────────────────────────────────────── */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.75); z-index:1000;
  align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--bs-surf); border:1px solid var(--bs-border2);
  border-radius:var(--radius-lg); padding:2rem;
  width:400px; max-width:95vw; max-height:90vh; overflow-y:auto;
}
.modal h3 {
  font-family:'Rajdhani',sans-serif;
  font-size:20px; font-weight:700;
  text-transform:uppercase; letter-spacing:1px;
  color:var(--bs-yellow); margin-bottom:1.25rem;
}
.modal-actions { display:flex; gap:10px; margin-top:1.25rem; }
.btn-cancel {
  flex:1; padding:11px;
  background:var(--bs-surf2); border:1px solid var(--bs-border);
  border-radius:var(--radius); color:var(--bs-muted); cursor:pointer;
}
.btn-confirm {
  flex:2; padding:11px; background:var(--bs-red);
  border:none; border-radius:var(--radius);
  color:#fff; font-weight:600; cursor:pointer;
  transition:background .2s;
}
.btn-confirm:hover { background:var(--bs-red-light); }

/* ── Upload img placeholder ─────────────────────────────── */
.img-drop {
  width:100%; height:140px;
  background:var(--bs-surf3); border:1px dashed var(--bs-border2);
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:8px;
  cursor:pointer; margin-bottom:1rem; transition:all .2s;
  color:var(--bs-muted); font-size:13px;
}
.img-drop:hover { border-color:var(--bs-red); background:rgba(200,21,42,.05); }
.img-drop img { width:100%; height:100%; object-fit:cover; border-radius:var(--radius); }

/* ── Scrollbar ──────────────────────────────────────────── */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:var(--bs-surf); }
::-webkit-scrollbar-thumb { background:var(--bs-border2); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--bs-red); }

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:768px) {
  .sidebar { display:none; }
  .page-content { padding:1rem; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}
