@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --bg:#05070f; --panel:#0e1423; --panel-2:#131a2e;
  --card:#141b32; --card-hi:#1a2240;
  --cyan:#00e0ff; --cyan-dim:rgba(0,224,255,0.28); --cyan-glow:rgba(0,224,255,0.12);
  --violet:#9d4dff; --pink:#ff4d8d;
  --text:#dee8ff; --text-2:#a8b4d4; --muted:rgba(200,216,240,0.65);
  --border:rgba(0,224,255,0.14); --border-hi:rgba(0,224,255,0.42);
  --t1:#FFD84D; --t2:#FFA23B; --t3:#FF5F2E; --t4:#E6265C; --t5:#9A0F2B;
  --green:#2cffab; --red:#ff3e5e; --amber:#ffc043;
  --r:6px; --r-lg:10px;
  --shadow:0 10px 40px rgba(0,0,0,0.6);
  --shadow-cyan:0 0 40px rgba(0,224,255,0.14);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;animation:page-enter .35s ease both}
@keyframes page-enter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
body.page-exit{animation:page-exit .18s ease both}
@keyframes page-exit{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(1000px 600px at 10% -10%,rgba(0,224,255,0.10),transparent 60%),radial-gradient(900px 500px at 90% 0%,rgba(157,77,255,0.10),transparent 60%),radial-gradient(700px 500px at 50% 100%,rgba(255,77,141,0.06),transparent 60%)}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(rgba(0,224,255,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(0,224,255,0.035) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%)}

/* Custom scrollbar */
::-webkit-scrollbar{width:8px;background:transparent}
::-webkit-scrollbar-track{background:var(--bg);border-left:1px solid var(--border)}
::-webkit-scrollbar-thumb{background:rgba(0,224,255,0.18);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(0,224,255,0.35)}
html{scrollbar-color:rgba(0,224,255,0.18) var(--bg);scrollbar-width:thin}

.container,.hero,nav,.admin-layout,#toast,.fab{position:relative;z-index:1}

/* Nav */
nav{position:sticky;top:0;z-index:100;background:rgba(5,7,15,0.85);border-bottom:1px solid var(--border-hi);backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2);display:flex;align-items:center;padding:0 34px;height:68px;box-shadow:0 4px 40px rgba(0,224,255,0.08);overflow:visible}
.nav-logo{display:flex;align-items:center;gap:13px;text-decoration:none}
.nav-logo img{height:42px;width:42px;object-fit:contain;filter:drop-shadow(0 0 10px rgba(0,224,255,0.55));transition:transform .3s}
.nav-logo:hover img{transform:rotate(-4deg) scale(1.05)}
.nav-logo-text{font-family:'Cinzel',serif;font-size:21px;font-weight:800;color:var(--cyan);text-shadow:0 0 22px rgba(0,224,255,0.55);letter-spacing:0.14em}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:32px;list-style:none}
.nav-links a{font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;padding:8px 16px;border-radius:var(--r);transition:all .2s;letter-spacing:.04em;text-transform:uppercase;position:relative}
.nav-links a:hover{color:var(--cyan)}
.nav-links a.active{color:var(--cyan);background:var(--cyan-glow)}
.nav-links a.active::after{content:'';position:absolute;left:16px;right:16px;bottom:3px;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.nav-spacer{flex:1}

/* More dropdown */
.nav-more{position:relative}
.nav-more>.nav-dropdown{
  display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);
  min-width:180px;padding:8px 0;margin-top:8px;
  background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r-lg);
  box-shadow:0 12px 40px rgba(0,0,0,0.5),0 0 20px rgba(0,224,255,0.08);
  list-style:none;z-index:200;
}
.nav-more:hover>.nav-dropdown,.nav-more:focus-within>.nav-dropdown{display:block}
.nav-dropdown li{display:block}
.nav-dropdown a{
  display:block;padding:10px 18px;font-size:13px;font-weight:500;
  color:var(--text-2);text-decoration:none;white-space:nowrap;
  transition:all .15s;letter-spacing:.03em;
}
.nav-dropdown a:hover,.nav-dropdown a:focus{background:rgba(0,224,255,0.08);color:var(--cyan)}
.nav-dropdown a.active{color:var(--cyan)}
.nav-admin-btn{font-size:12px;font-weight:700;color:var(--cyan);border:1px solid var(--border-hi);padding:9px 20px;border-radius:var(--r);text-decoration:none;transition:all .2s;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(180deg,rgba(0,224,255,0.06),rgba(0,224,255,0.02))}
.nav-admin-btn:hover{background:linear-gradient(180deg,rgba(0,224,255,0.18),rgba(0,224,255,0.08));box-shadow:0 0 18px var(--cyan-dim),inset 0 0 18px rgba(0,224,255,0.05);transform:translateY(-1px)}

/* Layout */
.container{max-width:1240px;margin:0 auto;padding:0 26px}
.page-header{padding:52px 0 32px}
.page-title{font-family:'Cinzel',serif;font-size:clamp(32px,6vw,56px);font-weight:900;background:linear-gradient(135deg,var(--cyan) 0%,#9d4dff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;letter-spacing:.08em;line-height:1.05}
.page-subtitle{font-size:15px;color:var(--text-2);margin-top:10px;letter-spacing:.02em}

.section-label{display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin:40px 0 18px}
.section-label::before,.section-label::after{content:'';flex:1;height:1px;max-width:80px;background:linear-gradient(90deg,transparent,var(--cyan-dim),transparent)}

/* Cards */
.card{background:linear-gradient(180deg,var(--card) 0%,var(--card-hi) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;transition:all .2s;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.5}
.card:hover{border-color:var(--border-hi);box-shadow:var(--shadow-cyan)}

/* Tier badges */
.tier-badge{display:inline-flex;align-items:center;gap:5px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.14em;padding:4px 10px;border-radius:3px;border:1px solid currentColor;text-transform:uppercase}
.tier-1{color:var(--t1);background:rgba(255,216,77,.10)}
.tier-2{color:var(--t2);background:rgba(255,162,59,.10)}
.tier-3{color:var(--t3);background:rgba(255,95,46,.10)}
.tier-4{color:var(--t4);background:rgba(230,38,92,.12)}
.tier-5{color:#e84a72;background:rgba(154,15,43,.22);text-shadow:0 0 8px rgba(232,74,114,0.5)}

/* Category badges */
.cat-badge{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.12em;padding:3px 9px;border-radius:3px;text-transform:uppercase}
.cat-exploit{background:rgba(0,224,255,.14);color:var(--cyan);border:1px solid var(--cyan-dim)}
.cat-degen{background:rgba(255,192,67,.12);color:var(--amber);border:1px solid rgba(255,192,67,.3)}

/* Ban banner */
.ban-banner{background:linear-gradient(90deg,rgba(154,15,43,.25),rgba(154,15,43,.1));border:1px solid rgba(230,38,92,.5);border-radius:var(--r-lg);padding:14px 20px;color:#ff8aa0;font-size:14px;margin-bottom:22px;display:flex;align-items:center;gap:12px}

/* Buttons */
.btn{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:12px 26px;border-radius:var(--r);cursor:pointer;transition:all .2s;border:1px solid transparent;text-decoration:none;display:inline-flex;align-items:center;gap:9px}
.btn-primary{background:linear-gradient(135deg,rgba(0,224,255,.22) 0%,rgba(0,224,255,.08) 100%);border-color:var(--cyan);color:var(--cyan)}
.btn-primary:hover{background:linear-gradient(135deg,rgba(0,224,255,.35) 0%,rgba(0,224,255,.15) 100%);box-shadow:0 0 24px rgba(0,224,255,0.35);transform:translateY(-1px)}
.btn-success{background:rgba(44,255,171,.12);border-color:var(--green);color:var(--green)}
.btn-success:hover{background:rgba(44,255,171,.22);box-shadow:0 0 18px rgba(44,255,171,.3)}
.btn-danger{background:rgba(255,62,94,.12);border-color:var(--red);color:var(--red)}
.btn-danger:hover{background:rgba(255,62,94,.22);box-shadow:0 0 18px rgba(255,62,94,.3)}
.btn-ghost{background:transparent;border-color:var(--border-hi);color:var(--text-2)}
.btn-ghost:hover{color:var(--text);border-color:var(--cyan);background:var(--cyan-glow)}
.btn-sm{padding:7px 14px;font-size:11px}
.btn:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;box-shadow:0 0 0 4px var(--cyan-glow)}
.btn-lg{padding:15px 32px;font-size:14px}

/* Forms */
.form-group{margin-bottom:20px}
.form-label{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--cyan);margin-bottom:8px;text-transform:uppercase}
.form-input,.form-select,.form-textarea{width:100%;background:rgba(0,5,15,.7);border:1px solid var(--border-hi);border-radius:var(--r);color:var(--text);font-family:'Inter',sans-serif;font-size:14px;padding:12px 15px;outline:none;transition:all .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow),0 0 20px rgba(0,224,255,0.1)}
.form-select{appearance:none;cursor:pointer;padding-right:36px}
.form-select option{background:#05070f}
.form-textarea{resize:vertical;min-height:96px}

/* Offense tags */
.offense-tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;padding:4px 11px;border-radius:3px;border:1px solid var(--border);color:var(--text-2);margin:3px;cursor:pointer;transition:all .15s}
.offense-tag.selected,.offense-tag:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-glow);box-shadow:0 0 10px var(--cyan-dim)}

/* Stats */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin:28px 0}
.stat-box{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 24px;text-align:center;position:relative;overflow:hidden;transition:all .25s}
.stat-box::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top,var(--cyan-glow),transparent 60%);opacity:.5;pointer-events:none}
.stat-box:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:var(--shadow-cyan)}
.stat-number{font-family:'Cinzel',serif;font-size:42px;font-weight:800;color:var(--cyan);text-shadow:0 0 24px rgba(0,224,255,0.45);line-height:1}
.stat-label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;margin-top:8px}

