@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;900&family=Share+Tech+Mono&family=Rajdhani:wght@400;500;600;700&display=swap');

/* ═══ VARIABLES ═══ */
:root{
  --o:#E8730A;--o2:#FF9A2E;--r:#C0392B;
  --d:#0A0C0E;--d2:#0F1215;--d3:#141820;
  --p:#161C22;--p2:#1C242C;--p3:#1E2830;
  --b:#2A3540;--b2:#344050;
  --t:#C8D4DC;--t2:#8A9AA8;--t3:#556070;
  --w:#EEF4F8;--g:#2ECC71;--y:#F39C12;--c:#00B4CC;
  --glow:0 0 20px rgba(232,115,10,.3);
}

/* ═══ BASE ═══ */
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;overflow:hidden;}
body{
  background: var(--d);
  background-image: url('/bg.jpg');
  background-size: cover;
  background-position: center top;
  background-attachment: fixed;
  color:var(--t);
  font-family:'Rajdhani',sans-serif;
}
/* Dunkles Overlay damit Text lesbar bleibt */
body::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background: linear-gradient(
    135deg,
    rgba(8,10,12,0.82) 0%,
    rgba(10,12,14,0.75) 50%,
    rgba(8,10,12,0.85) 100%
  );
}
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 4px);}
/* Alle App-Inhalte über dem Overlay */
#auth,#app{position:relative;z-index:1;}

/* ═══ AUTH ═══ */
#auth{position:fixed;inset:0;z-index:600;display:flex;align-items:center;justify-content:center;
  background: transparent;}
.abox{background:rgba(22,28,34,0.92);border:1px solid var(--b2);width:430px;max-width:96vw;position:relative;
  box-shadow:0 0 80px rgba(232,115,10,.18),0 0 0 1px rgba(232,115,10,.08);animation:fu .35s ease;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
@keyframes fu{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.alo{padding:28px 26px 18px;text-align:center;border-bottom:1px solid var(--b);}
.alm{font-family:'Barlow Condensed',sans-serif;font-size:42px;font-weight:900;letter-spacing:6px;
  color:var(--o);text-shadow:0 0 28px rgba(232,115,10,.5);}
.alm span{color:var(--w);}
.als{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);letter-spacing:3px;margin-top:5px;}
#sbar{display:flex;align-items:center;gap:8px;padding:9px 22px;border-bottom:1px solid var(--b);transition:all .4s;}
#sdot{width:8px;height:8px;border-radius:50%;background:var(--r);flex-shrink:0;transition:all .4s;}
#stxt{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--r);flex:1;letter-spacing:.5px;}
#sretry{background:none;border:1px solid rgba(232,115,10,.3);color:var(--o);
  font-family:'Share Tech Mono',monospace;font-size:9px;padding:3px 7px;cursor:pointer;}
.atabs{display:flex;border-bottom:1px solid var(--b);}
.atab{flex:1;padding:12px;text-align:center;cursor:pointer;font-family:'Barlow Condensed',sans-serif;
  font-size:14px;font-weight:700;letter-spacing:2px;color:var(--t3);border-bottom:2px solid transparent;transition:all .2s;}
.atab.on{color:var(--o);border-bottom-color:var(--o);background:rgba(232,115,10,.05);}
.aform{padding:20px 24px;}
.aform.hide{display:none;}
.aerr{display:none;background:rgba(192,57,43,.1);border:1px solid rgba(192,57,43,.3);
  padding:9px 12px;font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--r);margin-bottom:12px;}
.aerr.on{display:block;}

/* ═══ FORMS ═══ */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:11px;}
.fl{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;}
.fi{background:var(--d3);border:1px solid var(--b2);color:var(--t);font-family:'Rajdhani',sans-serif;
  font-size:15px;padding:10px 12px;outline:none;transition:border-color .2s;width:100%;}
.fi:focus{border-color:var(--o);box-shadow:0 0 0 2px rgba(232,115,10,.1);}
.fi::placeholder{color:var(--t3);}
select.fi{cursor:pointer;}
textarea.fi{resize:vertical;min-height:80px;}

/* ═══ BUTTONS ═══ */
.btn{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;cursor:pointer;padding:9px 18px;border:none;transition:all .2s;
  display:inline-flex;align-items:center;gap:6px;user-select:none;}
.btn-o{background:var(--o);color:#000;clip-path:polygon(7px 0%,100% 0%,calc(100% - 7px) 100%,0% 100%);}
.btn-o:hover{background:var(--o2);box-shadow:var(--glow);}
.btn-o:disabled{background:#555;cursor:not-allowed;box-shadow:none;}
.btn-g{background:transparent;color:var(--t2);border:1px solid var(--b2);
  clip-path:polygon(5px 0%,100% 0%,calc(100% - 5px) 100%,0% 100%);}
.btn-g:hover{border-color:var(--o);color:var(--o);}
.btn-r{background:var(--r);color:#fff;clip-path:polygon(5px 0%,100% 0%,calc(100% - 5px) 100%,0% 100%);}
.btn-r:hover{background:#e74c3c;}
.btn-sm{padding:5px 11px;font-size:11px;}
.btn-full{width:100%;justify-content:center;}

/* ═══ APP LAYOUT ═══ */
#app{display:none;height:100vh;flex-direction:row;}
#app.on{display:flex;}

/* TOPBAR */
#topbar{position:fixed;top:0;left:0;right:0;z-index:500;height:52px;
  background:linear-gradient(180deg,rgba(8,11,14,0.92),rgba(12,16,20,0.88));
  border-bottom:2px solid var(--o);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  box-shadow:0 2px 30px rgba(232,115,10,.25);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);}
.tb-logo{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;
  letter-spacing:3px;color:var(--o);text-shadow:0 0 20px rgba(232,115,10,.5);}
.tb-logo span{color:var(--w);}
.tb-div{width:1px;height:26px;background:var(--b2);}
.tb-sub{font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--t3);letter-spacing:1px;}
.tb-r{margin-left:auto;display:flex;align-items:center;gap:12px;}
#tb-clock{font-family:'Share Tech Mono',monospace;font-size:13px;color:var(--o2);letter-spacing:2px;}
.tb-user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;
  border:1px solid transparent;transition:border-color .2s;}
