/* Dashboard — thème noir/violet (cohérent avec le site vitrine) */
:root {
  --bg:#08070d; --bg-2:#0d0b16; --panel:rgba(255,255,255,.03); --panel-2:rgba(255,255,255,.05);
  --line:rgba(168,85,247,.16); --line-soft:rgba(255,255,255,.07); --text:#efedf7; --muted:#9c97b4;
  --muted-2:#6f6987; --violet:#8b5cf6; --violet-bright:#a855f7; --violet-glow:#c084fc;
  --green:#4ade80; --red:#ed4245; --amber:#fbbf24;
}
* { box-sizing:border-box; margin:0; padding:0; }
body { font-family:'Instrument Sans',system-ui,sans-serif; background:var(--bg); color:var(--text); line-height:1.55; min-height:100vh; }
body::before { content:''; position:fixed; inset:0; z-index:-1;
  background:radial-gradient(600px 400px at 0% 0%,rgba(139,92,246,.16),transparent 60%),
  radial-gradient(700px 500px at 100% 0%,rgba(232,121,249,.08),transparent 55%),var(--bg); }
a { color:inherit; text-decoration:none; }
h1 { font-family:'Bricolage Grotesque',sans-serif; font-size:30px; margin-bottom:6px; }
h2 { font-family:'Bricolage Grotesque',sans-serif; font-size:21px; margin:8px 0 14px; }
.subtitle { color:var(--muted); margin-bottom:26px; }
.muted { color:var(--muted); }

.topbar { position:sticky; top:0; z-index:40; height:62px; display:flex; align-items:center; justify-content:space-between;
  padding:0 22px; background:rgba(8,7,13,.8); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-soft); }
.topbar .brand { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:22px; display:flex; align-items:center; gap:9px; }
.topbar .brand .dot { width:11px; height:11px; border-radius:50%; background:var(--violet-bright); box-shadow:0 0 14px var(--violet-glow); }
.topbar .right { display:flex; align-items:center; gap:14px; }
.topbar .right a.site { color:var(--muted); font-size:14px; }
.user-chip { display:flex; align-items:center; gap:9px; padding:5px 10px 5px 6px; border-radius:99px; border:1px solid var(--line-soft); background:var(--panel); }
.user-chip img { width:28px; height:28px; border-radius:50%; }
.user-chip .logout { color:var(--muted); font-size:13px; border-left:1px solid var(--line-soft); padding-left:10px; }
.user-chip .logout:hover { color:var(--red); }