/* Cheater card */
.cheater-card{background:linear-gradient(135deg,var(--card) 0%,var(--card-hi) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;display:flex;align-items:center;gap:15px;text-decoration:none;color:inherit;transition:all .2s;position:relative;overflow:hidden}
.cheater-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--tier-color,var(--cyan));opacity:0;transition:opacity .2s}
.cheater-card:hover{border-color:var(--border-hi);transform:translateX(4px);box-shadow:0 6px 24px rgba(0,0,0,0.4),0 0 0 1px var(--border-hi)}
.cheater-card:hover::before{opacity:1}
.cheater-card .avatar{width:56px;height:56px;border-radius:50%;background:var(--panel);flex-shrink:0;object-fit:cover;border:2px solid var(--border);box-shadow:0 4px 12px rgba(0,0,0,0.4)}
.cheater-card .info{flex:1;min-width:0}
.cheater-card .username{font-weight:700;font-size:16px;margin-bottom:6px;letter-spacing:.01em}
.cheater-card .username small{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:400;letter-spacing:0}
.cheater-card .meta{display:flex;flex-wrap:wrap;gap:7px;align-items:center}

/* Hot card */
/* Hot card (browse grid view) */
.hot-card{background:linear-gradient(135deg,var(--card) 0%,var(--card-hi) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 18px;display:flex;flex-direction:column;gap:12px;text-decoration:none;color:inherit;transition:all .25s;position:relative;overflow:hidden}
.hot-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(0,0,0,0.5);border-color:var(--border-hi)}
.hot-card .name{font-family:'Cinzel',serif;font-size:17px;font-weight:800;text-align:center;color:var(--tier-color,var(--cyan));text-shadow:0 0 14px var(--tier-color,var(--cyan));line-height:1.2}
.hot-card .handle{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);text-align:center;word-break:break-all}

/* Search */
.search-bar{display:flex;gap:12px;margin-bottom:28px}
.search-input{flex:1;background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r);color:var(--text);font-size:16px;padding:14px 20px;outline:none;transition:all .2s}
.search-input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow),0 0 28px rgba(0,224,255,0.12)}
.search-input::placeholder{color:var(--muted)}

/* Filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:26px;align-items:center}
.filter-select{background:var(--panel);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-size:13px;padding:10px 16px;outline:none;cursor:pointer;transition:border-color .2s;appearance:none;padding-right:34px}
.filter-select:hover,.filter-select:focus{border-color:var(--border-hi)}
.filter-select option{background:#05070f}

/* Grids */
.entries-grid{display:flex;flex-direction:column;gap:10px}
.top-tier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:32px;flex-wrap:wrap}
.page-btn{background:var(--panel);border:1px solid var(--border);color:var(--text-2);padding:9px 16px;border-radius:var(--r);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:12px;transition:all .18s}
.page-btn:hover,.page-btn.active{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-glow);box-shadow:0 0 14px var(--cyan-dim)}

/* Evidence */
.evidence-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:16px}
.evidence-item{border-radius:var(--r);overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9;transition:border-color .2s}
.evidence-item:hover{border-color:var(--border-hi)}
.evidence-item img,.evidence-item video{width:100%;height:100%;object-fit:cover}
.evidence-link{display:flex;align-items:center;justify-content:center;height:100%;background:var(--panel);color:var(--cyan);font-size:12px;text-decoration:none;padding:12px;text-align:center;word-break:break-all}

/* Toast notifications */
#toast{position:fixed;top:80px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast-item{pointer-events:auto;padding:12px 20px;border-radius:var(--r-lg);font-size:14px;font-weight:500;transform:translateX(120%);transition:transform .3s ease;position:relative;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,0.4);max-width:360px}
.toast-item.toast-show{transform:translateX(0)}
.toast-item.toast-hide{transform:translateX(120%)}
.toast-ok{background:rgba(44,255,171,0.15);border:1px solid rgba(44,255,171,0.4);color:var(--green)}
.toast-err{background:rgba(255,62,94,0.15);border:1px solid rgba(255,62,94,0.4);color:var(--red)}
.toast-progress{position:absolute;bottom:0;left:0;height:2px;background:currentColor;opacity:0.4;animation:toast-timer 4s linear forwards}
@keyframes toast-timer{from{width:100%}to{width:0%}}

/* Admin layout */
.admin-layout{display:grid;grid-template-columns:230px 1fr;min-height:calc(100vh - 68px)}
.admin-sidebar{background:var(--panel);border-right:1px solid var(--border);padding:24px 0;position:sticky;top:68px;height:calc(100vh - 68px);overflow-y:auto}
.admin-sidebar .sidebar-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;color:var(--cyan);padding:0 22px 10px;text-transform:uppercase}
.admin-sidebar a{display:flex;align-items:center;gap:11px;padding:11px 22px;color:var(--text-2);text-decoration:none;font-size:14px;font-weight:500;transition:all .18s;border-left:3px solid transparent}
.admin-sidebar a:hover,.admin-sidebar a.active{color:var(--cyan);background:var(--cyan-glow);border-left-color:var(--cyan)}
/* Sidebar collapsible groups */
.sb-group{margin-bottom:2px}
.sb-group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 22px;font-size:10px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;font-family:'Cinzel',serif;cursor:pointer;user-select:none;transition:color .2s}
.sb-group-header:hover{color:var(--cyan)}
.sb-group-header .sb-toggle{font-size:14px;transition:transform .2s}
.sb-group.collapsed .sb-group-items{display:none}
.sb-group.collapsed .sb-toggle{transform:rotate(-90deg)}
.sb-group-items a{display:block;padding:7px 22px 7px 32px;font-size:13px;color:var(--text-2);text-decoration:none;transition:all .15s;border-left:2px solid transparent}
.sb-group-items a:hover{color:var(--cyan);background:rgba(0,224,255,.04)}
.sb-group-items a.active{color:var(--cyan);border-left-color:var(--cyan);background:rgba(0,224,255,.06)}
.sb-group-items .sb-badge{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--cyan);margin-left:6px}
.admin-content{padding:34px;overflow-y:auto}

/* Unified player card */
.player-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);text-decoration:none;transition:all .2s;border-left:3px solid var(--tier-color,var(--border))}
.player-card:hover{border-color:var(--border-hi);background:var(--card-hi)}
.player-card .pc-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.player-card .pc-name{font-weight:600;font-size:14px;color:var(--text)}
.player-card .pc-handle{font-size:12px;color:var(--muted)}
.player-card .pc-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-top:2px}
/* Unified clan card */
.clan-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);text-decoration:none;transition:all .2s}
.clan-card:hover{border-color:var(--border-hi);background:var(--card-hi)}
.clan-card .cc-icon{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.clan-card .cc-name{font-weight:600;font-size:14px;color:var(--text)}
.clan-card .cc-meta{font-size:12px;color:var(--muted)}
.clan-card .cc-bar{height:4px;border-radius:2px;background:var(--border);flex-shrink:0;width:80px;overflow:hidden}
.clan-card .cc-bar-fill{height:100%;border-radius:2px;transition:width .3s}

/* Profile tabs */
.profile-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin:20px 0 0}
.profile-tab{padding:10px 24px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:'Cinzel',serif;font-size:12px;letter-spacing:.1em;cursor:pointer;transition:all .2s}
.profile-tab:hover{color:var(--text)}
.profile-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.profile-tab-content{display:none;padding-top:20px}
.profile-tab-content.active{display:block}
/* Action dropdown */
.action-menu{position:relative;display:inline-block}
.action-menu-btn{cursor:pointer}
.action-menu-dd{display:none;position:absolute;right:0;top:100%;margin-top:6px;background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r);min-width:180px;box-shadow:var(--shadow);z-index:100;padding:4px 0}
.action-menu-dd.open{display:block}
.action-menu-dd button{display:block;width:100%;text-align:left;padding:8px 16px;font-size:13px;color:var(--text-2);background:none;border:none;cursor:pointer;text-decoration:none}
.action-menu-dd button:hover{background:rgba(0,224,255,.06);color:var(--cyan)}

/* Launchpad hero cards */
.launchpad{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin:36px 0 40px}
.launch-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 20px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);text-decoration:none;transition:all .25s;gap:12px;text-align:center}
.launch-card:hover{border-color:var(--cyan);background:var(--card-hi);transform:translateY(-2px);box-shadow:var(--shadow-cyan)}
.launch-card .launch-icon{font-size:32px}
.launch-card .launch-title{font-family:'Cinzel',serif;font-size:14px;letter-spacing:.1em;color:var(--cyan);font-weight:700}
.launch-card .launch-desc{font-size:12px;color:var(--muted);line-height:1.5}
/* Recent activity compact list */
.recent-compact{display:flex;flex-direction:column;gap:0}
.recent-compact a{display:flex;align-items:center;gap:12px;padding:10px 16px;text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s}
.recent-compact a:last-child{border-bottom:none}
.recent-compact a:hover{background:var(--card-hi)}
.recent-compact .rc-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0}
.recent-compact .rc-name{font-size:13px;font-weight:600;color:var(--text);flex:1}
.recent-compact .rc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.recent-compact .rc-time{font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace}