.tb-user:hover{border-color:var(--b2);}
#tb-mob{display:none;background:none;border:none;color:var(--o);font-size:20px;cursor:pointer;}

/* SIDEBAR */
#sidebar{position:fixed;left:0;top:52px;bottom:0;width:220px;
  background:rgba(12,16,20,0.88);
  border-right:1px solid rgba(42,53,64,0.6);
  display:flex;flex-direction:column;z-index:400;transition:transform .3s;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);}
.sb-sec{padding:8px 0;}
.sb-lbl{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);
  letter-spacing:2px;text-transform:uppercase;padding:7px 15px 3px;}
.ni{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:1px;
  color:var(--t3);text-transform:uppercase;border-left:3px solid transparent;
  transition:all .15s;margin:1px 0;user-select:none;}
.ni:hover{color:var(--t2);background:rgba(232,115,10,.08);border-left-color:rgba(232,115,10,.3);}
.ni.on{color:var(--o);background:rgba(232,115,10,.14);border-left-color:var(--o);}
.ni-ico{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.ni-badge{margin-left:auto;background:var(--o);color:#000;font-size:9px;font-weight:700;
  padding:1px 5px;border-radius:2px;font-family:'Share Tech Mono',monospace;}
.ni.adm{display:none;}
.ni.adm.on2{display:flex;}
.sb-ftr{padding:10px;border-top:1px solid rgba(42,53,64,0.5);margin-top:auto;}
.sb-usr{display:flex;align-items:center;gap:8px;background:rgba(20,24,32,0.7);border:1px solid var(--b);
  padding:8px;cursor:pointer;transition:border-color .2s;}
.sb-usr:hover{border-color:var(--o);}
.sb-un{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;
  color:var(--w);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sb-st{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);}

/* MAIN */
#main{margin-left:220px;padding-top:52px;min-height:100vh;overflow-y:auto;}
.page{display:none;padding:24px;animation:pi .25s ease;}
.page.on{display:block;}
@keyframes pi{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* PAGE HEADERS */
.ph{display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--b);}
.pt{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;
  letter-spacing:3px;color:var(--w);text-transform:uppercase;line-height:1;}
.pt span{color:var(--o);}
.ps{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);letter-spacing:1px;margin-top:3px;}
.pa{display:flex;gap:7px;flex-wrap:wrap;align-self:center;}

/* PANELS */
.panel{background:rgba(22,28,34,0.82);border:1px solid rgba(42,53,64,0.7);margin-bottom:16px;position:relative;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--o),transparent);}
.ph2{padding:11px 16px;border-bottom:1px solid var(--b);display:flex;align-items:center;
  justify-content:space-between;background:rgba(255,255,255,.02);}
.pt2{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px;
  color:var(--t);text-transform:uppercase;display:flex;align-items:center;gap:6px;}
.pt2::before{content:'◈';color:var(--o);font-size:11px;}
.pb{padding:16px;}

/* BADGES */
.badge{font-family:'Share Tech Mono',monospace;font-size:9px;font-weight:700;padding:2px 6px;letter-spacing:1px;}
.bL{background:rgba(232,115,10,.2);color:var(--o);border:1px solid rgba(232,115,10,.4);}
.bO{background:rgba(243,156,18,.2);color:var(--y);border:1px solid rgba(243,156,18,.4);}
.bVt{background:rgba(46,204,113,.2);color:var(--g);border:1px solid rgba(46,204,113,.4);}
.bM{background:rgba(200,212,220,.1);color:var(--t);border:1px solid var(--b2);}
.bR{background:rgba(85,96,112,.2);color:var(--t3);border:1px solid var(--b);}
.bAd{background:rgba(232,115,10,.3);color:var(--o2);border:1px solid rgba(232,115,10,.5);}
.bPl{background:rgba(0,180,204,.15);color:var(--c);border:1px solid rgba(0,180,204,.3);}
.nb{font-family:'Share Tech Mono',monospace;font-size:10px;font-weight:700;padding:2px 7px;letter-spacing:1px;}
.bI{background:rgba(232,115,10,.2);color:var(--o);border:1px solid rgba(232,115,10,.3);}
.bA{background:rgba(192,57,43,.2);color:var(--r);border:1px solid rgba(192,57,43,.3);}
.bU{background:rgba(0,180,204,.2);color:var(--c);border:1px solid rgba(0,180,204,.3);}
.bE{background:rgba(46,204,113,.2);color:var(--g);border:1px solid rgba(46,204,113,.3);}

/* TABLE */
.mt{width:100%;border-collapse:collapse;}
.mt th{background:var(--d3);padding:8px 11px;text-align:left;font-family:'Share Tech Mono',monospace;
  font-size:10px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;border-bottom:1px solid var(--b2);}
.mt td{padding:9px 11px;border-bottom:1px solid var(--b);font-size:13px;color:var(--t2);}
.mt tr:hover td{background:rgba(232,115,10,.03);}

/* UPLOAD ZONE */
.uzone{border:2px dashed var(--b2);padding:24px 14px;text-align:center;cursor:pointer;
  transition:all .3s;position:relative;background:var(--d3);}
.uzone:hover{border-color:var(--o);background:rgba(232,115,10,.04);}
.uzone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}

/* EMPTY STATE */
.empty{padding:32px 14px;text-align:center;border:1px dashed var(--b);background:var(--d3);}
.eico{font-size:28px;margin-bottom:7px;opacity:.5;}
.etxt{font-family:'Barlow Condensed',sans-serif;font-size:14px;letter-spacing:2px;
  color:var(--t3);text-transform:uppercase;}

/* DIVIDER */
.dvh{border:none;border-top:1px solid var(--b);margin:14px 0;}

