:root{
  --bg1:#000;--bg2:#0d0000;--bg3:#1a0000;
  --accent:#e60000;--accent2:#ff3333;--accent3:#ff6666;
  --card:rgba(30,0,0,.75);--cb:rgba(200,0,0,.25);
  --text:#f5f5f5;--muted:rgba(255,255,255,.4);
  --glow:0 0 16px rgba(200,0,0,.5);--glow2:0 0 28px rgba(200,0,0,.3);
  --ok:#00e676;--bad:#ff1744;--bar:rgba(255,255,255,.08);--inp:rgba(0,0,0,.4);
  --sidebar:rgba(0,0,0,.55);--sidebar2:rgba(0,0,0,.4);
  --ch-hover:rgba(255,255,255,.06);--msg-hover:rgba(255,255,255,.04);
  --border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.12);
}
body.theme-disco{--bg1:#0a001a;--bg2:#00001a;--bg3:#001a0d;--accent:#ff00ff;--accent2:#00ffff;--accent3:#ffff00;--card:rgba(20,0,40,.8);--cb:rgba(255,0,255,.3);--glow:0 0 16px rgba(255,0,255,.5);--glow2:0 0 28px rgba(0,255,255,.3)}
body.theme-ocean{--bg1:#000e1a;--bg2:#001a33;--bg3:#002244;--accent:#00aaff;--accent2:#33ccff;--accent3:#66ddff;--card:rgba(0,15,40,.75);--cb:rgba(0,150,255,.25);--glow:0 0 16px rgba(0,150,255,.5);--glow2:0 0 28px rgba(0,150,255,.3)}
body.theme-synthwave{--bg1:#0d0020;--bg2:#1a0030;--bg3:#0a0015;--accent:#ff00cc;--accent2:#cc00ff;--accent3:#ff66ee;--card:rgba(20,0,40,.75);--cb:rgba(200,0,255,.25);--glow:0 0 16px rgba(200,0,255,.5);--glow2:0 0 28px rgba(200,0,255,.3)}
body.theme-midnight{--bg1:#05050f;--bg2:#080820;--bg3:#0a0a30;--accent:#6666ff;--accent2:#8888ff;--accent3:#aaaaff;--card:rgba(8,8,30,.75);--cb:rgba(100,100,255,.25);--glow:0 0 16px rgba(100,100,255,.5);--glow2:0 0 28px rgba(100,100,255,.3)}
body.theme-toxic{--bg1:#001400;--bg2:#001a00;--bg3:#002200;--accent:#00ff44;--accent2:#33ff66;--accent3:#66ff88;--card:rgba(0,20,0,.75);--cb:rgba(0,200,60,.25);--glow:0 0 16px rgba(0,200,60,.5);--glow2:0 0 28px rgba(0,200,60,.3)}
body.theme-sunset{--bg1:#120005;--bg2:#1a0010;--bg3:#200020;--accent:#ff6600;--accent2:#ff9900;--accent3:#ffcc00;--card:rgba(25,5,0,.75);--cb:rgba(255,100,0,.25);--glow:0 0 16px rgba(255,100,0,.5);--glow2:0 0 28px rgba(255,100,0,.3)}
body.theme-blood{--bg1:#0d0000;--bg2:#1a0000;--bg3:#2a0000;--accent:#ff0000;--accent2:#ff3333;--accent3:#ff6666;--card:rgba(40,0,0,.8);--cb:rgba(255,0,0,.3);--glow:0 0 16px rgba(255,0,0,.6);--glow2:0 0 28px rgba(255,0,0,.3)}
body.theme-arctic{--bg1:#050d14;--bg2:#0a1a24;--bg3:#0f2233;--accent:#aaddff;--accent2:#cceeff;--accent3:#eef8ff;--card:rgba(5,20,35,.8);--cb:rgba(150,210,255,.2);--glow:0 0 16px rgba(150,210,255,.4);--glow2:0 0 28px rgba(150,210,255,.2)}
body.theme-lava{--bg1:#0d0800;--bg2:#1a0e00;--bg3:#2a1500;--accent:#ff6600;--accent2:#ff8800;--accent3:#ffaa33;--card:rgba(30,15,0,.8);--cb:rgba(255,100,0,.25);--glow:0 0 16px rgba(255,100,0,.5);--glow2:0 0 28px rgba(255,100,0,.3)}
body.theme-galaxy{--bg1:#02000f;--bg2:#05001a;--bg3:#08002a;--accent:#9933ff;--accent2:#bb55ff;--accent3:#dd99ff;--card:rgba(10,0,30,.8);--cb:rgba(150,50,255,.25);--glow:0 0 16px rgba(150,50,255,.5);--glow2:0 0 28px rgba(150,50,255,.3)}
body.theme-forest{--bg1:#000d00;--bg2:#001500;--bg3:#002000;--accent:#22aa44;--accent2:#33cc55;--accent3:#55dd77;--card:rgba(0,15,0,.8);--cb:rgba(30,150,60,.25);--glow:0 0 16px rgba(30,150,60,.5);--glow2:0 0 28px rgba(30,150,60,.3)}
body.theme-cherry{--bg1:#140008;--bg2:#200010;--bg3:#2d0018;--accent:#ff2266;--accent2:#ff4488;--accent3:#ff88bb;--card:rgba(30,0,15,.8);--cb:rgba(255,30,90,.25);--glow:0 0 16px rgba(255,30,90,.5);--glow2:0 0 28px rgba(255,30,90,.3)}
body.theme-gold{--bg1:#0d0900;--bg2:#1a1200;--bg3:#261a00;--accent:#ccaa00;--accent2:#ffcc00;--accent3:#ffdd55;--card:rgba(25,18,0,.8);--cb:rgba(200,160,0,.25);--glow:0 0 16px rgba(200,160,0,.5);--glow2:0 0 28px rgba(200,160,0,.3)}
body.theme-matrix{--bg1:#000800;--bg2:#001000;--bg3:#001800;--accent:#00ff00;--accent2:#33ff33;--accent3:#66ff66;--card:rgba(0,12,0,.85);--cb:rgba(0,255,0,.2);--glow:0 0 16px rgba(0,255,0,.5);--glow2:0 0 28px rgba(0,255,0,.25)}
body.theme-copper{--bg1:#0d0700;--bg2:#1a0e00;--bg3:#251500;--accent:#cc6622;--accent2:#ee8844;--accent3:#ffaa66;--card:rgba(25,12,0,.8);--cb:rgba(200,100,30,.25);--glow:0 0 16px rgba(200,100,30,.5);--glow2:0 0 28px rgba(200,100,30,.3)}
body.theme-rose{--bg1:#140009;--bg2:#200010;--bg3:#2d001a;--accent:#ff4499;--accent2:#ff66bb;--accent3:#ffaadd;--card:rgba(30,0,18,.8);--cb:rgba(255,50,140,.25);--glow:0 0 16px rgba(255,50,140,.5);--glow2:0 0 28px rgba(255,50,140,.3)}
body.theme-ice{--bg1:#050f18;--bg2:#081a28;--bg3:#0c2438;--accent:#88ddff;--accent2:#aaeeff;--accent3:#ccf5ff;--card:rgba(5,18,30,.8);--cb:rgba(120,210,255,.2);--glow:0 0 16px rgba(120,210,255,.45);--glow2:0 0 28px rgba(120,210,255,.2)}
body.theme-ash{--bg1:#0a0a0a;--bg2:#111111;--bg3:#181818;--accent:#aaaaaa;--accent2:#cccccc;--accent3:#eeeeee;--card:rgba(20,20,20,.8);--cb:rgba(180,180,180,.2);--glow:0 0 16px rgba(180,180,180,.3);--glow2:0 0 28px rgba(180,180,180,.15)}
body.theme-neonpink{--bg1:#0d000d;--bg2:#150015;--bg3:#1e001e;--accent:#ff00aa;--accent2:#ff33cc;--accent3:#ff88ee;--card:rgba(20,0,20,.8);--cb:rgba(255,0,170,.25);--glow:0 0 16px rgba(255,0,170,.6);--glow2:0 0 28px rgba(255,0,170,.3)}
body.theme-neonblue{--bg1:#00050f;--bg2:#000a1a;--bg3:#000f26;--accent:#0066ff;--accent2:#2288ff;--accent3:#66aaff;--card:rgba(0,8,20,.85);--cb:rgba(0,100,255,.25);--glow:0 0 16px rgba(0,100,255,.6);--glow2:0 0 28px rgba(0,100,255,.3)}
body.theme-amber{--bg1:#0d0700;--bg2:#180e00;--bg3:#221400;--accent:#ff9900;--accent2:#ffaa22;--accent3:#ffcc66;--card:rgba(22,13,0,.8);--cb:rgba(255,150,0,.25);--glow:0 0 16px rgba(255,150,0,.5);--glow2:0 0 28px rgba(255,150,0,.3)}
body.theme-wine{--bg1:#0d0005;--bg2:#18000a;--bg3:#220010;--accent:#990033;--accent2:#cc0044;--accent3:#ff3366;--card:rgba(20,0,8,.8);--cb:rgba(150,0,50,.25);--glow:0 0 16px rgba(150,0,50,.5);--glow2:0 0 28px rgba(150,0,50,.3)}
body.theme-coffee{--bg1:#0d0800;--bg2:#1a1000;--bg3:#261700;--accent:#aa7744;--accent2:#cc9966;--accent3:#eebb88;--card:rgba(22,14,0,.8);--cb:rgba(170,120,60,.25);--glow:0 0 16px rgba(170,120,60,.45);--glow2:0 0 28px rgba(170,120,60,.25)}
body.theme-storm{--bg1:#050810;--bg2:#080d18;--bg3:#0b1220;--accent:#4466aa;--accent2:#5577cc;--accent3:#8899ee;--card:rgba(8,12,22,.8);--cb:rgba(70,100,180,.25);--glow:0 0 16px rgba(70,100,180,.45);--glow2:0 0 28px rgba(70,100,180,.25)}
body.theme-fire{--bg1:#100000;--bg2:#1a0400;--bg3:#220800;--accent:#ff3300;--accent2:#ff5500;--accent3:#ff8833;--card:rgba(25,5,0,.8);--cb:rgba(255,60,0,.25);--glow:0 0 16px rgba(255,60,0,.55);--glow2:0 0 28px rgba(255,60,0,.3)}
body.theme-void{--bg1:#000000;--bg2:#030303;--bg3:#060606;--accent:#ffffff;--accent2:#dddddd;--accent3:#bbbbbb;--card:rgba(8,8,8,.9);--cb:rgba(255,255,255,.12);--glow:0 0 16px rgba(255,255,255,.25);--glow2:0 0 28px rgba(255,255,255,.1)}
body.theme-sakura{--bg1:#140009;--bg2:#1e000e;--bg3:#280014;--accent:#ff88bb;--accent2:#ffaacc;--accent3:#ffccdd;--card:rgba(25,0,12,.8);--cb:rgba(255,130,180,.2);--glow:0 0 16px rgba(255,130,180,.45);--glow2:0 0 28px rgba(255,130,180,.25)}
body.theme-rust{--bg1:#0d0500;--bg2:#1a0a00;--bg3:#260e00;--accent:#cc4400;--accent2:#ee5500;--accent3:#ff7733;--card:rgba(22,8,0,.8);--cb:rgba(200,70,0,.25);--glow:0 0 16px rgba(200,70,0,.5);--glow2:0 0 28px rgba(200,70,0,.3)}
body.theme-aqua{--bg1:#00100f;--bg2:#001a18;--bg3:#002422;--accent:#00ccbb;--accent2:#00eecc;--accent3:#44ffdd;--card:rgba(0,18,16,.8);--cb:rgba(0,200,180,.25);--glow:0 0 16px rgba(0,200,180,.5);--glow2:0 0 28px rgba(0,200,180,.3)}
body.theme-emerald{--bg1:#000f08;--bg2:#001810;--bg3:#002218;--accent:#00aa66;--accent2:#00cc77;--accent3:#33ee99;--card:rgba(0,14,10,.8);--cb:rgba(0,170,100,.25);--glow:0 0 16px rgba(0,170,100,.5);--glow2:0 0 28px rgba(0,170,100,.3)}
body.theme-violet{--bg1:#060010;--bg2:#0a0018;--bg3:#0e0022;--accent:#8800ff;--accent2:#aa33ff;--accent3:#cc77ff;--card:rgba(10,0,22,.8);--cb:rgba(130,0,255,.25);--glow:0 0 16px rgba(130,0,255,.5);--glow2:0 0 28px rgba(130,0,255,.3)}
body.theme-steel{--bg1:#060a0d;--bg2:#0a1018;--bg3:#0f1620;--accent:#4488aa;--accent2:#55aacc;--accent3:#88ccee;--card:rgba(8,14,20,.8);--cb:rgba(60,130,170,.25);--glow:0 0 16px rgba(60,130,170,.45);--glow2:0 0 28px rgba(60,130,170,.25)}
body.theme-coral{--bg1:#0d0500;--bg2:#1a0800;--bg3:#260c00;--accent:#ff5533;--accent2:#ff7755;--accent3:#ffaa88;--card:rgba(22,8,0,.8);--cb:rgba(255,80,50,.25);--glow:0 0 16px rgba(255,80,50,.5);--glow2:0 0 28px rgba(255,80,50,.3)}
body.theme-mint{--bg1:#001209;--bg2:#001c0e;--bg3:#002614;--accent:#44ddaa;--accent2:#66eebb;--accent3:#99ffdd;--card:rgba(0,18,10,.8);--cb:rgba(60,210,160,.25);--glow:0 0 16px rgba(60,210,160,.5);--glow2:0 0 28px rgba(60,210,160,.3)}
body.theme-lavender{--bg1:#080010;--bg2:#0d0018;--bg3:#120020;--accent:#bb88ff;--accent2:#ccaaff;--accent3:#ddccff;--card:rgba(12,0,20,.8);--cb:rgba(180,120,255,.2);--glow:0 0 16px rgba(180,120,255,.45);--glow2:0 0 28px rgba(180,120,255,.25)}
body.theme-cyber{--bg1:#000d00;--bg2:#001100;--bg3:#001600;--accent:#ddff00;--accent2:#eeff33;--accent3:#f5ff88;--card:rgba(0,14,0,.85);--cb:rgba(200,255,0,.2);--glow:0 0 16px rgba(200,255,0,.5);--glow2:0 0 28px rgba(200,255,0,.25)}
body.theme-bloodmoon{--bg1:#080000;--bg2:#140400;--bg3:#200800;--accent:#ff4400;--accent2:#ff6622;--accent3:#ff9955;--card:rgba(16,4,0,.85);--cb:rgba(255,60,0,.25);--glow:0 0 20px rgba(255,60,0,.55);--glow2:0 0 32px rgba(255,60,0,.3)}
body.theme-neonorange{--bg1:#0d0500;--bg2:#150800;--bg3:#1e0b00;--accent:#ff6600;--accent2:#ff8800;--accent3:#ffaa44;--card:rgba(20,8,0,.85);--cb:rgba(255,100,0,.25);--glow:0 0 16px rgba(255,100,0,.6);--glow2:0 0 28px rgba(255,100,0,.3)}
body.theme-deepsea{--bg1:#000008;--bg2:#000012;--bg3:#00001c;--accent:#0033aa;--accent2:#0044cc;--accent3:#3366ee;--card:rgba(0,0,14,.85);--cb:rgba(0,50,180,.25);--glow:0 0 16px rgba(0,50,180,.5);--glow2:0 0 28px rgba(0,50,180,.3)}
body.theme-solar{--bg1:#0d0900;--bg2:#1a1200;--bg3:#281b00;--accent:#ffcc00;--accent2:#ffdd33;--accent3:#ffee88;--card:rgba(22,16,0,.8);--cb:rgba(255,200,0,.25);--glow:0 0 16px rgba(255,200,0,.5);--glow2:0 0 28px rgba(255,200,0,.3)}
body.theme-terminal{--bg1:#000800;--bg2:#000d00;--bg3:#001100;--accent:#00bb00;--accent2:#00dd00;--accent3:#00ff00;--card:rgba(0,10,0,.9);--cb:rgba(0,180,0,.2);--glow:0 0 14px rgba(0,180,0,.5);--glow2:0 0 24px rgba(0,180,0,.25)}
body.theme-purplerain{--bg1:#050010;--bg2:#0a0020;--bg3:#0f002e;--accent:#7700cc;--accent2:#9922ee;--accent3:#bb66ff;--card:rgba(8,0,22,.8);--cb:rgba(120,0,200,.25);--glow:0 0 16px rgba(120,0,200,.5);--glow2:0 0 28px rgba(120,0,200,.3)}
body.theme-holographic{--bg1:#050508;--bg2:#08080d;--bg3:#0c0c12;--accent:#ff66ff;--accent2:#66ffff;--accent3:#ffff66;--card:rgba(10,10,16,.8);--cb:rgba(200,150,255,.2);--glow:0 0 16px rgba(180,120,255,.5);--glow2:0 0 28px rgba(100,200,255,.3)}
body.theme-holographic{animation:holoShift 6s infinite}
@keyframes holoShift{0%{filter:hue-rotate(0deg) saturate(1.5)}50%{filter:hue-rotate(180deg) saturate(2)}100%{filter:hue-rotate(360deg) saturate(1.5)}}
body.theme-obsidian{--bg1:#000000;--bg2:#050508;--bg3:#0a0a10;--accent:#6644ff;--accent2:#8866ff;--accent3:#bbaaff;--card:rgba(5,5,10,.9);--cb:rgba(100,60,255,.2);--glow:0 0 16px rgba(100,60,255,.4);--glow2:0 0 28px rgba(100,60,255,.2)}
body.theme-aurora{--bg1:#000d0a;--bg2:#001810;--bg3:#002018;--accent:#00ffaa;--accent2:#33ffbb;--accent3:#88ffdd;--card:rgba(0,14,10,.8);--cb:rgba(0,240,160,.2);--glow:0 0 16px rgba(0,240,160,.45);--glow2:0 0 28px rgba(0,240,160,.25)}
body.theme-aurora{animation:auroraWave 8s infinite}
@keyframes auroraWave{0%,100%{filter:hue-rotate(0deg)}50%{filter:hue-rotate(60deg)}}
body.theme-candy{--bg1:#0d0010;--bg2:#150018;--bg3:#1e0020;--accent:#ff44cc;--accent2:#ff66dd;--accent3:#ffaaee;--card:rgba(18,0,20,.8);--cb:rgba(255,60,200,.25);--glow:0 0 16px rgba(255,60,200,.5);--glow2:0 0 28px rgba(255,60,200,.3)}
body.theme-infrared{--bg1:#080000;--bg2:#110000;--bg3:#1a0000;--accent:#ff0055;--accent2:#ff2266;--accent3:#ff6699;--card:rgba(14,0,0,.85);--cb:rgba(255,0,80,.25);--glow:0 0 16px rgba(255,0,80,.55);--glow2:0 0 28px rgba(255,0,80,.3)}
body.theme-disco{animation:hueRot 4s infinite}
@keyframes hueRot{0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(360deg)}}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{
  height:100vh;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(100,0,0,.55) 0%, transparent 45%),
    radial-gradient(ellipse at 80% 85%, rgba(60,0,0,.4) 0%, transparent 40%),
    radial-gradient(ellipse at 60% 10%, rgba(50,0,0,.3) 0%, transparent 35%),
    linear-gradient(160deg, var(--bg1) 0%, var(--bg2) 45%, var(--bg3) 100%);
  color:var(--text);
  font-family:'Rajdhani',sans-serif;
  overflow:hidden;
  transition:background .6s;
}

/* ── LOADING ── */
#loading{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;overflow:hidden;transition:opacity .6s ease;
  background:radial-gradient(ellipse at 30% 40%,rgba(100,0,0,.5) 0%,transparent 50%),radial-gradient(ellipse at 70% 60%,rgba(60,0,0,.4) 0%,transparent 45%),linear-gradient(160deg,#050000 0%,#000 50%,#0a0000 100%)}
.ld-logo{font-family:'Bebas Neue',cursive;font-size:4.5rem;letter-spacing:12px;color:#cc0000;text-shadow:0 0 30px rgba(204,0,0,.8),0 0 60px rgba(204,0,0,.4),0 0 100px rgba(204,0,0,.2);animation:ldG .9s ease-in-out infinite alternate;position:relative}
.ld-logo::after{content:'';position:absolute;bottom:-8px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,rgba(204,0,0,.6),transparent)}
@keyframes ldG{from{text-shadow:0 0 20px rgba(204,0,0,.6),0 0 40px rgba(204,0,0,.2)}to{text-shadow:0 0 40px rgba(204,0,0,1),0 0 80px rgba(204,0,0,.5),0 0 120px rgba(204,0,0,.3)}}
.ld-sub{color:rgba(255,255,255,.35);letter-spacing:4px;font-size:.78rem;text-transform:uppercase}
.ld-dots{display:flex;gap:12px}
.ld-dot{width:11px;height:11px;border-radius:50%;background:#cc0000;box-shadow:0 0 10px rgba(204,0,0,.6);animation:ldB 1.4s infinite ease-in-out both}
.ld-dot:nth-child(1){animation-delay:-.32s}.ld-dot:nth-child(2){animation-delay:-.16s}
@keyframes ldB{0%,80%,100%{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}
.ld-status{color:rgba(255,255,255,.25);font-size:.72rem;letter-spacing:3px;text-transform:uppercase;min-height:18px}

/* ── WELCOME ── */
#welcome-screen{position:fixed;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:1001;text-align:center;padding:24px;
  background:radial-gradient(ellipse at 25% 35%,rgba(120,0,0,.5) 0%,transparent 50%),radial-gradient(ellipse at 75% 65%,rgba(70,0,0,.35) 0%,transparent 45%),linear-gradient(160deg,#060000 0%,#000 50%,#0c0000 100%)}
.w-logo{font-family:'Bebas Neue',cursive;font-size:5.5rem;color:#cc0000;letter-spacing:10px;margin-bottom:4px;
  text-shadow:0 0 30px rgba(204,0,0,.8),0 0 60px rgba(204,0,0,.4),0 0 100px rgba(204,0,0,.2);animation:ldG 1.1s infinite alternate}
.w-tag{font-size:1.35rem;color:rgba(255,255,255,.6);margin-bottom:30px;letter-spacing:3px;text-transform:uppercase;font-size:.9rem}
.w-feats{display:flex;gap:14px;margin-bottom:32px;flex-wrap:wrap;justify-content:center}
.w-feat{background:rgba(255,255,255,.04);padding:16px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.08);min-width:130px;backdrop-filter:blur(10px);transition:.2s}
.w-feat:hover{background:rgba(255,255,255,.07);border-color:rgba(204,0,0,.3);transform:translateY(-3px)}
.w-feat h3{color:#ffaa44;margin-bottom:4px;font-family:'Bebas Neue',cursive;letter-spacing:1px;font-size:1.05rem}
.w-feat p{font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.4}
.w-btns{display:flex;gap:14px}
.w-btn{padding:13px 36px;border:none;border-radius:10px;font-family:'Bebas Neue',cursive;font-size:1.35rem;letter-spacing:3px;cursor:pointer;transition:.25s;position:relative;overflow:hidden}
.w-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:.25s}
.w-btn:hover::after{opacity:1}
.w-btn.primary{background:linear-gradient(135deg,#cc0000,#880000);color:#fff;box-shadow:0 4px 24px rgba(204,0,0,.45),0 0 0 1px rgba(255,255,255,.08)}
.w-btn.primary:hover{box-shadow:0 6px 32px rgba(204,0,0,.65),0 0 0 1px rgba(255,255,255,.12);transform:translateY(-2px)}
.w-btn.secondary{background:rgba(255,255,255,.07);color:#fff;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(10px)}
.w-btn.secondary:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}

/* ── AUTH ── */
#auth{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1000;
  background:radial-gradient(ellipse at 25% 35%,rgba(100,0,0,.4) 0%,transparent 50%),linear-gradient(160deg,#050000 0%,#000 100%)}
.abox{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:36px;width:330px;max-width:95vw;backdrop-filter:blur(20px);box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.05),inset 0 1px 0 rgba(255,255,255,.07)}
.alogo{font-family:'Bebas Neue',cursive;font-size:2.4rem;color:#cc0000;letter-spacing:7px;text-align:center;margin-bottom:3px;text-shadow:0 0 20px rgba(204,0,0,.5)}
.atag{text-align:center;color:var(--muted);font-size:.8rem;margin-bottom:18px;letter-spacing:1px}
.atabs{display:flex;gap:5px;margin-bottom:18px;background:rgba(0,0,0,.4);border-radius:9px;padding:4px}
.atab{flex:1;padding:8px;border:none;border-radius:7px;background:none;color:var(--muted);cursor:pointer;font-family:'Rajdhani',sans-serif;font-weight:600;letter-spacing:1px;font-size:.9rem;transition:.15s}
.atab.on{background:linear-gradient(135deg,rgba(204,0,0,.35),rgba(150,0,0,.25));color:#fff;box-shadow:0 2px 8px rgba(204,0,0,.2)}
.field{margin-bottom:13px}
.field label{display:block;font-size:.72rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.field input{width:100%;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 13px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:1rem;outline:none;transition:.2s}
.field input:focus{border-color:rgba(204,0,0,.6);background:rgba(0,0,0,.6);box-shadow:0 0 0 3px rgba(204,0,0,.1)}
.abtn{width:100%;padding:12px;border:none;border-radius:9px;background:linear-gradient(135deg,#cc0000,#990000);color:#fff;font-family:'Bebas Neue',cursive;font-size:1.25rem;letter-spacing:3px;cursor:pointer;transition:.2s;margin-top:5px;position:relative;overflow:hidden}
.abtn::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transition:.4s}
.abtn:hover::after{left:100%}
.abtn:hover{box-shadow:0 4px 20px rgba(204,0,0,.5)}
.amsg{margin-top:10px;font-size:.82rem;color:var(--bad);text-align:center;min-height:18px}

/* ── APP GRID ── */
#app{display:none;height:100vh;grid-template-columns:66px 238px 1fr 210px;overflow:hidden}

/* ── SERVER LIST ── */
#server-list{
  background:linear-gradient(180deg,rgba(0,0,0,.7) 0%,rgba(5,0,0,.65) 100%);
  display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:6px;
  overflow-y:auto;border-right:1px solid rgba(255,255,255,.05);scrollbar-width:none;
  backdrop-filter:blur(20px);
}
#server-list::-webkit-scrollbar{display:none}
.srv-icon{
  width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);
  font-family:'Bebas Neue',cursive;font-size:.95rem;color:var(--text);
  border:2px solid transparent;flex-shrink:0;position:relative;text-align:center;line-height:1;
}
.srv-icon:hover{border-radius:15px;border-color:var(--accent);background:var(--cb) !important;transform:scale(1.05)}
.srv-icon.active{border-radius:15px;border-color:var(--accent);background:var(--cb) !important;box-shadow:var(--glow)}
.srv-icon.home-icon{background:linear-gradient(135deg,#cc0000,#7a0000);font-size:1.3rem;box-shadow:0 4px 16px rgba(204,0,0,.3)}
.srv-icon.home-icon.active{box-shadow:var(--glow),0 4px 16px rgba(204,0,0,.3)}
.srv-icon.srv-c{background:rgba(255,255,255,.08)}
.srv-icon.add-icon{background:rgba(255,255,255,.06);font-size:1.6rem;color:var(--ok);border-style:dashed}
.srv-icon.add-icon:hover{background:rgba(0,230,118,.12);border-color:var(--ok);border-style:solid}
.srv-div{width:30px;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);border-radius:1px;flex-shrink:0}

/* ── CHANNEL SIDEBAR ── */
#ch-sidebar{
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(5,0,0,.5) 100%);
  display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.05);overflow:hidden;
  backdrop-filter:blur(16px);
}
#srv-hdr{
  padding:13px 15px;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:8px;cursor:pointer;flex-shrink:0;min-height:48px;
  transition:.15s;background:rgba(255,255,255,.02);
}
#srv-hdr:hover{background:rgba(255,255,255,.05)}
.srv-hname{font-family:'Bebas Neue',cursive;font-size:1.15rem;letter-spacing:1.5px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.srv-hcaret{color:var(--muted);font-size:.88rem;transition:.2s}
#srv-hdr:hover .srv-hcaret{color:var(--text);transform:rotate(180deg)}
#ch-list{flex:1;overflow-y:auto;padding:5px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.ch-cat{padding:13px 13px 3px;font-size:.64rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;justify-content:space-between}
.ch-cat-add{cursor:pointer;opacity:.5;transition:.15s;font-size:.95rem;padding:2px 4px;border-radius:4px}
.ch-cat-add:hover{opacity:1;color:var(--accent2);background:var(--cb)}
.ch-item{
  display:flex;align-items:center;gap:7px;padding:7px 13px;margin:1px 5px;border-radius:7px;
  cursor:pointer;color:rgba(255,255,255,.45);transition:.12s;font-size:.91rem;font-weight:600;user-select:none;position:relative;
}
.ch-item:hover{background:var(--ch-hover);color:rgba(255,255,255,.82)}
.ch-item.active{background:linear-gradient(90deg,var(--cb),rgba(255,255,255,.04));color:#fff}
.ch-item.active::before{content:'';position:absolute;left:0;top:15%;bottom:15%;width:3px;background:var(--accent);border-radius:0 2px 2px 0}
.ch-icon{font-size:.86rem;width:14px;text-align:center;flex-shrink:0;color:var(--muted)}
.ch-item.active .ch-icon,.ch-item:hover .ch-icon{color:inherit}
.ch-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ch-del-btn{display:none;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;padding:2px 4px;border-radius:3px;transition:.15s}
.ch-item:hover .ch-del-btn{display:block}.ch-del-btn:hover{color:var(--bad)}
.dm-item{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:7px;cursor:pointer;transition:.12s;margin:2px 5px}
.dm-item:hover{background:var(--ch-hover)}.dm-item.active{background:linear-gradient(90deg,var(--cb),rgba(255,255,255,.04))}
.dm-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;border:2px solid rgba(255,255,255,.08)}
.dm-nm{font-weight:600;font-size:.88rem;color:rgba(255,255,255,.68)}.dm-item:hover .dm-nm,.dm-item.active .dm-nm{color:#fff}
.dm-prev{font-size:.7rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:125px}

/* ── USER INFO BAR ── */
#user-info{padding:9px 10px;background:rgba(0,0,0,.45);border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:7px;flex-shrink:0}
.ui-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.88rem;cursor:pointer;flex-shrink:0;border:2px solid rgba(255,255,255,.12);transition:.15s;font-weight:700}
.ui-av:hover{border-color:var(--accent2);box-shadow:var(--glow)}
.ui-names{flex:1;overflow:hidden}
.ui-nm{font-weight:700;font-size:.87rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ui-stat{font-size:.67rem;color:var(--ok)}
.ui-btns{display:flex;gap:2px}
.ui-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.9rem;padding:4px;border-radius:5px;transition:.15s;width:26px;height:26px;display:flex;align-items:center;justify-content:center}
.ui-btn:hover{color:var(--text);background:rgba(255,255,255,.1)}
.coins-d{font-family:'Bebas Neue',cursive;letter-spacing:1px;font-size:.87rem;color:#ffaa44;width:auto;padding:4px 6px}
.coins-d:hover{color:#ffcc66;background:rgba(255,170,0,.1)}
.inv-strip{padding:8px 11px;border-top:1px solid rgba(255,255,255,.05);flex-shrink:0}
.inv-box{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--accent2);background:rgba(0,0,0,.4);padding:6px 9px;border-radius:6px;display:flex;align-items:center;justify-content:space-between;border:1px solid rgba(255,255,255,.06)}
.inv-box button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;padding:0;transition:.15s}.inv-box button:hover{color:var(--accent2)}

/* ── MAIN ── */
#main-content{display:flex;flex-direction:column;overflow:hidden;min-width:0}
#ch-header{
  padding:11px 16px;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:9px;flex-shrink:0;min-height:48px;
  background:rgba(0,0,0,.18);backdrop-filter:blur(10px);
}
.ch-h-ic{font-size:1.05rem;color:var(--muted)}
.ch-h-nm{font-family:'Bebas Neue',cursive;font-size:1.25rem;letter-spacing:1.5px}
.ch-h-top{font-size:.78rem;color:var(--muted);border-left:1px solid rgba(255,255,255,.1);padding-left:10px;margin-left:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}
.ch-h-acts{margin-left:auto;display:flex;gap:5px}
.ch-hbtn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.97rem;padding:6px;border-radius:6px;transition:.15s}
.ch-hbtn:hover{color:var(--text);background:rgba(255,255,255,.08)}

#messages{flex:1;overflow-y:auto;padding:12px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.ch-start{padding:24px 16px 12px;border-bottom:1px solid rgba(255,255,255,.04);margin-bottom:8px}
.ch-start-icon{font-size:3rem;margin-bottom:9px;display:block;width:56px;height:56px;border-radius:16px;background:var(--cb);display:flex;align-items:center;justify-content:center;font-size:1.8rem;border:1px solid rgba(255,255,255,.08)}
.ch-start-name{font-family:'Bebas Neue',cursive;font-size:1.8rem;letter-spacing:2px;margin-bottom:4px;color:var(--text)}
.ch-start-desc{color:var(--muted);font-size:.86rem}
.msg-grp{padding:3px 16px;display:flex;gap:12px;transition:.1s}
.msg-grp:hover{background:var(--msg-hover)}
.msg-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0;margin-top:2px;cursor:pointer;border:2px solid rgba(255,255,255,.07);transition:.15s;font-weight:700}
.msg-av:hover{border-color:var(--accent2);box-shadow:0 0 10px rgba(0,0,0,.4)}
.msg-body{flex:1;min-width:0}
.msg-hdr{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}
.msg-user{font-weight:700;cursor:pointer;transition:.15s;font-size:.92rem}
.msg-user:hover{text-decoration:underline;filter:brightness(1.2)}
.msg-time{font-size:.68rem;color:var(--muted)}
.msg-txt{color:rgba(255,255,255,.87);line-height:1.55;font-size:.92rem;word-break:break-word}
.msg-txt .mention{color:var(--accent2);background:var(--cb);border-radius:4px;padding:1px 4px;cursor:pointer;transition:.15s}
.msg-txt .mention:hover{background:rgba(255,255,255,.1)}
.msg-cont{padding:2px 16px 2px 64px;position:relative;transition:.1s}
.msg-cont:hover{background:var(--msg-hover)}
.msg-ctext{color:rgba(255,255,255,.87);line-height:1.55;font-size:.92rem;word-break:break-word}
.msg-acts{display:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);background:rgba(5,0,0,.95);border:1px solid rgba(255,255,255,.1);border-radius:7px;padding:3px 6px;gap:3px;backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(0,0,0,.5)}
.msg-cont:hover .msg-acts,.msg-grp:hover .msg-acts{display:flex}
.msg-act{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.76rem;padding:4px 5px;border-radius:4px;transition:.15s;font-family:'Rajdhani',sans-serif;font-weight:600}
.msg-act:hover{color:var(--text);background:rgba(255,255,255,.08)}.msg-act.red:hover{color:var(--bad);background:rgba(255,23,68,.1)}
.msg-ed{font-size:.65rem;color:var(--muted);font-style:italic;margin-left:4px}
.msg-sys{text-align:center;color:var(--muted);font-size:.8rem;padding:7px 16px;font-style:italic}

#input-area{padding:10px 16px;flex-shrink:0}
.inp-wrap{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:10px;
  display:flex;align-items:flex-end;gap:6px;padding:0 10px;transition:.2s;
  box-shadow:0 2px 12px rgba(0,0,0,.3);
}
.inp-wrap:focus-within{border-color:rgba(204,0,0,.45);background:rgba(255,255,255,.08);box-shadow:0 2px 12px rgba(0,0,0,.3),0 0 0 3px rgba(204,0,0,.08)}
#msg-input{flex:1;background:none;border:none;outline:none;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.97rem;padding:11px 0;resize:none;line-height:1.4;max-height:110px;overflow-y:auto}
#msg-input::placeholder{color:rgba(255,255,255,.25)}
.send-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:1.05rem;padding:8px 4px;border-radius:6px;transition:.2s;flex-shrink:0}
.send-btn:hover{color:var(--accent2);background:var(--cb);transform:scale(1.1)}
.typ-bar{padding:3px 16px;font-size:.74rem;color:var(--muted);min-height:19px;font-style:italic}
.typ-dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--muted);margin:0 1px;animation:tdB 1.2s infinite ease-in-out both}
.typ-dots span:nth-child(1){animation-delay:-.24s}.typ-dots span:nth-child(2){animation-delay:-.12s}
@keyframes tdB{0%,80%,100%{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}

/* ── MEMBERS ── */
#members-bar{
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(5,0,0,.5) 100%);
  border-left:1px solid rgba(255,255,255,.05);overflow-y:auto;padding:10px 0;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent;backdrop-filter:blur(16px);
}
.mem-cat{padding:11px 12px 4px;font-size:.63rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}
.mem-row{display:flex;align-items:center;gap:8px;padding:6px 9px;margin:1px 4px;border-radius:7px;cursor:pointer;transition:.12s}
.mem-row:hover{background:var(--ch-hover)}
.mem-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0;position:relative;border:2px solid rgba(255,255,255,.08);font-weight:700}
.mem-dot{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;border:2px solid transparent}
.mem-dot.on{background:var(--ok);border-color:var(--sidebar)}.mem-dot.off{background:#555;border-color:var(--sidebar)}
.mem-nm{font-size:.86rem;font-weight:600;color:rgba(255,255,255,.68)}.mem-row:hover .mem-nm{color:#fff}

/* ── HOME ── */
#home-screen{display:none;flex:1;overflow-y:auto;padding:36px 32px;flex-direction:column;align-items:flex-start}
.home-logo{font-family:'Bebas Neue',cursive;font-size:3.6rem;color:#cc0000;letter-spacing:7px;text-shadow:0 0 20px rgba(204,0,0,.5),0 0 40px rgba(204,0,0,.25);margin-bottom:5px}
.home-sub{color:rgba(255,255,255,.55);font-size:1rem;margin-bottom:26px;letter-spacing:.5px}
.home-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(188px,1fr));gap:13px;max-width:740px;width:100%}
.hc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:18px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.2,.64,1);position:relative;overflow:hidden;backdrop-filter:blur(10px)}
.hc::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--cb),transparent);opacity:0;transition:.2s}
.hc:hover{background:rgba(255,255,255,.07);border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.4),var(--glow2)}
.hc:hover::before{opacity:.4}
.hc-icon{font-size:1.8rem;margin-bottom:8px;position:relative}
.hc-title{font-family:'Bebas Neue',cursive;font-size:1.1rem;color:var(--accent2);margin-bottom:4px;letter-spacing:1.5px;position:relative}
.hc-desc{font-size:.8rem;color:var(--muted);line-height:1.4;position:relative}
.home-stats{margin-top:24px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:18px;max-width:740px;width:100%;backdrop-filter:blur(10px)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(105px,1fr));gap:10px;margin-top:10px}
.stat-box{text-align:center;padding:10px;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}
.stat-val{display:block;font-family:'Bebas Neue',cursive;font-size:1.8rem;color:var(--accent2);text-shadow:var(--glow2)}
.stat-lbl{font-size:.67rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}

/* ── MODALS ── */
.moverlay{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);z-index:5000;display:none;align-items:center;justify-content:center}
.moverlay.on{display:flex}
.modal{
  background:linear-gradient(160deg,rgba(20,0,0,.95),rgba(10,0,0,.98));
  border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:26px;
  max-width:490px;width:92%;max-height:88vh;overflow-y:auto;
  box-shadow:0 24px 64px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.05),inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(20px);
}
.modal.wide{max-width:740px}.modal.xl{max-width:920px}
.mttl{font-family:'Bebas Neue',cursive;font-size:1.7rem;color:var(--accent2);letter-spacing:3px;margin-bottom:3px;text-shadow:var(--glow2)}
.msub{color:var(--muted);font-size:.83rem;margin-bottom:17px;letter-spacing:.3px}
.mfield{margin-bottom:13px}
.mfield label{display:block;font-size:.72rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.mfield input,.mfield textarea,.mfield select{width:100%;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:9px 12px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.93rem;outline:none;transition:.2s}
.mfield input:focus,.mfield textarea:focus{border-color:rgba(204,0,0,.6);box-shadow:0 0 0 3px rgba(204,0,0,.08)}
.mfield select option{background:#0d0000}
.mbtn{padding:10px 22px;border:none;border-radius:8px;font-family:'Bebas Neue',cursive;font-size:1.02rem;letter-spacing:2px;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.mbtn.primary{background:linear-gradient(135deg,#cc0000,#880000);color:#fff;box-shadow:0 4px 16px rgba(204,0,0,.35)}
.mbtn.primary:hover{box-shadow:0 6px 24px rgba(204,0,0,.55);transform:translateY(-1px)}
.mbtn.secondary{background:rgba(255,255,255,.07);color:var(--muted);border:1px solid rgba(255,255,255,.1)}
.mbtn.secondary:hover{color:#fff;background:rgba(255,255,255,.12)}
.mbtnclose{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--muted);padding:9px 20px;cursor:pointer;font-family:'Rajdhani',sans-serif;font-weight:700;letter-spacing:1px;transition:.15s;margin-top:12px}
.mbtnclose:hover{color:#fff;background:rgba(255,255,255,.12)}
.merr{color:var(--bad);font-size:.78rem;margin-top:7px;min-height:16px}
.srv-opts{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:10px}
.srv-opt{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:18px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.2,.64,1);text-align:center}
.srv-opt:hover{background:rgba(255,255,255,.08);border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--glow2)}
.srv-opt-icon{font-size:2.2rem;margin-bottom:8px}
.srv-opt-title{font-family:'Bebas Neue',cursive;font-size:1.05rem;color:var(--accent2);letter-spacing:1px;margin-bottom:3px}
.srv-opt-desc{font-size:.76rem;color:var(--muted)}

/* ── SYSTEM HUB ── */
.hub-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:17px;border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:10px}
.hub-tab{padding:6px 13px;border:none;border-radius:7px;background:rgba(255,255,255,.06);color:var(--muted);cursor:pointer;font-family:'Rajdhani',sans-serif;font-weight:700;letter-spacing:.8px;font-size:.79rem;transition:.15s}
.hub-tab.on{background:linear-gradient(135deg,rgba(204,0,0,.3),rgba(150,0,0,.2));color:#fff;border:1px solid rgba(204,0,0,.3);box-shadow:0 2px 8px rgba(204,0,0,.2)}
.hub-tab:hover:not(.on){color:var(--text);background:rgba(255,255,255,.1)}
.hub-sec{display:none}.hub-sec.on{display:block}
.hub-lock{text-align:center;padding:26px}
.hub-lock-icon{font-size:2.8rem;margin-bottom:10px;filter:drop-shadow(0 0 10px rgba(204,0,0,.3))}
.hub-lock-title{font-family:'Bebas Neue',cursive;font-size:1.35rem;color:var(--accent2);letter-spacing:2px;margin-bottom:5px}
.hub-lock input{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:9px 13px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.93rem;outline:none;width:210px;display:block;margin:0 auto 12px;text-align:center;letter-spacing:2px}
.hub-lock input:focus{border-color:rgba(204,0,0,.5);box-shadow:0 0 0 3px rgba(204,0,0,.08)}
.hub-section-title{font-family:'Bebas Neue',cursive;font-size:.98rem;color:var(--accent2);letter-spacing:2px;margin-bottom:7px;text-shadow:var(--glow2)}
.hub-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:3px}
.hub-search-inp{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 11px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.87rem;outline:none;width:100%;margin-bottom:9px;transition:.2s}
.hub-search-inp:focus{border-color:rgba(204,0,0,.5)}
.acc-table{width:100%;border-collapse:collapse}
.acc-table th{padding:7px 11px;text-align:left;font-size:.69rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid rgba(255,255,255,.08)}
.acc-table td{padding:7px 11px;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem;vertical-align:middle}
.acc-table tr:hover td{background:rgba(255,255,255,.025)}
.bsm{padding:3px 8px;border:none;border-radius:5px;font-size:.7rem;font-family:'Rajdhani',sans-serif;font-weight:700;cursor:pointer;transition:.15s;letter-spacing:.4px}
.bsm.give{background:rgba(0,230,118,.13);color:var(--ok);border:1px solid rgba(0,230,118,.27)}
.bsm.take{background:rgba(255,23,68,.13);color:var(--bad);border:1px solid rgba(255,23,68,.27)}
.bsm.mute{background:rgba(255,170,0,.13);color:#ffaa00;border:1px solid rgba(255,170,0,.27)}
.bsm.del{background:rgba(255,23,68,.13);color:var(--bad)}.bsm.edit{background:rgba(100,100,255,.13);color:#8888ff}
.bsm.punish{background:rgba(255,23,68,.13);color:var(--bad)}.bsm.forgive{background:rgba(0,230,118,.13);color:var(--ok)}
.coinamt{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:5px;padding:3px 7px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.78rem;width:58px;outline:none}
.ev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:11px;margin-top:8px}
.ev-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:11px;padding:15px;text-align:center;transition:.2s}
.ev-card:hover{transform:translateY(-2px)}
.ev-card.party{border-color:rgba(255,0,255,.3);background:rgba(38,0,38,.35)}
.ev-card.gold{border-color:rgba(255,200,0,.3);background:rgba(32,22,0,.35)}
.ev-card.dark{border-color:rgba(120,120,120,.3);background:rgba(8,8,8,.4)}
.ev-card.blue{border-color:rgba(0,150,255,.3);background:rgba(0,11,32,.35)}
.ev-icon{font-size:1.8rem;margin-bottom:6px}
.ev-name{font-family:'Bebas Neue',cursive;font-size:1.02rem;letter-spacing:1.5px;margin-bottom:3px}
.ev-desc{font-size:.72rem;color:var(--muted);margin-bottom:10px;line-height:1.4}
.ev-btn{width:100%;padding:8px;border:none;border-radius:7px;font-family:'Bebas Neue',cursive;font-size:.93rem;letter-spacing:1.5px;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.ev-btn.pb{background:linear-gradient(135deg,#ff00ff,#cc00ff);color:#fff}.ev-btn.gb{background:linear-gradient(135deg,#ff8c00,#ffd700);color:#000}
.ev-btn.db{background:linear-gradient(135deg,#333,#555);color:#fff}.ev-btn.bb{background:linear-gradient(135deg,#0066cc,#00aaff);color:#fff}
.ev-btn:hover{filter:brightness(1.2);transform:translateY(-1px)}
.report-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:9px;padding:12px;margin-bottom:7px;transition:.15s}
.report-item:hover{background:rgba(255,255,255,.06)}
.rpt-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.rpt-reason{color:var(--text);font-size:.85rem}.rpt-acts{display:flex;gap:5px;margin-top:7px}
.code-row{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.code-nm{font-family:'JetBrains Mono',monospace;font-size:.83rem;color:var(--accent2);font-weight:700;min-width:95px}
.code-rew{font-size:.76rem;color:var(--muted);flex:1}.code-uses{font-size:.71rem;color:rgba(255,255,255,.32)}
.wf-tag{display:inline-flex;align-items:center;gap:4px;background:rgba(255,23,68,.13);border:1px solid rgba(255,23,68,.27);border-radius:20px;padding:3px 9px;font-size:.73rem;margin:3px;color:var(--bad)}
.wf-tag button{background:none;border:none;color:inherit;cursor:pointer}
.srv-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.srv-row-nm{flex:1;font-weight:600}.srv-row-meta{font-size:.74rem;color:var(--muted)}
.code-create-row{display:flex;gap:6px;flex-wrap:wrap;align-items:flex-end;margin-bottom:13px}
.code-inp{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-radius:7px;padding:7px 10px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.84rem;outline:none;transition:.2s}
.code-inp:focus{border-color:rgba(204,0,0,.5)}.code-inp.mono{font-family:'JetBrains Mono',monospace;text-transform:uppercase}
.code-create-btn{padding:8px 16px;border:none;border-radius:7px;background:linear-gradient(135deg,#cc0000,#880000);color:#fff;font-family:'Bebas Neue',cursive;font-size:.93rem;letter-spacing:2px;cursor:pointer;transition:.2s}
.code-create-btn:hover{box-shadow:0 4px 16px rgba(204,0,0,.4)}
.gift-inp{background:rgba(255,200,0,.07);border:1px solid rgba(255,200,0,.27);border-radius:7px;padding:8px 10px;color:#fff;font-family:'Rajdhani',sans-serif;font-size:.84rem;outline:none;transition:.2s}
.gift-inp:focus{border-color:rgba(255,200,0,.5)}
.gift-btn{padding:8px 16px;border:none;border-radius:7px;background:linear-gradient(135deg,#ff8c00,#ffd700);color:#000;font-family:'Bebas Neue',cursive;font-size:.93rem;letter-spacing:2px;cursor:pointer;transition:.2s;font-weight:700}
.wf-add-btn{padding:7px 12px;border:1px solid rgba(255,23,68,.27);border-radius:7px;background:rgba(255,23,68,.13);color:var(--bad);font-family:'Rajdhani',sans-serif;font-weight:700;cursor:pointer;transition:.15s}
.wf-add-btn:hover{background:rgba(255,23,68,.2)}
.ann-close-btn{padding:10px 26px;border:none;border-radius:9px;background:linear-gradient(135deg,#0066cc,#00aaff);color:#fff;font-family:'Bebas Neue',cursive;font-size:1.1rem;letter-spacing:2px;cursor:pointer;transition:.2s}
.ann-close-btn:hover{box-shadow:0 4px 20px rgba(0,150,255,.4)}

/* ── DEPOULE ── */
#dp-panel{padding:14px;text-align:center;transition:transform .15s}
#dp-panel.shaking{animation:dpS .4s}
@keyframes dpS{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.dp-entity{font-size:3.5rem;margin:7px 0;display:block;user-select:none;filter:drop-shadow(0 0 10px rgba(204,0,0,.3))}
.dp-mood{font-size:.86rem;color:var(--muted);font-style:italic;margin-bottom:13px;min-height:19px}
.dp-skull{font-size:1.4rem;opacity:.22;transition:.3s}
.dp-skull.rage{opacity:1;animation:skP .3s infinite alternate;filter:drop-shadow(0 0 10px #f00)}
@keyframes skP{from{transform:scale(1)}to{transform:scale(1.15)}}
.pet-btn{padding:13px 36px;border:none;border-radius:12px;font-family:'Bebas Neue',cursive;font-size:1.7rem;letter-spacing:3px;cursor:pointer;transition:all .15s;margin:7px auto;display:block;position:relative;overflow:hidden}
.pet-btn::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:.4s}
.pet-btn:hover::after{left:100%}
.pet-btn.green{background:linear-gradient(135deg,#006600,#009933);color:#fff;box-shadow:0 4px 20px rgba(0,153,51,.35)}
.pet-btn.red{background:linear-gradient(135deg,#880000,#cc0000);color:#fff;box-shadow:0 4px 20px rgba(204,0,0,.35)}
.pet-btn.green:hover{box-shadow:0 6px 28px rgba(0,200,65,.55);transform:scale(1.04)}
.pet-btn.red:hover{box-shadow:0 6px 28px rgba(204,0,0,.55);transform:scale(1.04)}
.pet-btn.rage-mode{animation:rgP .25s infinite alternate}
@keyframes rgP{from{filter:brightness(1) saturate(1)}to{filter:brightness(1.4) saturate(1.6)}}
.pet-hint{padding:7px 14px;border-radius:8px;font-size:.84rem;font-weight:600;margin:7px 0;min-height:32px;display:flex;align-items:center;justify-content:center;transition:.2s}
.pet-hint.good{background:rgba(0,210,65,.1);color:var(--ok);border:1px solid rgba(0,210,65,.2)}
.pet-hint.bad{background:rgba(204,0,0,.1);color:var(--bad);border:1px solid rgba(204,0,0,.2)}
.pet-hint.neutral{background:rgba(255,255,255,.04);color:var(--muted);border:1px solid rgba(255,255,255,.07)}
.pet-hint.jackpot-hint{background:rgba(255,200,0,.1);color:#ffcc00;border:1px solid rgba(255,200,0,.2);animation:jpP .5s infinite alternate}
@keyframes jpP{from{filter:brightness(1)}to{filter:brightness(1.3)}}
.pet-result{font-family:'Bebas Neue',cursive;font-size:1.9rem;letter-spacing:2px;min-height:37px;text-align:center;margin:3px 0}
.pet-result.win{color:var(--ok);text-shadow:0 0 20px rgba(0,230,118,.5)}.pet-result.lose{color:var(--bad);text-shadow:0 0 20px rgba(255,23,68,.5)}
.pet-result.jackpot{color:#ffcc00;animation:jpP .3s infinite alternate;font-size:2.1rem;text-shadow:0 0 20px rgba(255,200,0,.6)}
.dp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:10px 0}
.dp-stat{background:rgba(255,255,255,.04);border-radius:8px;padding:8px;text-align:center;border:1px solid rgba(255,255,255,.06)}
.dp-stat-val{display:block;font-family:'Bebas Neue',cursive;font-size:1.28rem;color:var(--accent2)}
.dp-stat-lbl{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.combo-wrap{background:rgba(255,255,255,.06);border-radius:20px;height:7px;margin:7px 0;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.combo-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:20px;transition:.35s;width:0;box-shadow:0 0 8px var(--accent)}
.combo-lbl{font-size:.71rem;color:var(--muted);text-align:center;margin-top:3px;min-height:15px}

/* ── PROFILE ── */
.prof-hdr{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.prof-av{width:66px;height:66px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;border:3px solid var(--accent);flex-shrink:0;box-shadow:var(--glow);font-weight:700}
.prof-nm{font-family:'Bebas Neue',cursive;font-size:1.7rem;letter-spacing:2px;color:var(--accent2)}
.prof-coins{font-size:1.02rem;color:#ffaa44;font-weight:700;margin-top:3px}
.prof-bdgs{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.prof-bdg{background:rgba(255,255,255,.06);border-radius:6px;padding:3px 7px;font-size:.74rem;border:1px solid rgba(255,255,255,.08)}

/* ── THEME SHOP ── */
.theme-shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:10px;margin-top:10px;max-height:420px;overflow-y:auto;padding-right:4px}
.theme-card{border-radius:12px;padding:13px 10px;cursor:pointer;text-align:center;border:2px solid rgba(255,255,255,.07);transition:all .2s cubic-bezier(.34,1.2,.64,1);background:rgba(255,255,255,.04);position:relative;overflow:hidden}
.theme-card::before{content:'';position:absolute;inset:0;opacity:0;transition:.2s;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent)}
.theme-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.theme-card:hover::before{opacity:1}
.theme-card.owned{border-color:rgba(0,230,118,.35)}
.theme-card.active-theme{border-color:var(--accent2);box-shadow:var(--glow)}
.theme-card.locked{opacity:.75;cursor:default}
.theme-card.locked:hover{transform:none;box-shadow:none}
.tc-dot{width:28px;height:28px;border-radius:50%;margin:0 auto 7px;box-shadow:0 2px 10px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.15)}
.tc-name{font-family:'Bebas Neue',cursive;font-size:.95rem;letter-spacing:1px;margin-bottom:3px;color:var(--text)}
.tc-rarity{font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;margin-bottom:5px}
.rarity-free{color:rgba(255,255,255,.45)}.rarity-common{color:#88ccff}.rarity-rare{color:#aa55ff}
.rarity-epic{color:#ff8800}.rarity-legendary{font-size:.65rem;background:linear-gradient(90deg,#ff00ff,#ffff00,#00ffff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:prismaticShift 2s linear infinite;background-size:300% 100%}
@keyframes prismaticShift{0%{background-position:0% 50%}100%{background-position:300% 50%}}
.tc-price{font-family:'Bebas Neue',cursive;font-size:.9rem;color:#ffaa44}
.tc-price.owned{color:var(--ok);font-size:.82rem}.tc-price.active{color:var(--accent2)}
.tc-buy-btn{margin-top:6px;width:100%;padding:5px;border:none;border-radius:6px;font-family:'Bebas Neue',cursive;font-size:.82rem;letter-spacing:1px;cursor:pointer;transition:.2s}
.tc-buy-btn.buy{background:linear-gradient(135deg,#cc0000,#880000);color:#fff}
.tc-buy-btn.buy:hover{box-shadow:0 3px 12px rgba(204,0,0,.4)}
.tc-buy-btn.equip{background:rgba(0,230,118,.15);color:var(--ok);border:1px solid rgba(0,230,118,.3)}
.tc-buy-btn.equip:hover{background:rgba(0,230,118,.25)}
.tc-buy-btn.equipped{background:rgba(255,255,255,.06);color:var(--muted);cursor:default;font-size:.78rem}
.tc-buy-btn.locked-btn{background:rgba(255,255,255,.04);color:var(--muted);cursor:not-allowed;font-size:.78rem}
.theme-filter-tabs{display:flex;gap:5px;margin-bottom:12px;flex-wrap:wrap}
.tft{padding:5px 11px;border:none;border-radius:6px;background:rgba(255,255,255,.06);color:var(--muted);cursor:pointer;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.8px;transition:.15s}
.tft.on{background:rgba(204,0,0,.25);color:#fff;border:1px solid rgba(204,0,0,.3)}
.tft:hover:not(.on){background:rgba(255,255,255,.1);color:var(--text)}

/* ── EVENTS ── */
#party-overlay{display:none;position:fixed;inset:0;z-index:99990;pointer-events:none;overflow:hidden}
#party-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Bebas Neue',cursive;font-size:clamp(2rem,7vw,5rem);letter-spacing:6px;color:#fff;text-shadow:0 0 30px #ff0,0 0 60px #f0f,0 0 100px #0ff;text-align:center;animation:ptP 1s ease-in-out infinite alternate;pointer-events:none}
@keyframes ptP{from{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-50%) scale(1.06)}}
#party-timer{position:absolute;top:18px;right:20px;font-family:'Bebas Neue',cursive;font-size:1.3rem;color:rgba(255,255,255,.7);letter-spacing:2px;text-shadow:0 0 10px rgba(255,255,0,.5)}
#blackout-overlay{display:none;position:fixed;inset:0;z-index:99995;background:#000;pointer-events:none;opacity:0;transition:opacity .5s}
#blackout-txt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',cursive;font-size:clamp(2rem,6vw,4rem);letter-spacing:6px;color:#ff1111;text-shadow:0 0 40px #f00,0 0 80px #f00;opacity:0;transition:opacity 1s;text-align:center}
#announce-overlay{display:none;position:fixed;inset:0;z-index:99992;background:rgba(0,0,0,.87);backdrop-filter:blur(10px);align-items:center;justify-content:center}
.ann-box{background:linear-gradient(160deg,rgba(0,20,40,.95),rgba(0,10,25,.98));border:2px solid rgba(0,200,255,.35);border-radius:16px;max-width:500px;width:92%;padding:32px;text-align:center;box-shadow:0 0 80px rgba(0,150,255,.3),inset 0 1px 0 rgba(255,255,255,.07);animation:anIn .4s ease}
@keyframes anIn{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ── CONTEXT MENU ── */
#ctx-menu{position:fixed;background:linear-gradient(160deg,rgba(20,0,0,.97),rgba(10,0,0,.98));border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:5px 0;z-index:8000;display:none;min-width:155px;box-shadow:0 12px 36px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04);backdrop-filter:blur(20px)}
.ctx-item{padding:8px 14px;cursor:pointer;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;transition:.1s;color:rgba(255,255,255,.76)}
.ctx-item:hover{background:rgba(255,255,255,.08);color:#fff}.ctx-item.danger{color:var(--bad)}.ctx-item.danger:hover{background:rgba(255,23,68,.12)}
.ctx-sep{height:1px;background:rgba(255,255,255,.07);margin:3px 0}

/* ── MISC ── */
.empty{color:var(--muted);font-size:.84rem;font-style:italic;padding:14px 0;text-align:center}
.pill{display:inline-block;padding:2px 7px;border-radius:20px;font-size:.68rem;font-weight:700}
.pill.on{background:rgba(0,230,118,.13);color:var(--ok)}.pill.off{background:rgba(100,100,100,.17);color:#666}
.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%);
  background:rgba(10,0,0,.96);border:1px solid rgba(204,0,0,.4);border-radius:10px;
  padding:11px 22px;color:#fff;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:.93rem;
  z-index:9999;animation:tIn .25s ease;pointer-events:none;max-width:78vw;text-align:center;
  backdrop-filter:blur(16px);box-shadow:0 8px 24px rgba(0,0,0,.6),var(--glow2);}
@keyframes tIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.22)}
@media(max-width:768px){#app{grid-template-columns:56px 1fr}#ch-sidebar{position:fixed;left:56px;top:0;bottom:0;width:205px;z-index:100;transform:translateX(-100%);transition:.25s}#ch-sidebar.open{transform:translateX(0)}#members-bar{display:none}}