/* Hero */
.hero{padding:92px 0 60px;text-align:center;background:radial-gradient(ellipse 60% 60% at 50% 0%,rgba(0,224,255,0.14) 0%,transparent 65%),radial-gradient(ellipse 60% 60% at 50% 100%,rgba(157,77,255,0.08) 0%,transparent 65%)}
.hero-logo{width:120px;height:120px;margin:0 auto 22px;display:block;object-fit:contain;filter:drop-shadow(0 0 30px rgba(0,224,255,0.55));animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.hero-title{font-family:'Cinzel',serif;font-size:clamp(42px,8vw,88px);font-weight:900;background:linear-gradient(135deg,#fff 0%,var(--cyan) 50%,var(--violet) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.14em;line-height:1}
.hero-sub{font-size:17px;color:var(--text-2);margin-top:16px;max-width:580px;margin-left:auto;margin-right:auto;line-height:1.65;font-weight:400}
.hero-cta{display:flex;gap:14px;justify-content:center;margin-top:30px;flex-wrap:wrap}

.tagline{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:10px}
.tagline::before,.tagline::after{content:'';width:24px;height:1px;background:var(--cyan-dim)}

.fab{position:fixed;bottom:22px;right:22px;z-index:90;display:none;background:linear-gradient(135deg,var(--cyan),var(--violet));color:#05070f;font-weight:800;font-size:13px;padding:14px 20px;border-radius:999px;text-decoration:none;box-shadow:0 8px 28px rgba(0,224,255,0.4)}

.loader{display:flex;justify-content:center;padding:56px}
.spinner{width:36px;height:36px;border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}




.hero-roblox-link{
  display:inline-block;
  margin-top:8px;
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--cyan);text-decoration:none;
  padding:4px 12px;
  border:1px solid rgba(0,224,255,.25);
  border-radius:20px;
  transition:all .2s;
}
.hero-roblox-link:hover{
  background:rgba(0,224,255,.1);
  border-color:var(--cyan);
  color:#fff;
}
/* Alt account banner */
.alt-banner{
  background:linear-gradient(135deg,rgba(0,224,255,.08),rgba(138,43,226,.06));
  border:1px solid rgba(0,224,255,.3);
  border-radius:var(--r-lg);
  padding:14px 20px;
  margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:13px;
  color:var(--text-2);
}
.alt-banner-icon{font-size:18px}
.alt-banner-link{
  color:var(--cyan);font-weight:700;text-decoration:none;
  transition:color .2s;
}
.alt-banner-link:hover{color:#fff;text-decoration:underline}
/* Cheater profile clans list */
.profile-clans{display:flex;flex-wrap:wrap;gap:10px}
.profile-clan{
  display:flex;align-items:center;gap:10px;
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r);padding:8px 14px 8px 8px;
  text-decoration:none;color:inherit;transition:all .18s;
}
.profile-clan:hover{border-color:var(--cyan);box-shadow:0 0 12px var(--cyan-dim)}
.profile-clan img{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--panel)}
.profile-clan-name{font-family:'Cinzel',serif;font-weight:700;font-size:13px}

/* Clan profile header */
.clan-header{margin-bottom:22px;padding:28px}
.clan-header-inner{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.clan-header-icon{
  width:120px;height:120px;border-radius:var(--r-lg);
  object-fit:cover;flex-shrink:0;
  border:2px solid var(--border-hi);
  box-shadow:0 0 32px var(--cyan-dim), 0 10px 24px rgba(0,0,0,0.5);
  background:var(--panel);
}
.clan-header-fallback{
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:58px;font-weight:900;
  color:var(--cyan);
}
.clan-header-info{flex:1;min-width:260px}
.clan-header-name{
  font-family:'Cinzel',serif;font-size:clamp(28px,5vw,44px);font-weight:900;
  background:linear-gradient(135deg,#fff,var(--cyan) 60%,var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:.04em;line-height:1.1;margin-bottom:12px;
}
.clan-header-meta{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.clan-stat{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--text-2);letter-spacing:.02em;
}
.clan-stat strong{color:var(--cyan);font-weight:700;font-size:14px}
.clan-link{color:var(--cyan);text-decoration:none;transition:color .2s}
.clan-link:hover{color:var(--cyan)}
.clan-header-desc{
  margin-top:20px;padding-top:20px;
  border-top:1px solid var(--border);
  color:var(--text-2);line-height:1.65;font-size:14px;
  max-height:200px;overflow-y:auto;
}
.clan-stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:14px;margin-bottom:30px;
}

/* User info grid on cheater profile */
.user-info-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
}
.user-info-item{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:14px 16px;
  text-align:center;
  transition:all .2s;
  text-decoration:none;
  color:inherit;
}
.user-info-item:hover{border-color:var(--border-hi)}
.user-info-label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  letter-spacing:.14em;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:6px;
}
.user-info-value{
  font-family:'Cinzel',serif;
  font-size:18px;
  font-weight:700;
  color:var(--cyan);
}
.user-info-link .user-info-value{font-size:22px}

.past-name{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  padding:5px 11px;
  border-radius:3px;
  border:1px solid var(--border);
  color:var(--text-2);
  background:var(--panel);
}

/* Logged-in user badge in nav */
.nav-user-badge{
  display:inline-flex;align-items:center;gap:8px;
  margin-right:14px;padding:6px 12px;
  background:linear-gradient(180deg,rgba(157,77,255,0.12),rgba(157,77,255,0.04));
  border:1px solid rgba(157,77,255,0.35);
  border-radius:var(--r);
}
.nav-user-role{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:.14em;
  color:var(--violet);font-weight:700;
  padding:2px 6px;border-radius:3px;
  background:rgba(157,77,255,0.18);
}
.nav-user-name{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;font-weight:600;color:var(--text);
}

/* Status banner on cheater profile */
.status-banner{
  padding:12px 20px;
  border-radius:var(--r-lg);
  margin-bottom:16px;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;text-align:center;
}
.status-banner.status-pending{
  background:linear-gradient(90deg,rgba(255,192,67,.22),rgba(255,192,67,.08));
  border:1px solid rgba(255,192,67,.5);
  color:var(--amber);
}
.status-banner.status-rejected{
  background:linear-gradient(90deg,rgba(255,62,94,.22),rgba(255,62,94,.08));
  border:1px solid rgba(255,62,94,.5);
  color:var(--red);
}
.status-banner.status-archived{
  background:linear-gradient(90deg,rgba(200,216,240,.10),rgba(200,216,240,.04));
  border:1px solid rgba(200,216,240,.25);
  color:var(--text-2);
}

/* Profile header card */

/* Shared section title */
.section-title{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.16em;
  color:var(--cyan);margin-bottom:14px;
  text-transform:uppercase;
}

/* Clickable user info tile */
.user-info-clickable{
  cursor:pointer;
  transition:all .18s;
  border:1px solid var(--border);
}
.user-info-clickable:hover{
  border-color:var(--cyan);
  box-shadow:0 0 18px var(--cyan-glow);
  transform:translateY(-1px);
}
.user-info-clickable .user-info-label::after{
  content:' \2197';
  color:var(--muted);font-size:9px;
}

/* Badges page */
.back-link{color:var(--muted);font-size:13px;text-decoration:none;display:inline-block;margin-bottom:20px}
.progress-wrap{margin-top:22px;padding:22px}
.progress-text{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--cyan);text-align:center;margin-bottom:12px}
.progress-bar-wrap{height:6px;background:var(--panel);border-radius:3px;overflow:hidden;border:1px solid var(--border)}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--violet));transition:width .25s ease}

.badge-chart-card{padding:22px;margin-bottom:18px}
.chart-note{color:var(--muted);font-size:12px;margin-bottom:14px;font-family:'JetBrains Mono',monospace}
.chart-canvas-wrap{position:relative;height:380px}
.user-info-date{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--cyan);font-weight:500}

.private-card{padding:48px;text-align:center}
.private-mark{font-family:'Cinzel',serif;font-size:48px;color:var(--muted);margin-bottom:12px;letter-spacing:.12em}
.private-note{color:var(--text-2);max-width:500px;margin:0 auto;line-height:1.6}

.offline-gap-list{display:flex;flex-direction:column;gap:10px}
.offline-gap{
  display:flex;flex-direction:column;gap:6px;
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r);padding:12px 16px;overflow:hidden;
}
.offline-gap-bar{
  min-width:4px;height:6px;max-width:100%;
  background:linear-gradient(90deg,var(--red),var(--amber));
  border-radius:4px;
}
.offline-gap-info{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;min-width:0}
.offline-gap-days{
  font-family:'Cinzel',serif;
  font-size:16px;font-weight:800;color:var(--cyan);white-space:nowrap;
}
.offline-gap-dates{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.err{color:var(--red);text-align:center;padding:40px}
.muted-center{color:var(--muted);text-align:center;padding:40px}

/* === Hero profile header (cheater + clan) === */
.hero-profile{
  position:relative;
  border-radius:var(--r-lg);
  margin-bottom:24px;
  background:linear-gradient(180deg,var(--card) 0%,var(--card-hi) 100%);
  border:1px solid var(--border);
  padding:0;
}
.hero-profile-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:blur(24px) brightness(0.35) saturate(0.7);
  border-radius:var(--r-lg);
  pointer-events:none;
  overflow:hidden;
}
.hero-profile::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 80% at 50% 0%, var(--tier-color, var(--cyan)), transparent 55%),
    radial-gradient(ellipse 60% 60% at 100% 100%, rgba(157,77,255,0.12), transparent 60%);
  opacity:.22;
}
.hero-profile::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--tier-color,var(--cyan)),transparent);
  opacity:.7;
}
.hero-profile-inner{
  position:relative;z-index:1;
  display:flex;gap:32px;align-items:center;
  padding:40px 40px 36px;
  flex-wrap:wrap;
}
.hero-avatar{
  position:relative;
  width:150px;height:150px;
  border-radius:50%;
  overflow:hidden;
  flex-shrink:0;
  border:4px solid var(--tier-color,var(--cyan));
  box-shadow:
    0 0 0 2px var(--bg),
    0 0 48px var(--tier-color,var(--cyan)),
    0 12px 32px rgba(0,0,0,0.55);
}
.hero-avatar img,.hero-avatar > div{width:100%;height:100%;object-fit:cover}
.hero-avatar-fallback{
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:68px;font-weight:900;
  color:var(--muted);background:var(--panel);
}
.hero-info{flex:1;min-width:260px;display:flex;flex-direction:column;gap:10px}
.hero-name{
  font-family:'Cinzel',serif;
  font-size:clamp(32px,6vw,52px);
  font-weight:900;
  line-height:1;
  letter-spacing:.02em;
  color:var(--tier-color,var(--cyan));
  text-shadow:0 0 34px var(--tier-color,var(--cyan));
}
.hero-handle{
  font-family:'JetBrains Mono',monospace;
  font-size:14px;color:var(--text-2);letter-spacing:.03em;
}
.hero-handle-id{color:var(--muted)}
.hero-badges{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  margin-top:4px;
}