/* WIDGETS */
.wr{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.widget{background:var(--p);border:1px solid var(--b);padding:18px;position:relative;overflow:hidden;}
.widget::after{content:'';position:absolute;bottom:-18px;right:-18px;width:70px;height:70px;
  border-radius:50%;background:radial-gradient(circle,rgba(232,115,10,.08),transparent 70%);}
.wico{font-size:24px;margin-bottom:7px;}
.wval{font-family:'Barlow Condensed',sans-serif;font-size:38px;font-weight:900;color:var(--o);line-height:1;}
.wlbl{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);letter-spacing:2px;margin-top:3px;}

/* PROFILE HERO */
.phero{background:linear-gradient(135deg,var(--d3),var(--p2));border:1px solid var(--b);
  padding:22px;display:flex;gap:18px;align-items:flex-start;margin-bottom:18px;position:relative;overflow:hidden;}
.phero::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--o),transparent);}
.av-wr{position:relative;flex-shrink:0;}
.pav{width:84px;height:84px;border-radius:50%;object-fit:cover;border:3px solid var(--o);
  box-shadow:0 0 20px rgba(232,115,10,.3);}
.pav-ph{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--o),var(--o2));
  display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;
  font-size:34px;font-weight:900;color:#000;border:3px solid var(--o2);}
.av-ed{position:absolute;bottom:0;right:0;width:24px;height:24px;border-radius:50%;background:var(--o);
  border:2px solid var(--d);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;}
.av-ed:hover{background:var(--o2);}

/* MEMBERS GRID */
.mg{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:11px;}
.mc{background:var(--p2);border:1px solid var(--b);padding:14px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;}
.mc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--o),transparent);}
.mc:hover{border-color:var(--b2);transform:translateY(-2px);}
.mc-top{display:flex;align-items:center;gap:9px;margin-bottom:9px;}
.mc-nm{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--w);}
.mc-tag{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--o);margin-top:2px;}
.mc-bio{font-size:12px;color:var(--t3);margin-top:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mc-meta{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap;}

/* GALLERY */
.gg{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:9px;}
.gi{position:relative;overflow:hidden;background:var(--d3);border:1px solid var(--b);
  cursor:pointer;transition:transform .2s,border-color .2s;aspect-ratio:16/10;}
.gi:hover{transform:translateY(-2px);border-color:var(--o);box-shadow:var(--glow);}
.gi img{width:100%;height:100%;object-fit:cover;}
.gi-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent 50%);
  opacity:0;transition:opacity .2s;display:flex;flex-direction:column;justify-content:flex-end;padding:7px;}
.gi:hover .gi-ov{opacity:1;}

/* FORUM */
.forum-cats{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.forum-cat{background:var(--p);border:1px solid var(--b);padding:16px 18px;cursor:pointer;
  position:relative;overflow:hidden;transition:border-color .2s,transform .2s;}
.forum-cat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--o),transparent);}
.forum-cat:hover{border-color:var(--b2);transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.3);}
.fc-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.fc-ico{font-size:24px;}
.fc-nm{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;letter-spacing:1px;color:var(--w);}
.fc-desc{font-size:13px;color:var(--t3);line-height:1.4;margin-bottom:10px;}
.fc-meta{display:flex;gap:14px;}
.fc-stat{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);display:flex;align-items:center;gap:4px;}
.fc-stat span{color:var(--t2);}
.fc-last{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);margin-top:6px;}
.post-item{background:var(--p2);border:1px solid var(--b);padding:14px 16px;margin-bottom:8px;
  cursor:pointer;transition:border-color .2s,background .2s;position:relative;}
.post-item:hover{border-color:var(--b2);background:var(--p3);}
.post-item.pinned::before{content:'📌';position:absolute;top:10px;right:12px;font-size:14px;}
.pi-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;}
.pi-av{flex-shrink:0;}
.pi-meta{flex:1;min-width:0;}
.pi-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;
  letter-spacing:.5px;color:var(--w);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pi-author{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);}
.pi-preview{font-size:13px;color:var(--t3);line-height:1.4;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.pi-footer{display:flex;align-items:center;gap:14px;margin-top:8px;flex-wrap:wrap;}
.pi-stat{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);display:flex;align-items:center;gap:4px;}
.post-box{background:var(--p);border:1px solid var(--b);margin-bottom:12px;position:relative;overflow:hidden;}
.post-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--o),transparent);}
.pb-hdr{padding:14px 16px;border-bottom:1px solid var(--b);display:flex;align-items:flex-start;gap:12px;}
.pb-av{flex-shrink:0;}
.pb-info{flex:1;}
.pb-author{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:.5px;color:var(--w);}
.pb-meta{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);margin-top:2px;}
.pb-body{padding:14px 16px;}
.pb-title{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;letter-spacing:1px;color:var(--w);margin-bottom:10px;}
.pb-content{font-size:15px;color:var(--t);line-height:1.7;white-space:pre-wrap;word-break:break-word;}
.pb-img{max-width:100%;max-height:400px;margin-top:12px;border:1px solid var(--b);cursor:pointer;display:block;}
.pb-img:hover{opacity:.9;}
.pb-footer{padding:10px 16px;border-top:1px solid var(--b);display:flex;align-items:center;gap:10px;}
.like-btn{background:none;border:1px solid var(--b2);color:var(--t3);cursor:pointer;padding:5px 12px;
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:1px;
  display:flex;align-items:center;gap:5px;transition:all .2s;}
.like-btn:hover{border-color:var(--o);color:var(--o);}
.like-btn.liked{background:rgba(232,115,10,.15);border-color:var(--o);color:var(--o);}
.reply-box{background:var(--d3);border:1px solid var(--b);margin-bottom:8px;position:relative;overflow:hidden;}
.reply-box::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--o);}
.rb-hdr{padding:10px 14px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:10px;}
.rb-body{padding:12px 14px;}
.rb-txt{font-size:14px;color:var(--t);line-height:1.6;white-space:pre-wrap;word-break:break-word;}
.rb-img{max-width:100%;max-height:300px;margin-top:8px;border:1px solid var(--b);cursor:pointer;display:block;}
.rb-footer{padding:7px 14px;border-top:1px solid var(--b);display:flex;align-items:center;gap:8px;}

