/* =============================================
   LYSORIA — Cyberpunk Dark Theme
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Orbitron:wght@400;600;700;900&display=swap');

/* ===== VARIABLES ===== */
:root {
    --bg:           #05050d;
    --bg2:          #0a0a16;
    --bg3:          #0f0f1c;
    --card:         #0d0d1a;
    --card2:        #12121f;
    --card-bg:      #0d0d1a;
    --border:       #1a1a2e;
    --border2:      #252540;
    --purple:       #8b5cf6;
    --purple2:      #a78bfa;
    --purple-d:     #6d28d9;
    --purple-dark:  #7c3aed;
    --purple-bright:#c084fc;
    --cyan:         #22d3ee;
    --cyan-d:       #0891b2;
    --pink:         #ec4899;
    --red:          #ef4444;
    --green:        #22c55e;
    --yellow:       #f59e0b;
    --orange:       #f97316;
    --blue:         #3b82f6;
    --glow:         rgba(168,85,247,0.4);
    --glow-p:       rgba(139,92,246,0.3);
    --glow-c:       rgba(34,211,238,0.2);
    --glow-cyan:    rgba(34,211,238,0.3);
    --text:         #f0f0ff;
    --text2:        #9898b8;
    --text-muted:   #6366f1;
    --muted:        #5a5a78;
    --sidebar-w:    240px;
    --topbar-h:     64px;
    --r:            10px;
    --r-sm:         7px;
    --ease:         all .22s ease;
}

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box;}
body{
    font-family:'Inter',sans-serif;
    background:var(--bg);
    color:var(--text);
    display:flex;
    min-height:100vh;
    overflow-x:hidden;
    position:relative;
}
body::before{
    content:'';position:fixed;inset:0;
    background-image:
        linear-gradient(rgba(139,92,246,.025) 1px,transparent 1px),
        linear-gradient(90deg,rgba(139,92,246,.025) 1px,transparent 1px);
    background-size:50px 50px;pointer-events:none;z-index:0;
}
body::after{
    content:'';position:fixed;inset:0;
    background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.02) 2px,rgba(0,0,0,0.02) 4px);
    pointer-events:none;z-index:0;
}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--purple-d);border-radius:3px;}

/* ===== SIDEBAR ===== */
.sidebar{
    width:var(--sidebar-w);background:var(--card);border-right:1px solid var(--border);
    display:flex;flex-direction:column;position:fixed;top:0;left:0;
    height:100vh;z-index:100;transition:var(--ease);overflow:hidden;
}
.sidebar::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--purple),var(--cyan),transparent);
}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0;}
.logo{display:flex;align-items:center;gap:11px;}
.logo-icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--purple-d),var(--purple));display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;flex-shrink:0;box-shadow:0 0 15px var(--glow-p);}
.logo-name{font-family:'Orbitron',monospace;font-size:13px;font-weight:900;letter-spacing:3px;color:var(--text);display:block;}
.logo-sub{font-size:9px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;}
.sidebar-toggle{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:5px;transition:var(--ease);border-radius:6px;}
.sidebar-toggle:hover{color:var(--purple);background:rgba(139,92,246,.1);}

/* Server status */
.server-status{display:flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(34,197,94,.05);border-bottom:1px solid var(--border);font-size:11px;color:var(--text2);flex-shrink:0;}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.player-count{margin-left:auto;font-family:'Orbitron',monospace;font-size:10px;color:var(--cyan);}

/* Nav */
.nav-menu{flex:1;overflow-y:auto;padding:8px 0;}
.nav-section-label{font-size:9px;font-weight:700;letter-spacing:2px;color:var(--muted);text-transform:uppercase;padding:14px 18px 5px;}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 18px;color:var(--text2);text-decoration:none;font-size:13px;transition:var(--ease);position:relative;cursor:pointer;}
.nav-item i{width:17px;text-align:center;font-size:14px;transition:var(--ease);}
.nav-item span{flex:1;}
.nav-item:hover{color:var(--text);background:rgba(139,92,246,.06);}
.nav-item:hover i{color:var(--purple);}
.nav-item.active{color:var(--text);background:rgba(139,92,246,.1);}
.nav-item.active i{color:var(--purple);}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--purple),var(--cyan));border-radius:0 3px 3px 0;}
.nav-indicator{display:none;}
.nav-badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;font-family:'Orbitron',monospace;}
.nav-badge.red{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.2);}
.nav-badge.orange{background:rgba(249,115,22,.15);color:#fb923c;border:1px solid rgba(249,115,22,.2);}
.nav-badge.yellow{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.2);}
.nav-badge.blue{background:rgba(59,130,246,.15);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}