/* Clan hero - square icon instead of round */
.hero-profile.clan .hero-avatar{
  width:150px;height:150px;border-radius:var(--r-lg);
  border-color:var(--cyan);
  box-shadow:0 0 0 2px var(--bg), 0 0 40px var(--cyan-glow), 0 12px 32px rgba(0,0,0,0.55);
}
.hero-profile.clan .hero-name{
  background:linear-gradient(135deg,#fff 0%,var(--cyan) 55%,var(--violet) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:none;
}
.hero-profile.clan::before{
  background:
    radial-gradient(ellipse 70% 80% at 50% 0%, var(--cyan), transparent 55%),
    radial-gradient(ellipse 60% 60% at 100% 100%, rgba(157,77,255,0.18), transparent 60%);
  opacity:.2;
}
.clan-meta-row{
  display:flex;flex-wrap:wrap;gap:22px;align-items:center;
  margin-top:6px;
}
.clan-meta-item{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;color:var(--text-2);letter-spacing:.02em;
}
.clan-meta-item strong{
  color:var(--cyan);font-weight:700;font-size:15px;
  font-family:'Cinzel',serif;
}
.hero-profile-desc{
  position:relative;z-index:1;
  padding:0 40px 36px;
  color:var(--text-2);line-height:1.65;font-size:14px;
  max-height:220px;overflow-y:auto;
  border-top:1px solid var(--border);
  margin-top:4px;padding-top:22px;
}
.hero-actions{
  position:absolute;top:20px;right:20px;z-index:2;
  display:flex;gap:8px;
}

@media(max-width:720px){
  .hero-profile-inner{padding:28px 22px 24px;gap:22px;flex-direction:column;align-items:center;text-align:center}
  .hero-badges{justify-content:center}
  .clan-meta-row{justify-content:center}
  .hero-profile-desc{padding:20px 22px 24px;text-align:left}
  .hero-actions{position:static;padding:0 22px 18px;justify-content:center}
}

/* Avatar fallback (when no image) */
.avatar-letter{
  display:flex;align-items:center;justify-content:center;
  background:var(--panel);
  color:var(--muted);
  font-family:'Cinzel',serif;
  font-size:20px;font-weight:700;
}

/* Cheater-likely flag visuals */
.flag-pill{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:700;letter-spacing:.14em;
  padding:3px 8px;border-radius:3px;
  background:rgba(255,192,67,.18);
  border:1px solid rgba(255,192,67,.65);
  color:var(--amber);
  text-transform:uppercase;
  box-shadow:0 0 10px rgba(255,192,67,.25);
  margin-left:6px;
  vertical-align:middle;
}

.flag-banner{
  display:flex;align-items:center;gap:18px;
  background:linear-gradient(100deg,rgba(255,192,67,.18),rgba(255,140,0,.08));
  border:1px solid rgba(255,192,67,.55);
  border-left:4px solid var(--amber);
  border-radius:var(--r-lg);
  padding:18px 22px;margin-bottom:22px;
  box-shadow:0 0 28px rgba(255,192,67,.12);
}
.flag-banner-icon{
  font-size:30px;color:var(--amber);
  flex-shrink:0;line-height:1;
  text-shadow:0 0 12px rgba(255,192,67,.6);
}
.flag-banner-title{
  font-family:'Cinzel',serif;
  font-size:17px;font-weight:900;letter-spacing:.1em;
  color:var(--amber);
  text-shadow:0 0 10px rgba(255,192,67,.4);
}
.flag-banner-sub{
  font-size:13px;color:var(--text-2);margin-top:3px;line-height:1.4;
}

.btn-warn{
  background:rgba(255,192,67,.12);
  border-color:var(--amber);color:var(--amber);
}
.btn-warn:hover{
  background:rgba(255,192,67,.22);
  box-shadow:0 0 18px rgba(255,192,67,.3);
}

/* Home marquee: recolor flagged clan chip */

/* Card header with edit button */
.card-title-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:14px;
}
.card-title-row .section-title{margin-bottom:0}

/* Evidence delete button overlay */
.evidence-item{position:relative}
.ev-delete-btn{
  position:absolute;top:6px;right:6px;z-index:2;
  width:26px;height:26px;border-radius:50%;
  background:rgba(5,7,15,0.85);
  border:1px solid rgba(255,62,94,0.6);
  color:var(--red);
  font-size:18px;font-weight:700;line-height:1;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.ev-delete-btn:hover{background:rgba(255,62,94,0.25);transform:scale(1.1)}

/* Admin page header row */
.admin-header-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;margin-bottom:16px;
}

/* Filter count hint */
.filter-count{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:14px;
}

/* Clan manager row */
.clan-row{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.clan-row-icon{
  width:64px;height:64px;border-radius:var(--r-lg);
  object-fit:cover;flex-shrink:0;
  border:2px solid var(--border-hi);
  background:var(--panel);
}
.clan-row-fallback{
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:26px;font-weight:700;
  color:var(--cyan);
}
.clan-row-info{flex:1;min-width:220px}
.clan-row-name{
  font-family:'Cinzel',serif;
  font-weight:800;font-size:18px;color:var(--text);
  line-height:1.2;
}
.clan-row-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);
  margin-top:4px;letter-spacing:.02em;
}
.clan-row-stats{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;
}
.clan-row-actions{
  display:flex;gap:7px;flex-wrap:wrap;
}
.clan-stat-pill{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  padding:4px 10px;border-radius:3px;
  background:var(--panel);
  border:1px solid var(--border);
  color:var(--text-2);
}
.clan-stat-pill strong{
  font-family:'Cinzel',serif;
  font-size:14px;font-weight:800;color:var(--text);
}
.clan-stat-pill.pill-exploit{
  background:rgba(0,224,255,.08);
  border-color:var(--cyan-dim);
  color:var(--cyan);
}
.clan-stat-pill.pill-exploit strong{color:var(--cyan)}
.clan-stat-pill.pill-degen{
  background:rgba(255,192,67,.08);
  border-color:rgba(255,192,67,.3);
  color:var(--amber);
}
.clan-stat-pill.pill-degen strong{color:var(--amber)}

/* Clickable clan row in manager */
.clan-row-link{
  display:flex;align-items:center;gap:18px;flex:1;
  text-decoration:none;color:inherit;
  min-width:260px;
  transition:opacity .15s;
}
.clan-row-link:hover{opacity:.85}
.clan-row-link:hover .clan-row-name{color:var(--cyan)}

/* Browse tabs */
.browse-tabs{
  display:flex;gap:4px;margin-bottom:22px;
  border-bottom:1px solid var(--border);
  padding-bottom:0;
}
.browse-tab{
  background:transparent;border:none;
  padding:12px 22px;
  font-family:'Cinzel',serif;
  font-weight:700;font-size:14px;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:all .2s;
}
.browse-tab:hover{color:var(--text-2)}
.browse-tab.active{
  color:var(--cyan);
  border-bottom-color:var(--cyan);
  text-shadow:0 0 14px var(--cyan-dim);
}

/* Offense admin row */
.offense-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;margin-bottom:10px;
}
.offense-row-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.offense-row-name{
  font-family:'Inter',sans-serif;
  font-size:15px;font-weight:600;color:var(--text);
}

/* Leaderboard */
.lb-row{
  display:flex;align-items:center;gap:18px;
  background:linear-gradient(135deg,var(--card) 0%,var(--card-hi) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:16px 22px;
  margin-bottom:10px;
  text-decoration:none;color:inherit;
  transition:all .2s;
}
.lb-row:hover{
  border-color:var(--border-hi);
  transform:translateX(3px);
  box-shadow:0 0 22px var(--cyan-glow);
}
.lb-rank{
  font-family:'Cinzel',serif;
  font-size:24px;font-weight:900;
  color:var(--cyan);
  min-width:60px;text-align:center;
  text-shadow:0 0 18px var(--cyan-dim);
}
.lb-icon{
  width:64px;height:64px;border-radius:var(--r-lg);
  object-fit:cover;flex-shrink:0;
  border:2px solid var(--border-hi);
  background:var(--panel);
}
.lb-icon-fallback{
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:26px;font-weight:700;
  color:var(--cyan);
}
.lb-name-col{flex:1;min-width:160px}
.lb-name{
  font-family:'Cinzel',serif;font-weight:800;font-size:18px;
  color:var(--text);
}
.lb-sub{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.02em;
}
.lb-stats{
  display:flex;gap:10px;flex-wrap:wrap;
  flex-shrink:0;
}
.lb-stat{
  min-width:68px;
  padding:8px 14px;border-radius:var(--r);
  background:var(--panel);
  border:1px solid var(--border);
  text-align:center;
}
.lb-stat-val{
  font-family:'Cinzel',serif;
  font-size:20px;font-weight:800;color:var(--text);
  line-height:1;
}
.lb-stat-lbl{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;color:var(--muted);letter-spacing:.12em;
  text-transform:uppercase;margin-top:4px;
}
.lb-stat-exp .lb-stat-val{color:var(--cyan)}
.lb-stat-exp{border-color:var(--cyan-dim)}
.lb-stat-deg .lb-stat-val{color:var(--amber)}
.lb-stat-deg{border-color:rgba(255,192,67,.3)}
.lb-stat-rem .lb-stat-val{color:var(--green)}
.lb-stat-rem{border-color:rgba(44,255,171,.3)}

/* Markdown body */
.markdown-body{
  padding:34px 38px;
  font-size:15px;line-height:1.75;color:var(--text-2);
}
.markdown-body h1{
  font-family:'Cinzel',serif;
  font-size:32px;font-weight:900;color:var(--cyan);
  text-shadow:0 0 24px rgba(0,224,255,0.35);
  letter-spacing:.06em;margin:34px 0 18px;line-height:1.1;
}
.markdown-body h1:first-child{margin-top:0}
.markdown-body h2{
  font-family:'Cinzel',serif;
  font-size:22px;font-weight:800;color:var(--text);
  letter-spacing:.04em;margin:28px 0 14px;
  padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
.markdown-body h3{
  font-family:'Cinzel',serif;
  font-size:17px;font-weight:700;color:var(--cyan);
  margin:22px 0 10px;
}
.markdown-body p{margin-bottom:14px}
.markdown-body strong{color:var(--text);font-weight:700}
.markdown-body em{color:var(--amber);font-style:normal}
.markdown-body ul{margin:10px 0 18px 22px}
.markdown-body li{margin-bottom:6px}

/* Guidelines editor */
.guidelines-editor-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
@media(max-width:900px){
  .guidelines-editor-grid{grid-template-columns:1fr}
  .lb-stats{flex-wrap:wrap;justify-content:flex-start}
}

/* PRIVATED clan indicator */
.private-pill{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:700;letter-spacing:.14em;
  padding:3px 8px;border-radius:3px;
  background:rgba(157,77,255,.14);
  border:1px solid rgba(157,77,255,.55);
  color:var(--violet);
  text-transform:uppercase;
  box-shadow:0 0 10px rgba(157,77,255,.18);
  margin-left:6px;
  vertical-align:middle;
}

/* PRIVATED stat replacement */
.clan-stat-pill.pill-private{
  background:rgba(157,77,255,.14);
  border-color:rgba(157,77,255,.55);
  color:var(--violet);
  font-family:'JetBrains Mono',monospace;
  font-weight:700;letter-spacing:.14em;
}
.lb-stat.lb-stat-private{
  border-color:rgba(157,77,255,.55);
  background:rgba(157,77,255,.08);
  min-width:160px;
}
.lb-stat.lb-stat-private .lb-stat-val{
  color:var(--violet);
  font-family:'JetBrains Mono',monospace;
  font-size:16px;letter-spacing:.14em;
}

/* Approval-required (invite-only) clan indicator */
.join-pill{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:700;letter-spacing:.14em;
  padding:3px 8px;border-radius:3px;
  background:rgba(44,255,171,.12);
  border:1px solid rgba(44,255,171,.45);
  color:var(--green);
  text-transform:uppercase;
  margin-left:6px;
  vertical-align:middle;
}

/* === UI polish pass === */

/* Smoother hover on interactive elements */
.btn, .cheater-card, .player-card, .clan-card, .stat-box, .lb-row, .user-info-item,
.clan-row-link, .offense-tag, .clan-row, .profile-clan, .nav-links a,
.nav-admin-btn, .page-btn {
  will-change: transform, box-shadow;
}

/* Subtle hover lift on stat boxes */
.stat-box{cursor:default}

/* Nicer focus rings across all form controls */
.form-input:focus-visible,
.form-select:focus-visible,
.form-textarea:focus-visible,
.search-input:focus-visible,
.filter-select:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px var(--cyan-glow), 0 0 24px rgba(0,224,255,0.18);
}

/* Button focus visible */
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px var(--cyan-glow);
}