/* VOICE SIDEBAR */
.voice-sidebar{width:260px;background:rgba(12,16,20,0.88);border-right:1px solid rgba(42,53,64,0.6);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  position:fixed;right:0;top:52px;bottom:0;display:flex;flex-direction:column;z-index:300;}
.vs-hdr{padding:13px 16px;border-bottom:1px solid var(--b);background:var(--d3);}
.vs-t{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:900;letter-spacing:2px;color:var(--w);text-transform:uppercase;}
.vs-s{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);margin-top:2px;}
#vroom-list{flex:1;overflow-y:auto;padding:6px;}
.vroom{background:var(--dark);border:1px solid var(--b);margin-bottom:6px;overflow:hidden;}
.vroom-hdr{padding:8px 12px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s;user-select:none;}
.vroom-hdr:hover{background:rgba(232,115,10,.06);}
.vroom-hdr.in-room{background:rgba(232,115,10,.12);}
.vr-ico{font-size:16px;flex-shrink:0;}
.vr-nm{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;color:var(--t2);flex:1;}
.vr-nm.in{color:var(--o);}
.vr-cnt{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);}
.vroom-pw{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--y);padding-left:12px;padding-bottom:4px;}
.vroom-users{padding:0 8px 6px 28px;}
.vu{display:flex;align-items:center;gap:6px;padding:4px 6px;font-family:'Rajdhani',sans-serif;font-size:13px;color:var(--t2);}
.vu.me{color:var(--o);}
.vu-muted{color:var(--r);font-size:11px;}
.vs-ctrl{padding:10px;border-top:1px solid var(--b);background:var(--d3);}
.vs-ctrl-btns{display:flex;gap:6px;margin-bottom:8px;}
.vc-btn{flex:1;padding:8px;background:var(--d);border:1px solid var(--b2);color:var(--t2);
  cursor:pointer;font-size:18px;text-align:center;transition:all .2s;border-radius:3px;}
.vc-btn:hover{border-color:var(--o);color:var(--o);}
.vc-btn.active{background:rgba(192,57,43,.2);border-color:var(--r);color:var(--r);}
.vs-status{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);text-align:center;}

/* NEWS */
.ni2{background:var(--d3);border:1px solid var(--b);padding:13px 16px;position:relative;overflow:hidden;margin-bottom:10px;}
.ni2::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--o);}
.ni2.ALERT::before{background:var(--r);}
.ni2.UPDATE::before{background:var(--c);}
.ni2.EVENT::before{background:var(--g);}

/* ADMIN */
.asec{margin-bottom:22px;}
.asect{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;
  color:var(--o);text-transform:uppercase;margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--b);}

/* TOURNAMENT */
.br{display:flex;flex-direction:column;justify-content:space-around;min-width:165px;}
.br-lbl{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--o);letter-spacing:2px;
  text-transform:uppercase;text-align:center;margin-bottom:12px;padding:5px 0;border-bottom:1px solid var(--b);}
.mw{display:flex;align-items:center;position:relative;padding:0 12px;flex:1;}
.mb{background:var(--p2);border:1px solid var(--b2);width:148px;position:relative;flex-shrink:0;}
.mn{position:absolute;top:-8px;left:7px;font-family:'Share Tech Mono',monospace;font-size:9px;
  color:var(--t3);background:var(--p2);padding:0 3px;}

/* CALENDAR */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:16px;}
.cal-day-name{text-align:center;font-family:'Share Tech Mono',monospace;font-size:10px;
  color:var(--t3);letter-spacing:1px;padding:6px 0;text-transform:uppercase;}
.cal-cell{min-height:88px;background:var(--p);border:1px solid var(--b);padding:5px;
  position:relative;transition:border-color .15s;}
.cal-cell:hover{border-color:var(--b2);}
.cal-cell.today{border-color:var(--o);background:rgba(232,115,10,.06);}
.cal-cell.today .cal-dn{color:var(--o);font-weight:700;}
.cal-cell.other-month{background:var(--d3);opacity:.5;}
.cal-cell.past{opacity:.7;}
.cal-dn{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;color:var(--t2);margin-bottom:3px;}
.cal-ev{font-size:10px;font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.3px;
  padding:2px 5px;margin-bottom:2px;cursor:pointer;border-radius:2px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;transition:opacity .15s;}