/* Sidebar footer user */
.sidebar-footer{border-top:1px solid var(--border);padding:14px 18px;flex-shrink:0;}
.user-card{display:flex;align-items:center;gap:10px;}
.user-avatar{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;}
.user-name{display:block;font-size:12px;font-weight:600;color:var(--text);}
.user-role{display:inline-block;font-size:9px;font-weight:700;padding:1px 7px;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;margin-top:2px;}
.user-role.fondateur{background:rgba(139,92,246,.2);color:#a78bfa;border:1px solid rgba(139,92,246,.3);}
.user-role.admin{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.2);}
.user-role.modo{background:rgba(59,130,246,.15);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}
.user-role.helper{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.2);}
.logout-btn{margin-left:auto;background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:6px;border-radius:7px;transition:var(--ease);text-decoration:none;display:flex;align-items:center;}
.logout-btn:hover{color:var(--red);background:rgba(239,68,68,.1);}

/* ===== MAIN CONTENT ===== */
.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1;}

/* ===== TOPBAR ===== */
.topbar{height:var(--topbar-h);background:rgba(13,13,26,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50;flex-shrink:0;}
.page-title{font-family:'Orbitron',monospace;font-size:15px;font-weight:700;letter-spacing:3px;color:var(--text);}
.breadcrumb{font-size:11px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:5px;}
.breadcrumb i{font-size:10px;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.topbar-btn{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2);cursor:pointer;width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--ease);position:relative;}
.topbar-btn:hover{color:var(--purple);border-color:var(--purple);background:rgba(139,92,246,.08);}
.notif-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 6px var(--red);}
.topbar-date{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);background:rgba(255,255,255,.03);border:1px solid var(--border);padding:6px 12px;border-radius:8px;}
.topbar-user{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}
.topbar-username{font-size:12px;font-weight:600;color:var(--text);}

/* ===== PAGES ===== */
section.page{display:none;padding:24px;animation:fadeIn .2s ease;}
section.page.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.card-header h3{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.5px;}
.card-header h3 i{color:var(--purple);}
.card-count{font-size:11px;color:var(--muted);background:var(--bg2);padding:3px 9px;border-radius:20px;border:1px solid var(--border);}
.card-link{font-size:11px;color:var(--purple2);text-decoration:none;transition:var(--ease);}
.card-link:hover{color:var(--cyan);}

/* ===== STAT CARDS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;display:flex;align-items:center;gap:14px;transition:var(--ease);}
.stat-card:hover{border-color:rgba(139,92,246,.3);transform:translateY(-2px);}
.stat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.stat-icon.p{background:rgba(139,92,246,.15);color:var(--purple2);}
.stat-icon.r{background:rgba(239,68,68,.12);color:#f87171;}
.stat-icon.g{background:rgba(34,197,94,.12);color:#4ade80;}
.stat-icon.y{background:rgba(245,158,11,.12);color:#fbbf24;}
.stat-icon.c{background:rgba(34,211,238,.12);color:var(--cyan);}
.stat-value{font-family:'Orbitron',monospace;font-size:22px;font-weight:700;color:var(--text);display:block;}
.stat-label{font-size:11px;color:var(--muted);display:block;margin-top:2px;}
.stat-trend{font-size:10px;display:block;margin-top:4px;}
.stat-trend.up{color:var(--green);}
.stat-trend.down{color:var(--red);}
.stat-trend.flat{color:var(--muted);}
.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.give-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;}

/* ===== TABLE ===== */
.table-wrap{overflow-x:auto;}
.data-table{width:100%;border-collapse:collapse;font-size:12px;}
.data-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);background:var(--bg2);border-bottom:1px solid var(--border);}
.data-table td{padding:11px 14px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text2);}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:rgba(139,92,246,.04);color:var(--text);}
.ptag{background:rgba(139,92,246,.1);color:var(--purple2);padding:2px 8px;border-radius:5px;font-weight:600;font-size:11px;}
.mono{font-family:monospace;font-size:11px;color:var(--muted);}