.shell { display:flex; min-height:calc(100vh - 62px); }
.sidebar { width:250px; flex-shrink:0; padding:22px 14px; border-right:1px solid var(--line-soft); background:rgba(13,11,22,.5); }
.sidebar .srv { display:flex; align-items:center; gap:11px; padding:10px 12px; margin-bottom:14px; border-radius:12px; background:var(--panel); border:1px solid var(--line-soft); }
.sidebar .srv img, .sidebar .srv .ph { width:38px; height:38px; border-radius:10px; object-fit:cover; }
.sidebar .srv .ph { background:linear-gradient(135deg,var(--violet),var(--violet-bright)); display:flex; align-items:center; justify-content:center; font-weight:700; }
.sidebar .srv .nm { font-weight:600; font-size:14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.nav-section { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--muted-2); margin:18px 12px 8px; }
.nav-link { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:10px; color:var(--muted); font-size:14.5px; font-weight:500; transition:.13s; }
.nav-link:hover { color:var(--text); background:var(--panel); }
.nav-link.active { color:#fff; background:linear-gradient(135deg,rgba(139,92,246,.25),rgba(168,85,247,.15)); border:1px solid var(--line); }
.nav-link .ic { width:20px; text-align:center; }
.content { flex:1; padding:34px 40px; max-width:960px; }

.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:16px; }
.card { display:block; padding:20px; border-radius:16px; border:1px solid var(--line-soft); background:var(--panel); transition:.17s; }
.card:hover { border-color:var(--violet); transform:translateY(-3px); }
.card .srv-head { display:flex; align-items:center; gap:13px; margin-bottom:14px; }
.card .srv-head img, .card .srv-head .ph { width:52px; height:52px; border-radius:14px; object-fit:cover; }
.card .srv-head .ph { background:linear-gradient(135deg,var(--violet),var(--violet-bright)); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:20px; }
.card h3 { font-size:16px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.card .meta { color:var(--muted-2); font-size:12px; }
.card .action { margin-top:14px; }

.btn { display:inline-flex; align-items:center; gap:8px; padding:11px 20px; border-radius:11px; font-weight:600; font-size:14.5px; border:1px solid transparent; cursor:pointer; transition:.16s; font-family:inherit; }
.btn-primary { background:linear-gradient(135deg,var(--violet),var(--violet-bright)); color:#fff; box-shadow:0 6px 22px rgba(139,92,246,.3); }
.btn-primary:hover { transform:translateY(-2px); }
.btn-ghost { background:var(--panel); color:var(--text); border-color:var(--line); }
.btn-ghost:hover { border-color:var(--violet); }
.btn-discord { background:#5865f2; color:#fff; }
.btn-block { width:100%; justify-content:center; }
.badge { display:inline-block; padding:4px 11px; border-radius:99px; font-size:12px; font-weight:600; }
.badge.premium { color:var(--amber); border:1px solid rgba(251,191,36,.4); background:rgba(251,191,36,.08); }
.badge.in { color:var(--green); border:1px solid rgba(74,222,128,.35); background:rgba(74,222,128,.07); }
.badge.out { color:var(--muted); border:1px solid var(--line-soft); }
.notice { padding:12px 16px; border-radius:12px; margin-bottom:20px; border:1px solid rgba(74,222,128,.35); background:rgba(74,222,128,.08); color:var(--green); font-weight:500; }

.module-row { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:18px 20px; border:1px solid var(--line-soft); border-radius:14px; background:var(--panel); margin-bottom:12px; }
.module-row .ic { font-size:24px; }
.module-row .name { font-weight:600; }
.module-row .desc { color:var(--muted); font-size:13.5px; }
.module-row .left { display:flex; align-items:center; gap:15px; }

.switch { position:relative; display:inline-block; width:48px; height:27px; flex-shrink:0; }
.switch input { display:none; }
.slider { position:absolute; inset:0; background:#2a2740; border-radius:99px; transition:.2s; }
.slider::before { content:''; position:absolute; height:21px; width:21px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.2s; }
.switch input:checked + .slider { background:linear-gradient(135deg,var(--violet),var(--violet-bright)); }
.switch input:checked + .slider::before { transform:translateX(21px); }

.panel { padding:24px; border:1px solid var(--line-soft); border-radius:16px; background:var(--panel); margin-bottom:18px; }
.field { margin-bottom:18px; }
.field label { display:block; font-size:13px; font-weight:600; color:var(--muted); margin-bottom:7px; text-transform:uppercase; letter-spacing:.04em; }
.field input[type=text], .field input[type=number], .field textarea, .field select {
  width:100%; padding:11px 14px; border-radius:11px; background:var(--bg-2); border:1px solid var(--line-soft); color:var(--text); font-size:15px; font-family:inherit; outline:none; }
.field input:focus, .field textarea:focus, .field select:focus { border-color:var(--violet); }
.field textarea { min-height:90px; resize:vertical; }
.field .hint { color:var(--muted-2); font-size:12.5px; margin-top:6px; }
.row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.check-row { display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--line-soft); }
.check-row:last-child { border-bottom:0; }
.check-row .t { font-weight:500; }

.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; }
.login-card { width:100%; max-width:420px; padding:40px; border-radius:22px; border:1px solid var(--line); background:var(--panel); text-align:center; }
.login-card .logo { font-family:'Bricolage Grotesque',sans-serif; font-size:34px; font-weight:700; margin-bottom:8px; }
.login-card p { color:var(--muted); margin-bottom:28px; }

.empty { color:var(--muted); padding:40px; text-align:center; border:1px dashed var(--line-soft); border-radius:16px; }
table.data { width:100%; border-collapse:collapse; }
table.data th, table.data td { padding:11px 14px; border-bottom:1px solid var(--line-soft); text-align:left; font-size:14px; }
table.data th { color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.05em; }

@media (max-width:820px) {
  .shell { flex-direction:column; }
  .sidebar { width:100%; border-right:0; border-bottom:1px solid var(--line-soft); }
  .content { padding:24px 18px; }
  .row-2 { grid-template-columns:1fr; }
}