.cal-ev:hover{opacity:.8;}
.cal-ev.RAID    {background:rgba(192,57,43,.25);color:#e8816e;border-left:2px solid var(--r);}
.cal-ev.PVP     {background:rgba(243,156,18,.2);color:#f5c26b;border-left:2px solid var(--y);}
.cal-ev.TURNIER {background:rgba(232,115,10,.25);color:var(--o2);border-left:2px solid var(--o);}
.cal-ev.TRAINING{background:rgba(0,180,204,.18);color:#5fcfdf;border-left:2px solid var(--c);}
.cal-ev.MEETING {background:rgba(46,204,113,.18);color:#6de09f;border-left:2px solid var(--g);}
.cal-ev.EVENT   {background:rgba(157,77,220,.2);color:#c99ef5;border-left:2px solid #9B59B6;}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-month{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;
  letter-spacing:2px;color:var(--w);text-transform:uppercase;}
.cal-year{font-family:'Share Tech Mono',monospace;font-size:12px;color:var(--o);margin-left:8px;}
.ev-list{display:flex;flex-direction:column;gap:8px;}
.ev-item{background:var(--p2);border:1px solid var(--b);padding:14px 16px;
  position:relative;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s;}
.ev-item:hover{border-color:var(--b2);transform:translateY(-1px);}
.ev-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;}
.ev-item.RAID::before{background:var(--r);}
.ev-item.PVP::before{background:var(--y);}
.ev-item.TURNIER::before{background:var(--o);}
.ev-item.TRAINING::before{background:var(--c);}
.ev-item.MEETING::before{background:var(--g);}
.ev-item.EVENT::before{background:#9B59B6;}
.ev-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;color:var(--w);margin-bottom:4px;}
.ev-meta{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);display:flex;gap:12px;flex-wrap:wrap;}
.ev-rsvp{display:flex;gap:6px;margin-top:10px;}
.rsvp-btn{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;
  padding:5px 12px;cursor:pointer;border:1px solid var(--b2);background:transparent;
  color:var(--t3);text-transform:uppercase;transition:all .2s;}
.rsvp-btn:hover{border-color:var(--o);color:var(--o);}
.rsvp-btn.going.active{background:rgba(46,204,113,.2);border-color:var(--g);color:var(--g);}
.rsvp-btn.maybe.active{background:rgba(243,156,18,.2);border-color:var(--y);color:var(--y);}
.rsvp-btn.no.active{background:rgba(192,57,43,.2);border-color:var(--r);color:var(--r);}
.ev-countdown{font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--o);
  background:rgba(232,115,10,.1);border:1px solid rgba(232,115,10,.2);padding:4px 10px;margin-top:8px;display:inline-block;}

/* LIGHTBOX */
#lb{display:none;position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.92);align-items:center;justify-content:center;}
#lb.on{display:flex;}
#lb img{max-width:90vw;max-height:90vh;object-fit:contain;border:1px solid var(--b2);}
#lb-x{position:absolute;top:16px;right:16px;font-size:24px;color:var(--o);cursor:pointer;background:none;border:none;}
#lb-c{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  font-family:'Barlow Condensed',sans-serif;font-size:14px;color:var(--t2);}

/* MODAL */
.mo{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.75);align-items:center;justify-content:center;}
.mo.on{display:flex;}
.mbox{background:var(--p);border:1px solid var(--b2);width:460px;max-width:96vw;position:relative;
  box-shadow:0 0 60px rgba(0,0,0,.6);max-height:90vh;overflow-y:auto;}
.mbox::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--o),transparent);}
.mhd{padding:14px 16px;border-bottom:1px solid var(--b);display:flex;justify-content:space-between;
  align-items:center;position:sticky;top:0;background:var(--p);z-index:1;}
.mttl{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;
  letter-spacing:2px;color:var(--w);text-transform:uppercase;}
.mclose{background:none;border:none;color:var(--t3);font-size:18px;cursor:pointer;}
.mclose:hover{color:var(--o);}
.mbdy{padding:15px;}
.mftr{padding:11px 15px;border-top:1px solid var(--b);display:flex;justify-content:flex-end;gap:7px;}

/* TOAST */
#tc{position:fixed;bottom:16px;right:16px;z-index:999;display:flex;flex-direction:column;gap:5px;}
.toast{background:var(--p2);border:1px solid var(--b2);border-left:3px solid var(--o);
  padding:9px 13px;font-family:'Barlow Condensed',sans-serif;font-size:13px;
  letter-spacing:1px;color:var(--t);min-width:200px;animation:sli .3s ease;}
.toast.ok{border-left-color:var(--g);}
.toast.err{border-left-color:var(--r);}
@keyframes sli{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slo{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}

/* MOBILE */
#sb-ov{display:none;position:fixed;inset:0;z-index:350;background:rgba(0,0,0,.6);}
#sb-ov.on{display:block;}
@media(max-width:1100px){
  .voice-sidebar{
    display:flex;
    position:fixed;
    right:0; top:52px; bottom:0;
    z-index:450;
    transform:translateX(100%);
    transition:transform .3s;
    width:280px;
    flex-direction:column;
    border-left:1px solid rgba(42,53,64,0.6);
    border-right:none;
  }
  .voice-sidebar.on{transform:translateX(0);}
  #btn-voice-mobile{display:flex!important;}
  #main{margin-right:0;}
}
@media(max-width:768px){
  #sidebar{transform:translateX(-100%);}
  #sidebar.on{transform:translateX(0);}
  #main{margin-left:0;}
  #tb-mob{display:flex!important;}
  .tb-sub{display:none;}
  .wr{grid-template-columns:1fr 1fr!important;}
  .forum-cats{grid-template-columns:1fr!important;}
  .page{padding:14px!important;}
  .mg{grid-template-columns:1fr!important;}
  .cal-grid{grid-template-columns:repeat(7,1fr);}
  .cal-cell{min-height:60px;}
}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:var(--d);}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
::-webkit-scrollbar-thumb:hover{background:var(--o);}

/* ═══ FEATURE MANAGER ═══ */
.fm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:20px;}
.fm-card{background:var(--p2);border:1px solid var(--b);padding:13px 15px;display:flex;align-items:center;gap:11px;transition:border-color .2s;}
.fm-card.on{border-left:3px solid var(--g);}
.fm-card.off{border-left:3px solid var(--r);opacity:.7;}
.fm-ico{font-size:20px;flex-shrink:0;}
.fm-info{flex:1;min-width:0;}
.fm-name{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--w);}
.fm-desc{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);margin-top:1px;}
.toggle{position:relative;width:40px;height:22px;flex-shrink:0;}
.toggle input{opacity:0;width:0;height:0;}
.toggle-sl{position:absolute;inset:0;background:var(--b2);cursor:pointer;border-radius:22px;transition:background .3s;}
.toggle-sl::before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .3s;}
.toggle input:checked+.toggle-sl{background:var(--g);}
.toggle input:checked+.toggle-sl::before{transform:translateX(18px);}

