:root{
  --bg:#0d0e14; --bg-2:#15171f; --panel:#1a1d27; --panel-2:#20242f;
  --line:#2a2e3a; --text:#e7e9ee; --muted:#8b91a3; --brand:#ff5b6e;
  --brand-2:#6c5ce7; --ok:#3ecf8e; --warn:#ffb020; --ko:#ff5b6e;
  --radius:14px; --shadow:0 8px 30px rgba(0,0,0,.35);
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5}
a{color:inherit;text-decoration:none}
h1,h2{margin:.2em 0 .6em}
.muted{color:var(--muted)}
.small{font-size:.82rem}
.container{max-width:1100px;margin:0 auto;padding:24px 18px}
.brand{color:var(--brand);font-weight:800;letter-spacing:.5px}

/* ---------- Boutons ---------- */
.btn{background:var(--brand);color:#fff;border:0;padding:11px 18px;border-radius:10px;
  font-weight:600;cursor:pointer;transition:.15s;display:inline-block}
.btn:hover{filter:brightness(1.08)}
.btn.alt{background:var(--brand-2)}
.btn.danger{background:#3a2030;color:#ff8a9b;border:1px solid #5a2a3a}
.btn-ghost{border:1px solid var(--line);padding:8px 14px;border-radius:10px;color:var(--muted)}
.btn-ghost:hover{color:var(--text);border-color:var(--brand)}
.mini{background:var(--panel-2);border:1px solid var(--line);color:var(--text);
  padding:6px 10px;border-radius:8px;font-size:.8rem;cursor:pointer}
.mini:hover{border-color:var(--brand)}
.mini.danger{color:#ff8a9b;border-color:#5a2a3a}
.mini-file{position:relative;overflow:hidden;display:inline-block;background:var(--panel-2);
  border:1px solid var(--line);padding:6px 10px;border-radius:8px;font-size:.8rem;cursor:pointer}
.mini-file input{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}

/* ---------- Auth ---------- */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(1200px 600px at 50% -10%,#1b1430,transparent),var(--bg)}
.auth-card{background:var(--panel);border:1px solid var(--line);padding:34px;border-radius:18px;
  width:min(420px,92vw);box-shadow:var(--shadow)}
.auth-card h1{text-align:center}
.auth-card .brand{font-size:2rem;text-align:center;display:block}
.auth-card label{display:block;margin:14px 0 4px;font-size:.9rem}
.auth-card input{width:100%;padding:11px;border-radius:10px;border:1px solid var(--line);
  background:var(--bg-2);color:var(--text)}
.auth-card .btn{width:100%;margin-top:18px}

/* ---------- Topbar / panel ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:var(--panel);border-bottom:1px solid var(--line);padding:12px 20px;position:sticky;top:0;z-index:10}
.topbar-left{display:flex;align-items:center;gap:12px}
.logo{font-weight:800;color:var(--brand);font-size:1.2rem}
.topnav{display:flex;gap:6px;flex-wrap:wrap}
.topnav a{padding:8px 12px;border-radius:9px;color:var(--muted);font-size:.92rem}
.topnav a:hover{background:var(--panel-2);color:var(--text)}
.topbar-right{display:flex;align-items:center;gap:12px}
.pill{background:var(--brand);color:#fff;border-radius:20px;padding:1px 8px;font-size:.72rem;margin-left:4px}
.panel-footer{padding:24px;text-align:center;border-top:1px solid var(--line);margin-top:40px}

.role-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;padding:3px 9px;border-radius:20px;font-weight:700}
.role-superadmin{background:#3a1020;color:#ff9bb0}
.role-admin{background:#241a45;color:#b5a8ff}
.role-inspector{background:#103030;color:#7fe6d0}

/* ---------- Alertes ---------- */
.alert{padding:13px 16px;border-radius:11px;margin:14px 0;border:1px solid var(--line)}
.alert.success{background:#0f2a1f;border-color:#1f5a40;color:#9be8c6}
.alert.error{background:#2a0f17;border-color:#5a2030;color:#ff9bab}
.alert code{background:#00000040;padding:2px 6px;border-radius:5px}

/* ---------- Stats / cards ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:18px 0}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;color:var(--muted)}
.stat.warn{border-color:#5a4420}
.stat-num{display:block;font-size:1.9rem;font-weight:800;color:var(--text)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:24px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;font-weight:600;transition:.15s}
.card:hover{border-color:var(--brand);transform:translateY(-2px)}

/* ---------- Tables ---------- */
.data-table{width:100%;border-collapse:collapse;background:var(--panel);border-radius:var(--radius);overflow:hidden;margin-top:14px}
.data-table th,.data-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}
.data-table th{background:var(--panel-2);font-size:.82rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.row-actions .i{display:inline}
.ok{color:var(--ok)} .ko{color:var(--ko)}
.status{padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:600}
.status.ok{background:#0f2a1f;color:#9be8c6}
.status.warn{background:#2a2410;color:#ffd27f}
.status.ko{background:#2a0f17;color:#ff9bab}

/* ---------- Forms ---------- */
.panel-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin:16px 0}
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-form input[type=text],.inline-form select{padding:10px;border-radius:9px;border:1px solid var(--line);background:var(--bg-2);color:var(--text)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.form-col{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
label{display:block;margin:12px 0 4px;font-size:.9rem}
input[type=text],input[type=password],textarea,select{width:100%;padding:11px;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);color:var(--text);font-family:inherit}
fieldset{border:1px solid var(--line);border-radius:12px;padding:14px;margin-top:14px}
legend{padding:0 8px;color:var(--muted);font-size:.85rem}
.submit-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.flex-between{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}

/* ---------- Badges (admin) ---------- */
.badge-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:16px}
.badge-admin-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;align-items:center;gap:12px}
.badge-icon-box{width:46px;height:46px;border-radius:10px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.badge-icon-box img{max-width:34px;max-height:34px}
.no-icon{color:var(--muted);font-size:1.4rem}
.badge-meta{flex:1;display:flex;flex-direction:column;min-width:0}
.badge-meta strong{font-size:.92rem}
.badge-actions{display:flex;gap:6px;align-items:center}

/* badge picker (form) */
.badge-pick{display:flex;flex-wrap:wrap;gap:8px}
.badge-check input{display:none}
.badge-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:20px;
  border:1px solid var(--line);background:var(--bg-2);font-size:.85rem;cursor:pointer;transition:.12s}
.badge-chip img{width:18px;height:18px;object-fit:contain}
.badge-check input:checked + .badge-chip{border-color:var(--brand);background:#2a1620;color:#ffb3c0}

/* ---------- Filters ---------- */
.filters{display:flex;gap:8px;margin:14px 0}
.chip{padding:7px 14px;border-radius:20px;border:1px solid var(--line);color:var(--muted);font-size:.85rem}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ---------- Avatars ---------- */
.avatar-sm{width:36px;height:36px;border-radius:50%;object-fit:cover}
.avatar-md{width:52px;height:52px;border-radius:50%;object-fit:cover}
.avatar-lg{width:88px;height:88px;border-radius:50%;object-fit:cover}
.avatar-xl{width:130px;height:130px;border-radius:50%;object-fit:cover;border:3px solid var(--line)}
.avatar-preview{width:64px;height:64px;border-radius:50%;object-fit:cover;margin-top:8px}
.placeholder{background:linear-gradient(135deg,#2a2e3a,#1a1d27);display:inline-block}

/* ---------- Inspector ---------- */
.wl-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.wl-item{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:12px 16px;transition:.12s}
.wl-item:hover{border-color:var(--brand)}
.wl-info{flex:1;display:flex;flex-direction:column}
.wl-cta{color:var(--brand);font-weight:600}
.empty-state{background:var(--panel);border:1px dashed var(--line);border-radius:var(--radius);padding:40px;text-align:center;color:var(--muted)}
.review-layout{display:grid;grid-template-columns:300px 1fr;gap:22px}
.review-preview{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center}
.review-form{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.link-list{list-style:none;padding:0;text-align:left;font-size:.88rem}
.link-list li{padding:4px 0;border-bottom:1px solid var(--line)}
.back{color:var(--muted);font-size:.9rem}

/* ---------- Public ---------- */
.public-header{text-align:center;padding:46px 18px 20px;background:radial-gradient(900px 400px at 50% -30%,#241640,transparent)}
.public-header.slim{padding:18px;text-align:left}
.brand-xl{font-size:3rem;color:var(--brand);font-weight:900;letter-spacing:1px;margin:0}
.search{display:flex;gap:8px;justify-content:center;max-width:480px;margin:18px auto 0}
.search input{flex:1;padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);color:var(--text)}
.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:10px}
.profile-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px 16px;text-align:center;transition:.15s}
.profile-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow)}
.profile-name{font-weight:700;margin-top:12px}
.badge-row{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:10px}
.badge-row.big{margin-top:16px}
.badge-mini{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center}
.badge-mini img{max-width:22px;max-height:22px;object-fit:contain}
.badge-mini.lg{width:30px;height:30px}
.badge-mini.lg img{max-width:28px;max-height:28px}
.badge-mini .dot{width:10px;height:10px;border-radius:50%;background:var(--brand-2)}
.profile-detail{max-width:560px;margin:20px auto;text-align:center;background:var(--panel);
  border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:var(--shadow)}
.profile-title{font-size:2rem;margin:14px 0 4px}
.profile-bio{color:var(--muted);margin:14px 0}
.social-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.social-link{width:48px;height:48px;border-radius:12px;background:var(--bg-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;transition:.15s;font-size:1.4rem}
.social-link:hover{border-color:var(--brand);transform:translateY(-2px)}
.social-link img{width:30px;height:30px;object-fit:contain}
.public-footer{display:flex;justify-content:space-between;max-width:1100px;margin:40px auto 0;padding:20px 18px;border-top:1px solid var(--line)}

@media(max-width:760px){
  .form-grid,.review-layout{grid-template-columns:1fr}
  .brand-xl{font-size:2.2rem}
}