/* Smoother link hovers in the nav */
.nav-links a{position:relative}
.nav-links a::before{
  content:'';position:absolute;left:50%;right:50%;bottom:2px;height:2px;
  background:var(--cyan);opacity:0;transition:all .22s ease;
}
.nav-links a:hover::before{left:14px;right:14px;opacity:.6}
.nav-links a.active::before{left:14px;right:14px;opacity:1}

/* Scrollbars — only affects WebKit/Chromium but graceful */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:var(--bg)}
*::-webkit-scrollbar-thumb{background:rgba(0,224,255,0.18);border-radius:10px;border:2px solid var(--bg)}
*::-webkit-scrollbar-thumb:hover{background:rgba(0,224,255,0.35)}

/* Selection color */
::selection{background:rgba(0,224,255,0.35);color:#fff}

/* Smoother card reveal animation */
@keyframes cardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.card, .cheater-card, .player-card, .clan-card, .lb-row, .clan-row{animation:cardIn .35s ease both}

/* Loading skeleton block (alternative to spinner for list areas) */
.skeleton{
  background:linear-gradient(90deg,
    rgba(0,224,255,0.04) 0%,
    rgba(0,224,255,0.12) 50%,
    rgba(0,224,255,0.04) 100%);
  background-size:200% 100%;
  animation:shimmer 1.6s ease infinite;
  border-radius:var(--r);
}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

/* Empty-state messaging — unified styling */

/* Card hover polish */
.card:hover{transition:all .2s ease}

/* Tooltip cursor on info pills */
.flag-pill, .private-pill, .join-pill{cursor:help}

/* Hero CTAs: subtle glow ramp-up on hover */
.hero-cta .btn{transition:all .22s cubic-bezier(.4,.14,.3,1)}
.hero-cta .btn:hover{transform:translateY(-2px)}

/* Tier badges — pulse faintly for Tier 5 */
@keyframes t5-pulse{
  0%,100%{box-shadow:0 0 8px rgba(154,15,43,0.4)}
  50%{box-shadow:0 0 16px rgba(154,15,43,0.7)}
}
.tier-badge.tier-5{animation:t5-pulse 2.4s ease-in-out infinite}

/* Profile hero polish */
.hero-profile{transition:border-color .3s}

/* Reduce visual noise on admin rows */
.clan-row{transition:all .2s}
.clan-row:hover{background:linear-gradient(180deg,var(--card-hi),var(--card-hi))}

/* Live presence counter in the nav */
.nav-presence{
  display:inline-flex;align-items:center;gap:8px;
  margin-right:14px;padding:6px 14px;
  background:rgba(44,255,171,0.06);
  border:1px solid rgba(44,255,171,0.22);
  border-radius:999px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.06em;
  color:var(--text-2);
  white-space:nowrap;line-height:1;
}
.nav-presence:empty{display:none}
.presence-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px rgba(44,255,171,0.6);
  animation:presence-pulse 2s ease-in-out infinite;
}
@keyframes presence-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.55;transform:scale(.92)}
}
.presence-online{
  color:var(--green);font-weight:700;
  display:inline-flex;align-items:baseline;white-space:nowrap;
}
.presence-online::after{
  content:'online';color:var(--muted);font-weight:400;margin-left:4px;
  text-transform:uppercase;font-size:9px;letter-spacing:.12em;
}
.presence-sep{color:rgba(200,216,240,0.25)}
.presence-total{color:var(--cyan);font-weight:700;display:inline-flex;align-items:center;gap:4px}
.presence-label{
  color:var(--muted);font-weight:400;
  text-transform:uppercase;font-size:9px;letter-spacing:.12em;
}

/* Presence hides inside hamburger menu on mobile */

/* Feedback admin row */
.fb-row{margin-bottom:14px;padding:18px 22px}
.fb-row-head{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-bottom:12px;
}
.fb-kind{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:700;letter-spacing:.14em;
  padding:3px 10px;border-radius:3px;
  text-transform:uppercase;
}
.fb-kind-bug{background:rgba(255,62,94,.15);border:1px solid rgba(255,62,94,.45);color:var(--red)}
.fb-kind-feature{background:rgba(0,224,255,.12);border:1px solid var(--cyan-dim);color:var(--cyan)}
.fb-kind-review{background:rgba(44,255,171,.12);border:1px solid rgba(44,255,171,.45);color:var(--green)}
.fb-kind-other{background:rgba(157,77,255,.12);border:1px solid rgba(157,77,255,.45);color:var(--violet)}

.fb-status{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:700;letter-spacing:.14em;
  padding:3px 9px;border-radius:3px;
  text-transform:uppercase;
  background:var(--panel);
  border:1px solid var(--border);
  color:var(--muted);
}
.fb-status-new{color:var(--amber);border-color:rgba(255,192,67,.45);background:rgba(255,192,67,.08)}
.fb-status-read{color:var(--text-2)}
.fb-status-archived{color:var(--muted);opacity:.7}

.fb-date{
  margin-left:auto;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);
}

.fb-message{
  color:var(--text);
  line-height:1.65;
  white-space:pre-wrap;
  font-size:14px;
  margin-bottom:12px;
}

.fb-contact{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--cyan);
  background:rgba(0,224,255,.06);
  padding:6px 12px;
  border-radius:var(--r);
  border:1px solid var(--border);
  margin-bottom:12px;
  display:inline-block;
}

.fb-actions{
  display:flex;gap:7px;flex-wrap:wrap;
}

/* Update card */
.update-card{
  margin-bottom:18px;
  padding:26px 32px;
}
.update-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--muted);
  letter-spacing:.04em;margin-bottom:10px;
}
.update-title{
  font-family:'Cinzel',serif;
  font-size:22px;font-weight:800;
  color:var(--cyan);
  text-shadow:0 0 18px rgba(0,224,255,0.25);
  letter-spacing:.03em;line-height:1.2;
  margin-bottom:14px;
}
.update-body{padding:0;border-top:1px solid var(--border);padding-top:14px}
.update-body h1,.update-body h2,.update-body h3{margin-top:14px}
.update-body h1:first-child,.update-body h2:first-child,.update-body h3:first-child{margin-top:0}
.update-card-admin .fb-actions{margin-top:12px}

/* === RESPONSIVE (hamburger nav + mobile scaling) === */

/* Hamburger button - hidden by default */
.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--border-hi);
  color:var(--cyan);
  width:42px;height:42px;
  border-radius:var(--r);
  font-size:22px;line-height:1;
  cursor:pointer;
  margin-left:auto;
  align-items:center;justify-content:center;
  transition:all .2s;
}
.nav-toggle:hover{background:var(--cyan-glow);box-shadow:0 0 14px var(--cyan-dim)}

/* The wrapper around nav-links + spacer + presence + user badge + admin btn */
.nav-collapse{display:flex;align-items:center;flex:1;min-width:0}

/* Right side group - always visible, presence hides when tight */
.nav-right{
  display:flex;align-items:center;gap:8px;
  margin-left:auto;flex-shrink:0;white-space:nowrap;
}
@media (max-width:1500px){
  .nav-right .nav-presence{display:none}
}

/* Links take remaining space and hide overflow */
.nav-links{flex:1;min-width:0}

/* Tablet + mobile breakpoint: hamburger kicks in */
@media (max-width: 900px){
  nav{
    padding:10px 18px;
    min-height:64px;height:auto;
    flex-wrap:wrap;
    align-items:center;
    row-gap:0;
  }
  .nav-toggle{display:inline-flex}

  /* First row: logo on the left, hamburger on the right. */
  .nav-logo{flex:0 0 auto}
  .nav-toggle{flex:0 0 auto;margin-left:auto}

  /* Second row: the collapsible menu wrapper. Width 100% forces it onto its own row. */
  .nav-collapse{
    display:none;
    flex-basis:100%;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    margin-top:12px;
    padding:12px 16px 16px;
    border-top:1px solid var(--border);
    background:var(--panel);
    border-radius:0 0 var(--r-lg) var(--r-lg);
    box-shadow:0 8px 32px rgba(0,0,0,0.4);
    z-index:101;
    overflow:visible;
  }
  nav.nav-open .nav-collapse{display:flex;overflow:visible}

  /* Stacked links — override the base horizontal layout completely */
  .nav-links{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:2px;
    margin:0;
    padding:0;
    width:100%;
  }
  .nav-links li{
    display:block;
    width:100%;
    list-style:none;
  }
  .nav-links a{
    display:block;
    width:100%;
    padding:12px 16px;
    font-size:14px;
    border-radius:var(--r);
    line-height:1.4;
    position:static; /* kill the absolute ::before underline that would overlap */
  }
  /* Remove the hover-underline pseudo-element that was designed for horizontal layout */
  .nav-links a::before,
  .nav-links a.active::after{display:none !important}
  .nav-links a.active{background:var(--cyan-glow)}
  .nav-links a:hover,
  .nav-links a:focus-visible{background:var(--cyan-glow)}
  .nav-more>.nav-dropdown{
    display:block;position:static;transform:none;
    min-width:0;padding:0;margin:0;
    background:none;border:none;border-radius:0;box-shadow:none;
  }
  .nav-more>a{display:none}

  /* Disable touch-sticky hover on mobile so tapped items don't stay highlighted */
  @media (hover: none) {
    .nav-links a:hover{background:transparent}
  }

  .nav-right{
    display:flex;
    margin-left:0;flex-shrink:1;flex-wrap:wrap;
    justify-content:center;gap:8px;width:100%;
  }
  .nav-presence{
    justify-content:center;
    margin:6px 0 2px;
    width:100%;
  }
  .nav-user-badge{
    margin:0 0 6px;
    justify-content:center;
    align-self:center;
  }
  .nav-admin-btn{
    display:block;
    text-align:center;
    margin-top:4px;
    width:100%;
  }
}