/* ═══ DIREKTNACHRICHTEN ═══ */
.dm-list{max-height:400px;overflow-y:auto;}
.dm-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--b);transition:background .15s;}
.dm-item:hover,.dm-item.on{background:rgba(232,115,10,.08);}
.dm-un{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--w);}
.dm-preview{font-size:12px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dm-badge{background:var(--o);color:#000;font-size:9px;font-weight:700;padding:1px 5px;border-radius:9px;font-family:'Share Tech Mono',monospace;flex-shrink:0;}
.dm-chat{display:flex;flex-direction:column;height:460px;}
.dm-msgs{flex:1;overflow-y:auto;padding:10px;}
.dm-msg{display:flex;gap:8px;margin-bottom:10px;}
.dm-msg.mine{flex-direction:row-reverse;}
.dm-bubble{max-width:70%;background:var(--p2);border:1px solid var(--b);padding:8px 11px;font-size:14px;color:var(--t);line-height:1.5;word-break:break-word;}
.dm-msg.mine .dm-bubble{background:rgba(232,115,10,.15);border-color:rgba(232,115,10,.3);}
.dm-inp{display:flex;gap:7px;padding:10px;border-top:1px solid var(--b);flex-shrink:0;}
.dm-inp input{flex:1;background:var(--d3);border:1px solid var(--b2);color:var(--t);font-family:'Rajdhani',sans-serif;font-size:14px;padding:8px 11px;outline:none;}
.dm-inp input:focus{border-color:var(--o);}

/* ═══ BENACHRICHTIGUNGEN ═══ */
.nb-bell{position:relative;cursor:pointer;padding:4px 8px;}
.nb-dot{position:absolute;top:0;right:0;width:8px;height:8px;border-radius:50%;background:var(--r);border:2px solid var(--d3);display:none;}
.nb-dot.on{display:block;}
.notif-drop{position:absolute;top:52px;right:16px;width:320px;background:var(--p);border:1px solid var(--b2);box-shadow:0 8px 30px rgba(0,0,0,.5);z-index:600;display:none;max-height:400px;overflow-y:auto;}
.notif-drop.on{display:block;}
.notif-drop::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--o),transparent);}
.notif-hdr{padding:10px 14px;border-bottom:1px solid var(--b);display:flex;justify-content:space-between;align-items:center;}
.notif-item{padding:10px 14px;border-bottom:1px solid var(--b);transition:background .15s;cursor:pointer;}
.notif-item:hover{background:rgba(232,115,10,.06);}
.notif-item.unread{background:rgba(232,115,10,.04);}
.notif-type{font-size:14px;margin-right:6px;}
.notif-title{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--w);}
.notif-body{font-size:12px;color:var(--t3);margin-top:2px;}
.notif-time{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);margin-top:3px;}

/* ═══ POLLS ═══ */
.poll-item{background:var(--p2);border:1px solid var(--b);padding:15px 17px;margin-bottom:10px;position:relative;overflow:hidden;}
.poll-item::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--o),transparent);}
.poll-q{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--w);margin-bottom:12px;}
.poll-opt{display:flex;align-items:center;gap:9px;padding:8px 10px;margin-bottom:6px;cursor:pointer;border:1px solid var(--b);background:var(--d3);position:relative;overflow:hidden;transition:border-color .2s;}
.poll-opt:hover{border-color:var(--b2);}
.poll-opt.voted{border-color:var(--o);}
.poll-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(232,115,10,.12);transition:width .5s ease;}
.poll-opt-text{position:relative;flex:1;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;color:var(--w);}
.poll-pct{position:relative;font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);flex-shrink:0;}

/* ═══ KASSE ═══ */
.kasse-balance{font-family:'Barlow Condensed',sans-serif;font-size:42px;font-weight:900;color:var(--o);}
.kasse-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--b);}
.kasse-in{color:var(--g);}
.kasse-out{color:var(--r);}

/* ═══ WIKI ═══ */
.wiki-content{font-size:15px;color:var(--t);line-height:1.8;white-space:pre-wrap;word-break:break-word;}
.wiki-content h1{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;color:var(--w);letter-spacing:2px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--b);}
.wiki-content h2{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;color:var(--o);margin:16px 0 8px;}
.wiki-content h3{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--t);margin:12px 0 6px;}

/* ═══ ACHIEVEMENTS ═══ */
.ach-grid{display:flex;flex-wrap:wrap;gap:8px;}
.ach-badge{display:inline-flex;align-items:center;gap:6px;background:var(--d3);border:1px solid var(--b2);padding:6px 12px;position:relative;}
.ach-icon{font-size:18px;}
.ach-name{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;}
.ach-locked{opacity:.3;filter:grayscale(1);}

/* ═══ SQUAD FINDER ═══ */
.squad-item{background:var(--p2);border:1px solid var(--b);padding:13px 15px;margin-bottom:8px;display:flex;align-items:center;gap:12px;transition:border-color .2s;}
.squad-item:hover{border-color:var(--b2);}

/* ═══ STATS TRACKER ═══ */
.stat-bar-wrap{background:var(--d);height:6px;overflow:hidden;flex:1;}
.stat-bar{height:100%;background:linear-gradient(90deg,var(--o),var(--o2));transition:width .6s ease;}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:900;color:var(--o);}

/* ═══ WARN SYSTEM ═══ */
.warn-sev-low   {background:rgba(243,156,18,.15);color:var(--y);border:1px solid rgba(243,156,18,.3);}
.warn-sev-mid   {background:rgba(232,115,10,.15);color:var(--o);border:1px solid rgba(232,115,10,.3);}
.warn-sev-high  {background:rgba(192,57,43,.2);color:var(--r);border:1px solid rgba(192,57,43,.4);}

/* ═══ DROPDOWN NAVIGATION ═══ */
#sb-nav{flex:1;overflow-y:auto;padding:6px 0;}

/* Group wrapper */
.dd-group{margin:2px 0;}
.dd-group.adm{display:none;}
.dd-group.adm.on2{display:block;}

/* Group header (clickable) */
.dd-head{
  display:flex;align-items:center;gap:9px;
  padding:9px 14px;cursor:pointer;user-select:none;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:var(--t2);
  border-left:3px solid transparent;transition:all .15s;position:relative;
}
.dd-head:hover{color:var(--w);background:rgba(232,115,10,.07);border-left-color:rgba(232,115,10,.3);}
.dd-head.open{color:var(--o);background:rgba(232,115,10,.1);border-left-color:var(--o);}
.dd-head.active-group{color:var(--o);}