/* ===== BADGES ===== */
.badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:5px;letter-spacing:.5px;text-transform:uppercase;}
.b-ban{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.2);}
.b-warn{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.2);}
.b-kick{background:rgba(249,115,22,.15);color:#fb923c;border:1px solid rgba(249,115,22,.2);}
.b-tempban{background:rgba(168,85,247,.15);color:#c084fc;border:1px solid rgba(168,85,247,.2);}
.b-mute{background:rgba(59,130,246,.15);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}
.b-freeze{background:rgba(34,211,238,.15);color:var(--cyan);border:1px solid rgba(34,211,238,.2);}
.b-give-money{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.2);}
.b-give-item{background:rgba(139,92,246,.15);color:var(--purple2);border:1px solid rgba(139,92,246,.2);}
.b-give-veh{background:rgba(34,211,238,.15);color:var(--cyan);border:1px solid rgba(34,211,238,.2);}
.b-new{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.2);}
.b-fix{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.2);}
.b-improve{background:rgba(59,130,246,.15);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}

/* ===== RTAG ===== */
.rtag{font-size:9px;font-weight:700;padding:1px 6px;border-radius:20px;display:inline-block;text-transform:uppercase;letter-spacing:.5px;}
.rtag.fondateur{background:rgba(139,92,246,.2);color:#a78bfa;}
.rtag.admin{background:rgba(239,68,68,.15);color:#f87171;}
.rtag.modo{background:rgba(59,130,246,.15);color:#60a5fa;}
.rtag.helper{background:rgba(34,197,94,.15);color:#4ade80;}

/* ===== PAGE ACTIONS ===== */
.page-actions{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.search-bar{display:flex;align-items:center;gap:9px;flex:1;min-width:180px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:0 12px;}
.search-bar i{color:var(--muted);font-size:13px;}
.search-bar input{background:none;border:none;outline:none;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;padding:10px 0;width:100%;}
.search-bar input::placeholder{color:var(--muted);}
.filter-select{background:var(--card);border:1px solid var(--border);border-radius:var(--r);color:var(--text2);font-size:12px;font-family:'Inter',sans-serif;padding:9px 12px;outline:none;cursor:pointer;transition:var(--ease);}
.filter-select:focus{border-color:var(--purple);}
.filter-select option{background:var(--card);}

/* ===== BUTTONS ===== */
.btn-primary{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--purple-d),var(--purple));border:none;border-radius:var(--r);padding:9px 16px;color:#fff;font-size:12px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;transition:var(--ease);white-space:nowrap;text-decoration:none;}
.btn-primary:hover{box-shadow:0 0 18px var(--glow-p);transform:translateY(-1px);}
.btn-primary.sm{padding:6px 12px;font-size:11px;}
.btn-secondary{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:var(--r);padding:9px 16px;color:var(--text2);font-size:12px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;transition:var(--ease);white-space:nowrap;}
.btn-secondary:hover{border-color:var(--purple);color:var(--text);}
.btn-secondary.sm{padding:6px 12px;font-size:11px;}
.btn-success{display:inline-flex;align-items:center;gap:7px;background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.25);border-radius:var(--r);padding:7px 14px;color:#4ade80;font-size:12px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;transition:var(--ease);}
.btn-success:hover{background:rgba(34,197,94,.25);}
.btn-success.sm{padding:5px 10px;font-size:11px;}
.btn-danger{display:inline-flex;align-items:center;gap:7px;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.2);border-radius:var(--r);padding:7px 14px;color:#f87171;font-size:12px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;transition:var(--ease);}
.btn-danger:hover{background:rgba(239,68,68,.22);}
.btn-icon{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:var(--ease);}
.btn-icon.edit:hover{color:var(--cyan);border-color:var(--cyan);background:rgba(34,211,238,.08);}
.btn-icon.lift:hover{color:var(--green);border-color:var(--green);background:rgba(34,197,94,.08);}
.act-btns{display:flex;gap:5px;}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;gap:6px;padding:12px 18px;border-top:1px solid var(--border);}
.pager{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:none;color:var(--muted);font-size:11px;cursor:pointer;transition:var(--ease);}
.pager:hover{border-color:var(--purple);color:var(--purple);}
.pager.active{background:var(--purple-d);border-color:var(--purple);color:#fff;}
.pager-sep{color:var(--muted);font-size:12px;padding:0 4px;}

/* ===== STAFF ONLINE ===== */
.staff-ol-list{padding:10px 14px;display:flex;flex-direction:column;gap:8px;}
.staff-ol-item{display:flex;align-items:center;gap:10px;}
.savatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.staff-ol-info{flex:1;display:flex;flex-direction:column;gap:2px;}
.sname{font-size:12px;font-weight:600;color:var(--text);}
.dot-on{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);flex-shrink:0;}
.dot-off{width:7px;height:7px;border-radius:50%;background:var(--muted);flex-shrink:0;}

/* ===== BUG LIST ===== */
.bug-list{padding:10px 14px;display:flex;flex-direction:column;gap:8px;}
.bug-item{display:flex;align-items:center;gap:9px;font-size:12px;}
.bprio{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;flex-shrink:0;text-transform:uppercase;}
.bprio.h{background:rgba(239,68,68,.15);color:#f87171;}
.bprio.m{background:rgba(245,158,11,.15);color:#fbbf24;}
.bprio.l{background:rgba(34,197,94,.15);color:#4ade80;}
.bug-desc{flex:1;color:var(--text2);}
.bstat{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;flex-shrink:0;}
.bstat.open{background:rgba(239,68,68,.1);color:#f87171;}
.bstat.prog{background:rgba(245,158,11,.1);color:#fbbf24;}
.bstat.done{background:rgba(34,197,94,.1);color:#4ade80;}

/* ===== CHANGELOG LIST ===== */
.cl-list{padding:10px 14px;display:flex;flex-direction:column;gap:8px;}
.cl-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text2);}
.cv{font-family:'Orbitron',monospace;font-size:10px;font-weight:700;color:var(--purple2);}
.cv.big{font-size:14px;}

/* ===== BUGS GRID ===== */
.bugs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}
.bug-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:var(--ease);position:relative;overflow:hidden;}
.bug-card:hover{transform:translateY(-2px);border-color:rgba(139,92,246,.3);}
.bug-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.bug-card.bch::before{background:linear-gradient(90deg,var(--red),transparent);}
.bug-card.bcm::before{background:linear-gradient(90deg,var(--yellow),transparent);}
.bug-card.bcl::before{background:linear-gradient(90deg,var(--green),transparent);}
.bug-ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.bug-card h4{font-size:13px;font-weight:700;color:var(--text);margin-bottom:7px;}
.bug-card p{font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:12px;}
.bug-meta{display:flex;gap:14px;font-size:11px;color:var(--muted);margin-bottom:12px;}
.bug-meta i{margin-right:4px;}
.bug-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.assigned{font-size:11px;color:var(--purple2);display:flex;align-items:center;gap:5px;flex:1;}

/* ===== STAFF GRID ===== */
.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.staff-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;display:flex;align-items:center;gap:12px;transition:var(--ease);position:relative;}
.staff-card:hover{border-color:rgba(139,92,246,.3);transform:translateY(-2px);}
.sc-av{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;}
.staff-card h4{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px;}
.staff-stats-sm{display:flex;flex-direction:column;gap:3px;margin-top:6px;}
.staff-stats-sm span{font-size:10px;color:var(--muted);display:flex;align-items:center;gap:5px;}
.staff-stats-sm i{color:var(--purple);font-size:10px;}
.sc-dot{width:8px;height:8px;border-radius:50%;position:absolute;top:14px;right:14px;flex-shrink:0;}
.sc-dot.on{background:var(--green);box-shadow:0 0 7px var(--green);}
.sc-dot.off{background:var(--muted);}

/* ===== GRADES ===== */
.grades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;}
.grade-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.grade-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);}
.grade-count{font-size:11px;color:var(--muted);}
.perm-list{padding:12px 16px;display:flex;flex-direction:column;gap:10px;}
.perm-item{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text2);}
.perm-toggle{width:34px;height:18px;border-radius:20px;border:none;cursor:pointer;position:relative;transition:var(--ease);flex-shrink:0;}
.perm-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:var(--ease);}
.perm-toggle.on{background:var(--purple);}
.perm-toggle.on::after{left:18px;}
.perm-toggle.off{background:var(--border2);}

