:root {
    --bg: #0f1117;
    --bg2: #161b22;
    --bg3: #1c2330;
    --border: #30363d;
    --accent: #e84545;
    --accent2: #c0392b;
    --text: #e6edf3;
    --text2: #8b949e;
    --success: #2ea043;
    --warning: #d29922;
    --danger: #da3633;
    --info: #388bfd;
    --radius: 8px;
    --shadow: 0 4px 24px rgba(0,0,0,0.4);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: var(--bg); color: var(--text); font-family: 'Segoe UI', system-ui, sans-serif; min-height: 100vh; }

/* NAVBAR */
.navbar { display:flex; align-items:center; background:var(--bg2); border-bottom:1px solid var(--border); padding:0 24px; height:60px; position:sticky; top:0; z-index:100; gap:16px; }
.navbar-brand { display:flex; align-items:center; gap:8px; min-width:180px; }
.brand-name { font-size:1.1rem; font-weight:700; color:var(--text); }
.brand-staff { color:var(--accent); }
.navbar-links { display:flex; list-style:none; gap:4px; flex:1; }
.nav-link { display:flex; align-items:center; gap:6px; padding:6px 14px; border-radius:var(--radius); color:var(--text2); text-decoration:none; font-size:.9rem; transition:.2s; }
.nav-link:hover, .nav-link.active { background:var(--bg3); color:var(--text); }
.navbar-user { display:flex; align-items:center; gap:10px; margin-left:auto; }
.user-name { font-size:.9rem; color:var(--text2); }
.user-role { font-size:.75rem; padding:2px 10px; border-radius:20px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.user-role.fondateur { background:#6e40c9; color:#fff; }
.user-role.gerant { background:#1f6feb; color:#fff; }
.user-role.responsable { background:#388bfd; color:#fff; }
.user-role.super-admin { background:#e84545; color:#fff; }
.user-role.recruteur { background:#2ea043; color:#fff; }
.user-role.animateur { background:#d29922; color:#000; }
.btn-logout { background:transparent; border:1px solid var(--border); color:var(--text2); padding:5px 14px; border-radius:var(--radius); cursor:pointer; font-size:.85rem; text-decoration:none; transition:.2s; }
.btn-logout:hover { border-color:var(--danger); color:var(--danger); }

/* LAYOUT */
.page-wrapper { max-width:1200px; margin:0 auto; padding:32px 24px; }
.page-header { margin-bottom:28px; }
.page-header h1 { font-size:1.6rem; font-weight:700; }
.page-header p { color:var(--text2); margin-top:4px; font-size:.95rem; }

/* CARDS */
.card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:24px; margin-bottom:20px; }
.card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--border); }
.card-title { font-size:1rem; font-weight:600; }

/* STATS */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; margin-bottom:28px; }
.stat-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:20px; text-align:center; }
.stat-number { font-size:2rem; font-weight:700; color:var(--accent); }
.stat-label { font-size:.85rem; color:var(--text2); margin-top:4px; }

/* TABLE */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:.9rem; }
thead tr { background:var(--bg3); }
th { padding:10px 14px; text-align:left; color:var(--text2); font-weight:600; font-size:.8rem; text-transform:uppercase; letter-spacing:.5px; border-bottom:1px solid var(--border); }
td { padding:10px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
tr:hover td { background:var(--bg3); }

/* BADGES */
.badge { display:inline-block; padding:2px 10px; border-radius:20px; font-size:.75rem; font-weight:600; }
.badge-success { background:rgba(46,160,67,.2); color:#2ea043; border:1px solid rgba(46,160,67,.3); }
.badge-danger { background:rgba(218,54,51,.2); color:#da3633; border:1px solid rgba(218,54,51,.3); }
.badge-warning { background:rgba(210,153,34,.2); color:#d29922; border:1px solid rgba(210,153,34,.3); }
.badge-info { background:rgba(56,139,253,.2); color:#388bfd; border:1px solid rgba(56,139,253,.3); }
.badge-gray { background:rgba(139,148,158,.15); color:#8b949e; border:1px solid rgba(139,148,158,.2); }

/* FORMS */
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:.85rem; color:var(--text2); margin-bottom:6px; font-weight:500; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:10px 14px; color:var(--text); font-size:.9rem; outline:none; transition:.2s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(232,69,69,.15); }
.form-group textarea { resize:vertical; min-height:80px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--radius); border:none; cursor:pointer; font-size:.9rem; font-weight:500; text-decoration:none; transition:.2s; }
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent2); }
.btn-secondary { background:var(--bg3); color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover { border-color:var(--text2); }
.btn-danger { background:transparent; color:var(--danger); border:1px solid var(--danger); }
.btn-danger:hover { background:var(--danger); color:#fff; }
.btn-success { background:var(--success); color:#fff; }
.btn-sm { padding:5px 12px; font-size:.8rem; }

/* MODAL */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:1000; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:28px; width:90%; max-width:600px; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow); }
.modal-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.modal-title { font-size:1.1rem; font-weight:700; }
.modal-close { background:none; border:none; color:var(--text2); font-size:1.3rem; cursor:pointer; }
.modal-close:hover { color:var(--text); }

/* LOGIN */
.login-wrapper { min-height:100vh; display:flex; align-items:center; justify-content:center; }
.login-box { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:40px; width:380px; box-shadow:var(--shadow); }
.login-logo { text-align:center; margin-bottom:28px; }
.login-logo h1 { font-size:1.5rem; }
.login-logo p { color:var(--text2); font-size:.9rem; margin-top:4px; }
.alert { padding:10px 14px; border-radius:var(--radius); margin-bottom:16px; font-size:.9rem; }
.alert-danger { background:rgba(218,54,51,.15); border:1px solid rgba(218,54,51,.3); color:#da3633; }
.alert-success { background:rgba(46,160,67,.15); border:1px solid rgba(46,160,67,.3); color:#2ea043; }

/* DIVERS */
.id-badge { font-family:monospace; font-size:.8rem; background:var(--bg3); padding:2px 8px; border-radius:4px; border:1px solid var(--border); }
.event-card { background:var(--bg3); border:1px solid var(--border); border-left:3px solid var(--accent); border-radius:var(--radius); padding:16px; margin-bottom:12px; }
.event-date { font-size:.8rem; color:var(--text2); margin-bottom:6px; }
.event-title { font-weight:600; font-size:1rem; }
.event-desc { font-size:.85rem; color:var(--text2); margin-top:6px; }