/* Direct link (Dashboard) */
.dd-direct{cursor:pointer;}
.dd-direct.on{color:var(--o);background:rgba(232,115,10,.12);border-left-color:var(--o);}

/* Arrow */
.dd-arrow{
  margin-left:auto;font-size:16px;line-height:1;
  transition:transform .25s;color:var(--t3);flex-shrink:0;
}
.dd-head.open .dd-arrow{transform:rotate(90deg);color:var(--o);}

/* Icons */
.dd-ico{font-size:16px;width:20px;text-align:center;flex-shrink:0;}

/* Dropdown body */
.dd-body{
  overflow:hidden;max-height:0;
  transition:max-height .28s cubic-bezier(.4,0,.2,1),opacity .2s;
  opacity:0;
}
.dd-body.open{max-height:400px;opacity:1;}

/* Dropdown items */
.dd-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 12px 7px 38px;cursor:pointer;
  font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:600;
  color:var(--t3);border-left:3px solid transparent;
  transition:all .13s;letter-spacing:.3px;
}
.dd-item:hover{color:var(--t2);background:rgba(255,255,255,.04);border-left-color:rgba(232,115,10,.2);}
.dd-item.on{color:var(--o);background:rgba(232,115,10,.1);border-left-color:var(--o);}
.dd-sub-ico{font-size:13px;width:16px;text-align:center;flex-shrink:0;}

/* Scrollbar in nav */
#sb-nav::-webkit-scrollbar{width:3px;}
#sb-nav::-webkit-scrollbar-thumb{background:var(--b);border-radius:2px;}

/* ═══ VOICE SETTINGS PANEL ═══ */
.vc-icon-btn{background:none;border:none;color:var(--t3);cursor:pointer;font-size:16px;padding:3px 5px;border-radius:3px;transition:all .2s;line-height:1;}
.vc-icon-btn:hover{color:var(--o);background:rgba(232,115,10,.1);}
.vc-icon-btn.active{color:var(--o);}

/* Mic visualizer */
.mic-viz-bar-wrap{flex:1;height:6px;background:var(--d);overflow:hidden;border-radius:3px;}
.mic-viz-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--g),#80ff60);border-radius:3px;transition:width .05s;}

/* Settings sections */
.vsp-sec{padding:10px 13px;border-bottom:1px solid var(--b);}
.vsp-lbl{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--o);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;}
.vsp-row{display:flex;align-items:center;gap:8px;}
.vsp-key{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);flex-shrink:0;min-width:44px;}
.vsp-val{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t2);min-width:34px;text-align:right;}
.vsp-range{flex:1;accent-color:var(--o);height:3px;cursor:pointer;}
.vsp-sel{background:var(--d3);border:1px solid var(--b2);color:var(--t);font-family:'Rajdhani',sans-serif;font-size:12px;padding:5px 7px;outline:none;width:100%;cursor:pointer;}
.vsp-sel:focus{border-color:var(--o);}
.vsp-btn{background:none;border:1px solid var(--b2);color:var(--t3);font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:1px;padding:4px 9px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:4px;}
.vsp-btn:hover{border-color:var(--o);color:var(--o);}
.vsp-key-btn{width:100%;padding:8px;background:var(--d3);border:1px solid var(--b2);color:var(--o);font-family:'Share Tech Mono',monospace;font-size:12px;cursor:pointer;text-align:center;letter-spacing:2px;transition:all .2s;}
.vsp-key-btn:hover{border-color:var(--o);}
.vsp-key-btn.binding{border-color:var(--r);color:var(--r);animation:blink .6s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* Room admin controls */
.vsp-room-item{display:flex;align-items:center;gap:7px;padding:6px 0;border-bottom:1px solid var(--b);}
.vsp-room-nm{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:var(--w);flex:1;}
.vsp-room-cnt{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);}

/* Voice log */
.vs-log-entry{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);padding:3px 0;border-bottom:1px solid rgba(42,53,64,.4);display:flex;gap:6px;}
.vs-log-time{color:var(--t3);flex-shrink:0;}
.vs-log-join{color:var(--g);}
.vs-log-leave{color:var(--r);}

/* Speaking indicator on room users */
.vu.speaking{background:rgba(46,204,113,.08);}
.vu-speaking-ring{width:8px;height:8px;border-radius:50%;background:var(--g);flex-shrink:0;animation:pulse-ring .8s infinite;}
@keyframes pulse-ring{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

/* Deafen button */
.vc-btn.deafened{background:rgba(192,57,43,.2);border-color:var(--r);color:var(--r);}

/* ═══ SOUNDBOARD ═══ */
.sb-header{padding:9px 12px;border-bottom:1px solid var(--b);flex-shrink:0;}
.sb-cat{padding:8px 10px 4px;}
.sb-cat-label{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--o);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;}
.sb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:5px;}
.sb-btn{background:var(--p2);border:1px solid var(--b);padding:8px 4px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;transition:all .12s;position:relative;overflow:hidden;}
.sb-btn:hover{border-color:var(--o);background:rgba(232,115,10,.1);}
.sb-btn:active{transform:scale(.95);}
.sb-btn.playing{border-color:var(--g);background:rgba(46,204,113,.15);animation:sb-pulse .3s ease;}
@keyframes sb-pulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}
.sb-btn-ico{font-size:20px;line-height:1;}
.sb-btn-name{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;color:var(--w);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:0 2px;}
.sb-btn-key{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--o);background:rgba(232,115,10,.15);padding:1px 4px;border-radius:2px;}
.sb-toggle-btn{background:none;border:none;color:var(--t3);cursor:pointer;font-size:15px;padding:3px 5px;border-radius:3px;transition:all .2s;line-height:1;}
.sb-toggle-btn:hover{color:var(--o);background:rgba(232,115,10,.1);}
.sb-toggle-btn.active{color:var(--o);}