/* ===== CONVOCATIONS ===== */
.convoc-list{padding:14px;display:flex;flex-direction:column;gap:12px;}
.convoc-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px;}
.convoc-card.pend{border-left:3px solid var(--purple);}
.convoc-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;}
.convoc-card p{font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:5px;}
.convoc-acts{display:flex;gap:8px;margin-top:12px;}

/* ===== PROFILE ===== */
.profile-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px;}
.profile-hd{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.profile-av{width:60px;height:60px;border-radius:15px;background:linear-gradient(135deg,var(--purple-d),var(--purple));display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0;}
.profile-info h2{font-size:18px;font-weight:700;color:var(--text);}
.profile-info span{font-size:11px;color:var(--muted);display:block;margin-top:3px;}
.profile-badges{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap;}
.profile-stats{display:flex;gap:20px;margin-left:auto;}
.ps{text-align:center;}
.ps span{font-family:'Orbitron',monospace;font-size:18px;font-weight:700;color:var(--text);display:block;}
.ps small{font-size:10px;color:var(--muted);}

/* ===== NOTES ===== */
.notes-list{padding:12px 14px;display:flex;flex-direction:column;gap:10px;}
.note{background:var(--bg2);border-radius:var(--r-sm);padding:11px 13px;}
.note-auth{font-size:11px;font-weight:700;color:var(--purple2);display:block;margin-bottom:5px;}
.note p{font-size:12px;color:var(--text2);line-height:1.5;}
.note-date{font-size:10px;color:var(--muted);display:block;margin-top:5px;}

/* ===== TIMELINE ===== */
.timeline{display:flex;flex-direction:column;gap:0;padding-left:20px;border-left:2px solid var(--border);}
.tl-item{position:relative;padding-left:24px;padding-bottom:24px;}
.tl-dot{position:absolute;left:-29px;top:4px;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg);flex-shrink:0;}
.tl-dot.p{background:var(--purple);}
.tl-dot.c{background:var(--cyan);}
.tl-dot.g{background:var(--green);}
.tl-content{padding:14px 16px;}
.tl-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.cl-date{font-size:11px;color:var(--muted);}
.tl-content ul{list-style:none;display:flex;flex-direction:column;gap:7px;}
.tl-content li{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);}