/* Small phones */
@media (max-width: 560px){
  nav{padding:0 14px;height:58px}
  .nav-logo img{height:34px;width:34px}
  .nav-logo-text{font-size:16px;letter-spacing:.1em}
  .container{padding:0 14px}
  .page-header{padding:36px 0 20px}
  .page-title{font-size:clamp(24px,7vw,34px)}
  .hero{padding:52px 0 30px}
  .hero-logo{width:84px;height:84px}
  .hero-title{font-size:clamp(36px,10vw,56px)}
  .hero-sub{font-size:14px}
  .hero-cta{flex-direction:column;gap:10px}
  .hero-cta .btn{width:100%;justify-content:center}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-box{padding:16px 14px}
  .stat-number{font-size:30px}
  .entries-grid{gap:8px}
  .cheater-card{padding:12px 14px;gap:12px}
  .cheater-card .avatar{width:46px;height:46px}
  .cheater-card .username{font-size:14px}
  .top-tier-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .filter-bar{gap:8px}
  .filter-bar .search-input{width:100%}
  .filter-bar .filter-select,
  .filter-bar input.filter-select{flex:1;min-width:0}
  .card{padding:18px}
  .page-subtitle{font-size:13px}

  /* Admin layout: sidebar on top, content below, tighter spacing */
  .admin-layout{grid-template-columns:1fr}
  .admin-sidebar{
    position:static;height:auto;
    padding:14px 0;
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .admin-sidebar a{padding:10px 18px;font-size:13px}
  .admin-content{padding:22px 16px}
  .admin-header-row{gap:10px}

  /* Cheater profile hero */
  .hero-profile-inner{padding:24px 20px 20px;gap:18px}
  .hero-avatar{width:120px;height:120px}
  .hero-profile.clan .hero-avatar{width:110px;height:110px}
  .hero-name{font-size:clamp(24px,7vw,36px) !important}
  .hero-actions{position:static;padding:12px 20px 0;justify-content:center}

  /* Clan profile stats */
  .clan-stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .clan-header-icon{width:96px;height:96px}

  /* User info tiles */
  .user-info-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .user-info-item{padding:12px 14px}
  .user-info-value{font-size:16px}

  /* Leaderboard row */
  .lb-row{padding:14px 16px;gap:12px;flex-wrap:wrap}
  .lb-rank{font-size:20px;min-width:48px}
  .lb-icon{width:52px;height:52px}
  .lb-name{font-size:15px}
  .lb-stats{width:100%;flex:none;gap:6px}
  .lb-stat{min-width:0;flex:1;padding:8px 6px}
  .lb-stat-val{font-size:16px}

  /* Clan manager row */
  .clan-row{flex-direction:column;align-items:flex-start}
  .clan-row-link{width:100%}
  .clan-row-actions{width:100%;justify-content:flex-start}

  /* Evidence grid */
  .evidence-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}

  /* Guidelines editor becomes single column */
  .guidelines-editor-grid{grid-template-columns:1fr}
  .chart-canvas-wrap{height:300px}

  /* Toast — mobile positioning */
  #toast{top:auto;bottom:14px;left:14px;right:14px}

  /* Hero profile on cheater page */
  .hero-info{min-width:0;width:100%;text-align:center;align-items:center}
  .hero-badges{justify-content:center}
  .hero-handle{word-break:break-word}
}

/* Nav presence pill stays hidden on the smallest screens to keep header clean */
@media (max-width: 420px){
  .hero-title{font-size:clamp(32px,9vw,48px)}
}

/* Medium desktop — tighten nav spacing before the hamburger threshold kicks in.
   Ensures 7+ links + presence pill + admin button fit without clipping. */

/* Active link background shouldn't extend beyond the text — reset to inline-block */
.nav-links a{
  white-space:nowrap;
  text-align:center;
}



/* Flex safety: keep items shrinking gracefully instead of clipping */
nav{min-width:0}
.nav-logo{flex-shrink:0;min-width:0}
.nav-admin-btn{flex-shrink:1;white-space:nowrap}

/* Hard wall between the nav links and the right-side group (presence/badge/admin).
   Even if flex auto-sizing tries to collapse the spacer, keep at least 32px of air. */




/* No-evidence warning pill (moderator+ visibility only) */
.no-evidence-pill{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:700;letter-spacing:.14em;
  padding:3px 8px;border-radius:3px;
  background:rgba(255,62,94,.14);
  border:1px solid rgba(255,62,94,.55);
  color:var(--red);
  text-transform:uppercase;
  box-shadow:0 0 10px rgba(255,62,94,.2);
  margin-left:4px;
  vertical-align:middle;
}

/* Staff-only filter toggle on browse page */
.staff-filter{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;
  background:rgba(157,77,255,.08);
  border:1px solid rgba(157,77,255,.35);
  border-radius:var(--r);
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--violet);
  letter-spacing:.04em;cursor:pointer;
  user-select:none;
}
.staff-filter input{accent-color:var(--violet);cursor:pointer}
.staff-filter:hover{border-color:var(--violet);box-shadow:0 0 14px rgba(157,77,255,.22)}

/* === MOBILE RESPONSIVENESS (768px) === */
@media (max-width: 768px) {
  /* Admin sidebar: collapsible */
  .admin-layout {
    grid-template-columns: 1fr;
  }
  .admin-sidebar {
    display: none;
    position: fixed;
    top: 68px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 90;
    height: auto;
    max-height: calc(100vh - 68px);
    overflow-y: auto;
    border-right: none;
    border-bottom: 1px solid var(--border);
    box-shadow: 0 10px 40px rgba(0,0,0,0.6);
  }
  .admin-sidebar.open {
    display: block;
  }
  .admin-content {
    padding: 20px 16px;
  }

  /* Hamburger toggle for admin sidebar */
  .admin-sidebar-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--border-hi);
    color: var(--cyan);
    width: 38px;
    height: 38px;
    border-radius: var(--r);
    font-size: 20px;
    cursor: pointer;
    margin-right: 12px;
    transition: all .2s;
    flex-shrink: 0;
  }
  .admin-sidebar-toggle:hover {
    background: var(--cyan-glow);
    box-shadow: 0 0 14px var(--cyan-dim);
  }

  /* Filter bars stack vertically */
  .filter-bar,
  .dir-filters {
    flex-direction: column;
    align-items: stretch;
  }
  .filter-bar > *,
  .dir-filters > * {
    width: 100%;
    min-width: 0;
  }
  .dir-filters input {
    min-width: 0;
  }

  /* Stats row wrapping */
  .stats-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  /* Hero title sizing */
  .hero-title {
    font-size: clamp(28px, 8vw, 48px);
  }
  .page-title {
    font-size: clamp(22px, 5vw, 40px);
  }

  /* Cards full width */
  .card {
    width: 100%;
  }
  .top-tier-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  /* Comparison cards stack */
  .compare-grid,
  .compare-row {
    flex-direction: column;
    gap: 12px;
  }
  .compare-card {
    width: 100%;
  }

  /* Tables horizontally scrollable */
  .dir-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .dir-table {
    min-width: 600px;
  }

  /* Reduce padding/margins */
  .container {
    padding: 0 14px;
  }
  .page-header {
    padding: 32px 0 18px;
  }

  /* Search bar stacking */
  .search-bar {
    flex-direction: column;
    gap: 8px;
  }

  /* Entries grid */
  .entries-grid {
    gap: 8px;
  }
  .cheater-card {
    padding: 12px 14px;
    gap: 10px;
  }

  /* Stat boxes */
  .stat-box {
    padding: 16px 12px;
  }
  .stat-number {
    font-size: 28px;
  }

  /* Evidence grid */
  .evidence-grid {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}

/* Autocomplete results */
.ac-result{display:flex;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border);transition:background .15s}
.ac-result:hover{background:var(--card-hi)}

/* Copy button */
.copy-btn{background:none;border:1px solid var(--border);border-radius:var(--r);padding:3px 8px;cursor:pointer;color:var(--muted);font-size:11px;font-family:'JetBrains Mono',monospace;transition:all .2s;display:inline-flex;align-items:center;gap:4px}
.copy-btn:hover{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-glow)}
.copy-btn.copied{color:var(--green);border-color:var(--green)}

/* Leaderboard rank highlights */
.lb-rank-1{color:#FFD700;font-weight:800;text-shadow:0 0 12px rgba(255,215,0,0.5)}
.lb-rank-2{color:#C0C0C0;font-weight:800;text-shadow:0 0 10px rgba(192,192,192,0.4)}
.lb-rank-3{color:#CD7F32;font-weight:800;text-shadow:0 0 10px rgba(205,127,50,0.4)}

/* Evidence lightbox */
.lightbox-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.92);display:flex;align-items:center;justify-content:center;cursor:zoom-out;opacity:0;transition:opacity .2s;pointer-events:none}
.lightbox-overlay.open{opacity:1;pointer-events:all}
.lightbox-overlay img,.lightbox-overlay video{max-width:92vw;max-height:88vh;border-radius:var(--r-lg);box-shadow:0 0 60px rgba(0,224,255,0.2)}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
  .float{animation:none !important}
}