/* ═══ AUTO DJ ═══ */
.dj-player{position:relative;background:var(--p);border:1px solid var(--b);overflow:hidden;margin-bottom:0;}
.dj-player-bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,115,10,.08) 0%,transparent 60%);pointer-events:none;}
.dj-player-inner{position:relative;display:flex;align-items:center;gap:20px;padding:20px 22px;}

/* Disc */
.dj-disc{width:90px;height:90px;border-radius:50%;background:radial-gradient(circle at 50%,#1a1a1a 28%,#0A0C0E 30%,#1E2A36 100%);border:3px solid var(--b2);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;}
.dj-disc::before{content:'';position:absolute;inset:8px;border-radius:50%;border:1px solid rgba(232,115,10,.25);}
.dj-disc-inner{font-size:24px;position:relative;z-index:1;}
.dj-disc.spinning{animation:dj-spin 4s linear infinite;}
@keyframes dj-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Info */
.dj-info{flex:1;min-width:0;}
.dj-now-label{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--o);letter-spacing:3px;margin-bottom:4px;}
.dj-title{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:900;color:var(--w);letter-spacing:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dj-artist{font-family:'Rajdhani',sans-serif;font-size:14px;color:var(--t3);margin-bottom:10px;}

/* Progress */
.dj-progress-wrap{margin-bottom:12px;}
.dj-progress-bar-bg{background:var(--d3);height:4px;overflow:hidden;border-radius:2px;}
.dj-progress-bar{height:100%;background:var(--o);border-radius:2px;transition:width .5s linear;}
.dj-times{display:flex;justify-content:space-between;font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--t3);margin-top:3px;}

/* Controls */
.dj-controls{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.dj-btn{background:none;border:1px solid var(--b2);color:var(--t2);cursor:pointer;width:34px;height:34px;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.dj-btn:hover{border-color:var(--o);color:var(--o);}
.dj-btn-main{width:44px;height:44px;font-size:18px;border-color:var(--o);color:var(--o);background:rgba(232,115,10,.1);}
.dj-btn-main:hover{background:rgba(232,115,10,.2);}
.dj-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}

/* Queue / Library items */
.dj-queue-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--b);transition:background .12s;}
.dj-queue-item:hover{background:rgba(232,115,10,.04);}
.dj-queue-item.active{background:rgba(232,115,10,.08);border-left:3px solid var(--o);}
.dj-queue-num{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--t3);min-width:16px;text-align:center;}
.dj-queue-play{background:none;border:1px solid var(--b2);color:var(--t3);cursor:pointer;padding:3px 8px;font-size:11px;transition:all .12s;}
.dj-queue-play:hover{border-color:var(--o);color:var(--o);}
.dj-queue-rm{background:none;border:1px solid var(--b2);color:var(--t3);cursor:pointer;padding:3px 7px;font-size:11px;transition:all .12s;}
.dj-queue-rm:hover{border-color:var(--r);color:var(--r);}
.dj-lib-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--b);transition:background .12s;}
.dj-lib-item:hover{background:rgba(255,255,255,.03);}

/* ═══ DEBUG CONSOLE ═══ */
.dbg-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:6px;padding:9px 12px;
  background:var(--d3);border:1px solid var(--b);border-bottom:none;}
.dbg-filter{background:none;border:1px solid var(--b2);color:var(--t3);
  font-family:'Share Tech Mono',monospace;font-size:10px;padding:3px 9px;cursor:pointer;transition:all .15s;}
.dbg-filter:hover{border-color:var(--o);color:var(--t2);}
.dbg-filter.on{border-color:var(--o);color:var(--o);background:rgba(232,115,10,.1);}
.dbg-btn{background:none;border:1px solid var(--b2);color:var(--t3);
  font-family:'Share Tech Mono',monospace;font-size:10px;padding:3px 9px;cursor:pointer;transition:all .15s;}
.dbg-btn:hover{border-color:var(--b2);color:var(--t2);}
.dbg-btn.active{border-color:var(--y);color:var(--y);}
.dbg-console{height:320px;overflow-y:auto;background:#050709;border:1px solid var(--b);
  font-family:'Share Tech Mono',monospace;font-size:11px;}
.dbg-console::-webkit-scrollbar{width:4px;}
.dbg-console::-webkit-scrollbar-thumb{background:var(--b2);}
.dbg-line{display:flex;align-items:baseline;gap:7px;padding:4px 10px;
  border-bottom:1px solid rgba(42,53,64,.3);cursor:pointer;transition:background .1s;line-height:1.5;}
.dbg-line:hover{background:rgba(255,255,255,.03);}
.dbg-line.expanded{background:rgba(232,115,10,.05);}
.dbg-error{border-left:2px solid #FF4444;}
.dbg-warn{border-left:2px solid #F39C12;}
.dbg-ok{border-left:2px solid #2ECC71;}
.dbg-socket{border-left:2px solid #A855F7;}
.dbg-api,.dbg-ok{border-left:2px solid #E8730A;}
.dbg-time{color:#3A4A5A;font-size:9px;flex-shrink:0;min-width:85px;}
.dbg-icon{font-size:10px;flex-shrink:0;}
.dbg-msg{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dbg-line.expanded .dbg-msg{white-space:normal;word-break:break-all;}
.dbg-detail{color:#556070;font-size:10px;flex-shrink:0;max-width:200px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dbg-line.expanded .dbg-detail{white-space:normal;max-width:100%;display:block;margin-top:3px;}
.dbg-input-row{display:flex;align-items:center;gap:8px;padding:7px 10px;
  background:#050709;border:1px solid var(--b);border-top:1px solid var(--b2);}
.dbg-input{flex:1;background:transparent;border:none;color:#E8730A;
  font-family:'Share Tech Mono',monospace;font-size:11px;outline:none;}
.dbg-input::placeholder{color:#2A3540;}