/* ===== SETTINGS ===== */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.settings-form{padding:14px 18px;display:flex;flex-direction:column;gap:13px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.fi{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 12px;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;transition:var(--ease);width:100%;}
.fi:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(139,92,246,.1);}
textarea.fi{height:auto;padding:10px 12px;resize:vertical;}
select.fi{cursor:pointer;}

/* ===== MODALS ===== */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px;}
.modal-bg.open{display:flex;}
.modal{background:var(--card);border:1px solid var(--border2);border-radius:14px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;animation:mIn .2s ease;}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--purple),var(--cyan));border-radius:14px 14px 0 0;}
@keyframes mIn{from{transform:translateY(-15px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--border);}
.modal-hd h3{font-size:14px;font-weight:700;display:flex;align-items:center;gap:9px;text-transform:uppercase;letter-spacing:1px;}
.modal-hd h3 i{color:var(--purple);}
.modal-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:17px;transition:var(--ease);}
.modal-x:hover{color:var(--red);}
.modal-bd{padding:18px 22px;display:flex;flex-direction:column;gap:14px;}
.modal-ft{display:flex;justify-content:flex-end;gap:9px;padding:14px 22px;border-top:1px solid var(--border);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr);}.dash-grid{grid-template-columns:1fr;}}
@media(max-width:768px){
    .sidebar{transform:translateX(-100%);}
    .sidebar.open{transform:translateX(0);}
    .main-content{margin-left:0;}
    .stats-grid{grid-template-columns:1fr;}
    section.page{padding:18px 14px;}
    .profile-stats{display:none;}
    .frow{grid-template-columns:1fr;}
    .topbar{padding:0 14px;}
}