/* System theme detection */
@media (prefers-color-scheme: light) {
  :root:not(.theme-dark) { --bg:#f0f2f5;--panel:#ffffff;--panel-2:#f8f9fa;--card:#ffffff;--card-hi:#f0f2f5;--text:#1a1a2e;--text-2:#4a4a6a;--muted:rgba(0,0,0,0.5);--border:rgba(0,100,200,0.2);--border-hi:rgba(0,100,200,0.4);--cyan-dim:rgba(0,180,220,0.22);--cyan-glow:rgba(0,180,220,0.10) }
}

/* Loading skeletons */
.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--card-hi) 50%,var(--card) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--r)}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-text{height:14px;margin:8px 0;border-radius:4px}
.skeleton-title{height:24px;width:60%;margin:12px 0;border-radius:4px}
.skeleton-avatar{width:56px;height:56px;border-radius:50%}
.skeleton-card{padding:22px;border:1px solid var(--border);border-radius:var(--r-lg);min-height:120px}
.skeleton-row{display:flex;align-items:center;gap:14px;padding:14px 18px}
.skeleton-badge{width:60px;height:22px;border-radius:4px;display:inline-block}
.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}

/* Mobile touch targets */
@media (max-width:768px) {
  .btn-sm{padding:10px 16px;font-size:12px;min-height:44px}
  .page-btn{padding:12px 18px;min-height:44px}
  .filter-select,.search-input{min-height:44px}
}

/* Submit form mobile single-column */
@media (max-width:560px) {
  form .form-group { break-inside: avoid }
  #form > div[style*="grid-template-columns"] { grid-template-columns: 1fr !important }
}

/* Light theme body pseudo-element overrides */
.theme-light::before {
  background: radial-gradient(1000px 600px at 10% -10%, rgba(0,100,200,0.06), transparent 60%),
              radial-gradient(900px 500px at 90% 0%, rgba(100,50,200,0.06), transparent 60%),
              radial-gradient(700px 500px at 50% 100%, rgba(200,50,100,0.04), transparent 60%);
}
.theme-light::after {
  background-image: linear-gradient(rgba(0,100,200,0.04) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(0,100,200,0.04) 1px, transparent 1px);
}
.theme-light nav {
  background: rgba(240,242,245,0.92);
}
.theme-light .form-select option {
  background: #ffffff;
}
.theme-light .form-input,
.theme-light .form-select,
.theme-light .form-textarea {
  background: rgba(240,242,245,0.9);
}

/* Scroll to top button */
.scroll-top{position:fixed;bottom:28px;right:28px;z-index:90;width:44px;height:44px;border-radius:50%;background:var(--panel);border:1px solid var(--border-hi);color:var(--cyan);font-size:20px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .25s;box-shadow:var(--shadow)}
.scroll-top:hover{background:var(--cyan-glow);transform:translateY(-2px);box-shadow:0 0 24px rgba(0,224,255,0.35)}
.scroll-top.visible{display:flex}

/* Share button on profiles */
.share-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);background:none;border:1px solid var(--border);border-radius:var(--r);padding:5px 12px;cursor:pointer;font-family:'JetBrains Mono',monospace;transition:all .2s}
.share-btn:hover{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-glow)}

/* Relative time styling */

/* Command palette */
.cmd-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:500;display:none;align-items:flex-start;justify-content:center;padding-top:min(20vh,160px);backdrop-filter:blur(4px)}
.cmd-overlay.open{display:flex}
.cmd-box{width:min(560px,90vw);background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,0.5),0 0 30px rgba(0,224,255,0.1);overflow:hidden}
.cmd-input{width:100%;padding:16px 20px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:16px;font-family:'Inter',sans-serif;outline:none}
.cmd-input::placeholder{color:var(--muted)}
.cmd-results{max-height:340px;overflow-y:auto;padding:6px 0}
.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;transition:background .1s;color:var(--text-2);font-size:14px}
.cmd-item:hover,.cmd-item.selected{background:rgba(0,224,255,0.08);color:var(--text)}
.cmd-item img{width:32px;height:32px;border-radius:50%;object-fit:cover}
.cmd-item .cmd-type{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-left:auto}
.cmd-hint{padding:10px 20px;font-size:12px;color:var(--muted);border-top:1px solid var(--border);display:flex;gap:16px}
.cmd-hint kbd{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:1px 6px;font-family:'JetBrains Mono',monospace;font-size:11px}

/* Clan profile redesign */
.clan-banner{position:relative;height:180px;overflow:hidden;border-radius:var(--r-lg);margin-bottom:24px;border:1px solid var(--border)}
.clan-banner-bg{position:absolute;inset:-20px;background-size:cover;background-position:center;filter:blur(20px) brightness(0.4);transform:scale(1.1)}
.clan-banner-content{position:relative;z-index:1;display:flex;align-items:center;gap:20px;padding:30px;height:100%}
.clan-banner-icon{width:80px;height:80px;border-radius:var(--r-lg);object-fit:cover;border:3px solid var(--border-hi);box-shadow:0 4px 20px rgba(0,0,0,0.4)}
.clan-banner-icon-letter{width:80px;height:80px;border-radius:var(--r-lg);background:var(--panel);border:3px solid var(--border-hi);display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:32px;color:var(--cyan);font-weight:700}
.clan-banner-info h1{font-family:'Cinzel',serif;font-size:28px;font-weight:800;color:var(--cyan);text-shadow:0 0 20px rgba(0,224,255,0.4);margin:0}
.clan-banner-info .clan-meta{color:var(--text-2);font-size:14px;margin-top:4px}
.clan-banner-info .clan-badges{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}

/* Risk gauge */
.risk-gauge{width:100px;height:100px;position:relative;margin-left:auto;flex-shrink:0}
.risk-gauge svg{transform:rotate(-90deg)}
.risk-gauge-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:700}

/* Clan tabs */
.clan-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}
.clan-tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase;letter-spacing:.06em;font-family:'Inter',sans-serif}
.clan-tab:hover{color:var(--text)}
.clan-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.clan-tab-panel{display:none}
.clan-tab-panel.active{display:block}

/* Cheater timeline */
.timeline{display:flex;flex-direction:column;gap:0;padding-left:20px;border-left:2px solid var(--border)}
.timeline-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;position:relative}
.timeline-item::before{content:'';position:absolute;left:-25px;top:16px;width:8px;height:8px;border-radius:50%;background:var(--cyan);border:2px solid var(--bg)}
.timeline-icon{font-size:16px;flex-shrink:0}
.timeline-content{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;font-size:13px}
.timeline-label{font-weight:600;color:var(--text)}
.timeline-by{color:var(--muted);font-size:12px}
.timeline-date{color:var(--muted);font-size:12px;font-family:'JetBrains Mono',monospace;margin-left:auto}

/* Threat level bar */
.threat-bar{display:flex;align-items:center;gap:8px;margin-top:8px}
.threat-track{flex:1;max-width:200px;height:6px;border-radius:3px;background:rgba(255,255,255,0.06);overflow:hidden}
.threat-fill{height:100%;border-radius:3px;transition:width .6s ease}
.threat-label{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.08em}

/* Page load fade-in */
.container,.admin-content{animation:page-fadein .3s ease}
@keyframes page-fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Site footer */
.site-footer{margin-top:60px;padding:32px 0;border-top:1px solid var(--border);background:rgba(5,7,15,0.6)}
.footer-inner{max-width:1240px;margin:0 auto;padding:0 26px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.footer-brand{display:flex;align-items:center;gap:10px;font-family:'Cinzel',serif;font-size:15px;font-weight:700;color:var(--cyan);letter-spacing:.12em}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 20px}
.footer-links a{font-size:13px;color:var(--muted);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--cyan)}
.footer-meta{font-size:12px;color:rgba(200,216,240,0.35);letter-spacing:.04em}

/* Live feed */
.feed-item{display:flex;align-items:center;gap:12px;padding:12px 18px;text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s}
.feed-item:last-child{border-bottom:none}
.feed-item:hover{background:rgba(0,224,255,0.04)}
.feed-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.feed-avatar-fallback{background:var(--panel);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--cyan);font-weight:700}
.feed-info{flex:1;font-size:13px;color:var(--text);display:flex;flex-wrap:wrap;align-items:center;gap:4px}
.feed-name{font-weight:600;color:var(--text)}
.feed-action{color:var(--muted);font-size:12px}
.feed-time{font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace;flex-shrink:0;white-space:nowrap}

/* Light theme overrides for new components */
.theme-light .site-footer{background:rgba(240,242,245,0.8);border-top-color:rgba(0,100,200,0.15)}
.theme-light .footer-meta{color:rgba(0,0,0,0.35)}
.theme-light .cmd-hint kbd{background:rgba(0,100,200,0.06);border-color:rgba(0,100,200,0.3)}
.theme-light .clan-banner-bg{filter:blur(20px) brightness(0.85) saturate(0.4)}
.theme-light .hero-profile-bg{filter:blur(24px) brightness(0.85) saturate(0.4)}
.theme-light .clan-banner{border-color:rgba(0,100,200,0.25)}
.theme-light .feed-item:hover{background:rgba(0,100,200,0.04)}
.theme-light .toast-ok{background:rgba(44,200,130,0.15);border-color:rgba(44,200,130,0.4)}
.theme-light .toast-err{background:rgba(220,50,70,0.15);border-color:rgba(220,50,70,0.4)}
/* Admin 3-col grid responsive */
@media(max-width:560px){.admin-content div[style*="1fr 1fr 1fr"]{grid-template-columns:1fr !important}}

/* Global focus-visible for keyboard nav */
a:focus-visible,.page-btn:focus-visible,.browse-tab:focus-visible,.nav-toggle:focus-visible,.cheater-card:focus-visible,.lb-row:focus-visible,.player-card:focus-visible,.clan-card:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;box-shadow:0 0 0 4px var(--cyan-glow)}
.nav-links a:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

/* Checker scan button hover */
.checker-form button{transition:opacity .18s,box-shadow .18s}
.checker-form button:hover:not(:disabled){opacity:.88;box-shadow:0 0 18px rgba(0,224,255,0.4)}
.checker-form button:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

/* Theme toggle hover */
#themeToggleBtn:hover{border-color:var(--border-hi) !important;background:var(--cyan-glow) !important;color:var(--cyan) !important}
#themeToggleBtn:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

/* Standardized empty state */
.muted-center{color:var(--muted);text-align:center;padding:48px 24px;font-size:14px;letter-spacing:.02em;line-height:1.6}


/* Ctrl+K first-visit hint */
.ctrlk-hint{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r-lg);padding:12px 20px;font-size:13px;color:var(--text-2);z-index:500;opacity:0;transition:all .3s ease;pointer-events:none;box-shadow:0 8px 30px rgba(0,0,0,0.4)}
.ctrlk-hint.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ctrlk-hint kbd{background:var(--card);border:1px solid var(--border);border-radius:3px;padding:2px 8px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--cyan);margin-right:6px}

/* Scan indicator */
.scan-indicator{padding:10px 16px;font-size:12px;color:var(--cyan);font-family:'JetBrains Mono',monospace;letter-spacing:.04em;border-top:1px solid var(--border);margin-top:10px;animation:pulse-glow 1.5s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{opacity:1}50%{opacity:.5}}

/* Chart canvas glow */
.badge-chart-card canvas{filter:drop-shadow(0 0 6px rgba(0,224,255,0.15))}

/* ═══ Homepage Dashboard ═══ */
.home-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:0 0 36px}
.home-stat{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 16px;text-align:center;position:relative;overflow:hidden;transition:all .25s}
.home-stat::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top,var(--cyan-glow),transparent 60%);opacity:.5;pointer-events:none}
.home-stat:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:var(--shadow-cyan)}
.home-stat-val{font-family:'Cinzel',serif;font-size:36px;font-weight:800;color:var(--cyan);text-shadow:0 0 20px rgba(0,224,255,0.4);line-height:1}
.home-stat-lbl{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-top:6px}

/* Clan carousel — infinite marquee */
.clan-carousel-wrap{position:relative;margin:0 0 36px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,black 4%,black 96%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,black 4%,black 96%,transparent)}
.clan-carousel{display:flex;gap:16px;width:max-content;animation:marquee calc(var(--carousel-items,10) * 3s) linear infinite;padding:4px 0}
.clan-carousel:hover{animation-play-state:paused}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.clan-carousel-item{flex:0 0 200px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 14px;text-align:center;text-decoration:none;color:inherit;transition:border-color .25s,box-shadow .25s;position:relative;overflow:hidden}
.clan-carousel-item:hover{border-color:var(--cyan);box-shadow:var(--shadow-cyan)}
.clan-carousel-item::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.4}
.clan-carousel-icon{width:56px;height:56px;border-radius:50%;object-fit:cover;margin:0 auto 10px;display:block;border:2px solid var(--border);box-shadow:0 4px 12px rgba(0,0,0,0.4)}
.clan-carousel-fallback{width:56px;height:56px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:24px;font-weight:900;color:var(--cyan);background:var(--panel);border:2px solid var(--border)}
.clan-carousel-name{font-family:'Cinzel',serif;font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}
.clan-carousel-meta{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.06em}
.clan-carousel-risk{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;margin-top:6px}

/* Enforcement highlight */
.enforce-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:0 0 36px}
.enforce-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;transition:all .2s}
.enforce-card:hover{border-color:var(--green);box-shadow:0 0 20px rgba(44,255,171,0.12)}
.enforce-icon{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.enforce-icon-fb{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:18px;font-weight:900;color:var(--green);background:rgba(44,255,171,0.08);border:1px solid rgba(44,255,171,0.2)}
.enforce-info{flex:1;min-width:0}
.enforce-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.enforce-count{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--green);margin-top:2px}

/* Counter animation */
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.count-animated{animation:countUp .5s ease both}

@media(max-width:640px){
  .home-stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .home-stat-val{font-size:28px}
  .clan-carousel-item{flex:0 0 160px;padding:14px 10px}
  .clan-carousel-icon,.clan-carousel-fallback{width:44px;height:44px}
  .enforce-row{grid-template-columns:1fr}
}

/* ═══ Chat ═══ */
.chat-layout{display:flex;height:calc(100vh - 60px);overflow:hidden}
.chat-sidebar{width:240px;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0}
.chat-sidebar-header{padding:16px;font-family:'Cinzel',serif;font-size:14px;font-weight:700;color:var(--cyan);border-bottom:1px solid var(--border);letter-spacing:.05em}
.chat-channel-btn{display:block;width:100%;text-align:left;padding:8px 16px;font-size:13px;color:var(--text-2);background:none;border:none;cursor:pointer;font-family:'JetBrains Mono',monospace;transition:background .15s}
.chat-channel-btn:hover{background:rgba(0,224,255,.06);color:var(--text)}
.chat-channel-btn.active{background:rgba(0,224,255,.1);color:var(--cyan);font-weight:600}
.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}
.chat-header{padding:12px 16px;border-bottom:1px solid var(--border);font-family:'Cinzel',serif;font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.chat-sidebar-toggle{display:none;background:none;border:none;color:var(--text);font-size:20px;cursor:pointer;padding:0}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column}
.chat-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}
.chat-input{flex:1;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:8px 12px;color:var(--text);font-size:14px;outline:none}
.chat-input:focus{border-color:var(--cyan)}
.chat-msg{display:flex;gap:10px;padding:6px 0}
.chat-msg-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.chat-msg-body{min-width:0;flex:1}
.chat-msg-header{display:flex;align-items:baseline;gap:8px}
.chat-msg-name{font-weight:600;font-size:13px;color:var(--text)}
.chat-msg-time{font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.chat-msg-text{font-size:14px;color:var(--text-2);line-height:1.5;word-break:break-word;margin-top:2px}
.chat-msg-delete{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:0 4px;opacity:0;transition:opacity .15s}
.chat-msg:hover .chat-msg-delete{opacity:1}
.chat-msg-delete:hover{color:var(--red)}
.chat-system-msg{text-align:center;color:var(--muted);font-size:12px;padding:8px 0;font-family:'JetBrains Mono',monospace}
.chat-raid-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;margin:8px 0}
.chat-raid-title{font-family:'Cinzel',serif;font-size:14px;font-weight:700;color:var(--cyan);margin-bottom:6px}
.chat-raid-msg{color:var(--text-2);font-size:14px;line-height:1.5}
.chat-raid-status{display:inline-block;font-size:10px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:3px;margin-top:8px;letter-spacing:.08em}
.chat-raid-open{background:rgba(0,224,255,.1);color:var(--cyan);border:1px solid rgba(0,224,255,.3)}
.chat-raid-accepted{background:rgba(80,200,120,.1);color:var(--green);border:1px solid rgba(80,200,120,.3)}
.chat-raid-expired{background:rgba(200,200,200,.1);color:var(--muted);border:1px solid rgba(200,200,200,.2)}
.nav-member-badge{display:flex;align-items:center;gap:4px;text-decoration:none;padding:4px 8px;border-radius:var(--r);border:1px solid var(--border);transition:border-color .15s}
.nav-member-badge:hover{border-color:var(--cyan)}
/* Member nav dropdown */
.nav-member-wrap{position:relative}
.nav-member-badge{cursor:pointer;background:none}
.nav-member-dropdown{display:none;position:absolute;top:100%;right:0;min-width:140px;padding:6px 0;margin-top:6px;background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r);box-shadow:0 8px 30px rgba(0,0,0,0.5);z-index:200}
.nav-member-wrap.open .nav-member-dropdown{display:block}
.nav-member-dropdown a,.nav-member-dropdown button{display:block;width:100%;text-align:left;padding:8px 14px;font-size:13px;color:var(--text-2);background:none;border:none;cursor:pointer;text-decoration:none;font-family:inherit}
.nav-member-dropdown a:hover,.nav-member-dropdown button:hover{background:rgba(0,224,255,.06);color:var(--text)}
.nav-member-sep{height:1px;margin:4px 10px;background:var(--border)}
.nav-member-danger{color:var(--red) !important}
.nav-member-danger:hover{background:rgba(255,60,60,.08) !important;color:var(--red) !important}
/* Role badges */
.chat-role-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.06em;vertical-align:middle;line-height:16px;border:1px solid;display:inline-flex;align-items:center;gap:3px}
.chat-badge-icon{width:14px;height:14px;object-fit:contain;vertical-align:middle;border-radius:2px;flex-shrink:0}
/* Edited indicator */
.chat-msg-edited{font-size:10px;color:var(--muted);margin-left:4px;font-style:italic}
/* Edit input inline */
.chat-msg-edit-input{width:100%;background:var(--card);border:1px solid var(--cyan);border-radius:var(--r);padding:4px 8px;color:var(--text);font-size:14px;font-family:inherit;outline:none;margin-top:2px}
.chat-msg-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s;margin-left:auto}
.chat-msg:hover .chat-msg-actions{opacity:1}
.chat-msg-action-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 4px;transition:color .15s}
.chat-msg-action-btn:hover{color:var(--text)}
.chat-msg-action-btn.action-delete:hover{color:var(--red)}
/* Profile popup */
.chat-disconnect-banner{text-align:center;padding:8px 16px;margin:8px 0;background:rgba(255,60,60,.1);border:1px solid rgba(255,60,60,.25);border-radius:var(--r);color:var(--red);font-size:13px}
.profile-popup-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease;backdrop-filter:blur(4px)}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
.profile-popup{background:var(--panel);border:1px solid var(--border-hi);border-radius:var(--r-lg);width:340px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,0.7),0 0 30px rgba(0,224,255,0.06);overflow:hidden;animation:popup-slide .2s ease}
@keyframes popup-slide{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
.profile-popup-banner{height:70px;background:linear-gradient(135deg,rgba(0,224,255,.15),rgba(157,77,255,.12))}
.profile-popup-avatar{width:72px;height:72px;border-radius:50%;border:4px solid var(--panel);object-fit:cover;margin:-36px auto 0;display:block;position:relative;z-index:1;box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.profile-popup-body{padding:6px 22px 22px;text-align:center}
.profile-popup-name{font-weight:700;font-size:17px;color:var(--text);margin-top:6px}
.profile-popup-handle{font-size:12px;color:var(--muted);margin-bottom:10px;font-family:'JetBrains Mono',monospace}
.profile-popup-roles{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:12px}
.profile-popup-stat{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);padding:6px 0;border-top:1px solid var(--border)}
.profile-popup-stat-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.profile-popup-close{position:absolute;top:8px;right:12px;background:none;border:none;color:rgba(255,255,255,.5);font-size:20px;cursor:pointer;z-index:2;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s}
.profile-popup-close:hover{background:rgba(255,255,255,.1);color:var(--text)}
.profile-popup-bio{font-size:13px;color:var(--text-2);line-height:1.5;padding:10px 0;border-top:1px solid var(--border);margin-top:6px;text-align:left;word-break:break-word}
@media(max-width:768px){
  .chat-sidebar{position:fixed;left:-260px;top:60px;bottom:0;z-index:50;transition:left .2s;width:240px}
  .chat-sidebar.open{left:0}
  .chat-sidebar-toggle{display:block}
}
