/* ─── Reset & tokens ──────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0c0c14;--sb:#10111a;--panel:#131420;--card:#181928;--hover:#1e1f30;
  --inp:#151622;--b:rgba(255,255,255,.06);--bm:rgba(255,255,255,.10);
  --ac:#6c5ce7;--as:rgba(108,92,231,.10);--ab:rgba(108,92,231,.28);
  --green:#00d2a0;--yellow:#fdcb6e;--red:#ff6b6b;--blue:#74b9ff;
  --purple:#a29bfe;--pink:#fd79a8;--tx:#eef0ff;--sub:#b0b2cc;--mu:#5a5b78;
}
html,body{margin:0;padding:0;height:100%;overflow:hidden}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--tx);font-size:13px}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
input::placeholder{color:var(--mu)}button{font-family:inherit;cursor:pointer}

/* ─── Views ────────────────────────────────────────────────────────────────── */
.view{display:none;height:100%}.view.active{display:flex}

/* ─── Login ────────────────────────────────────────────────────────────────── */
#vL{background:radial-gradient(ellipse at 25% 50%,rgba(108,92,231,.16),transparent 55%),radial-gradient(ellipse at 78% 18%,rgba(162,155,254,.09),transparent 45%),var(--bg);align-items:center;justify-content:center;flex-direction:column}
.lw{width:340px;max-width:92vw;animation:fadeUp .35s ease}
.l-brand{display:flex;align-items:center;gap:12px;margin-bottom:5px}
.l-ico{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--ac),var(--purple));display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;box-shadow:0 6px 24px rgba(108,92,231,.4);flex-shrink:0}
.l-name{font-size:34px;font-weight:900;letter-spacing:-1.5px}
.l-sub{color:var(--mu);font-size:10px;letter-spacing:.7px;text-transform:uppercase;margin-bottom:28px;padding-left:60px}
.l-card{background:var(--card);border:1px solid var(--bm);border-radius:16px;padding:24px}
.lbl{font-size:10px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.6px;margin-bottom:7px}
.inp{width:100%;background:var(--inp);border:1px solid var(--b);border-radius:9px;padding:11px 14px;color:var(--tx);font-size:14px;outline:none;transition:border .2s;margin-bottom:14px}.inp:focus{border-color:var(--ab)}
.btn-p{width:100%;padding:11px;background:linear-gradient(135deg,var(--ac),var(--purple));color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;margin-bottom:8px;box-shadow:0 4px 20px rgba(108,92,231,.35);transition:opacity .2s}.btn-p:hover{opacity:.88}
.btn-g{width:100%;padding:10px;background:transparent;color:var(--sub);border:1px solid var(--b);border-radius:9px;font-size:12px;transition:all .2s}.btn-g:hover{border-color:var(--ab);color:var(--tx)}

/* ─── Chat layout ──────────────────────────────────────────────────────────── */
#vChat{flex-direction:row;overflow:hidden}

/* ─── Left sidebar ─────────────────────────────────────────────────────────── */
.lsb{width:280px;background:var(--sb);border-right:1px solid var(--b);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s}
.lsb.collapsed{width:0;overflow:hidden;border:none}
.lsb-hdr{padding:14px 14px 10px;border-bottom:1px solid var(--b);flex-shrink:0}
.lsb-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.lsb-ico{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--ac),var(--purple));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:#fff;box-shadow:0 4px 14px rgba(108,92,231,.4);flex-shrink:0}
.lsb-bname{font-weight:800;font-size:15px;letter-spacing:-.4px}
.lsb-bsub{font-size:9px;color:var(--mu);text-transform:uppercase;letter-spacing:.5px}
.lsb-globe{width:28px;height:28px;border-radius:7px;margin-left:auto;border:1px solid var(--b);background:transparent;color:var(--sub);font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.lsb-globe:hover{border-color:var(--ab);background:var(--as);color:var(--ac)}
.lsb-srch{display:flex;align-items:center;gap:7px;background:var(--inp);border-radius:8px;padding:6px 10px;border:1px solid var(--b)}
.lsb-srch-ico{color:var(--mu);font-size:12px}.lsb-srch-inp{background:transparent;border:none;outline:none;font-size:11px;color:var(--sub);width:100%}
.tabs{display:flex;gap:4px;padding:8px 10px 4px;flex-shrink:0}
.tab{flex:1;padding:6px 0;font-size:10px;font-weight:700;border-radius:8px;border:1px solid var(--b);background:transparent;color:var(--mu);transition:all .15s;position:relative}
.tab.on{border-color:var(--ab);background:var(--as);color:var(--ac)}
.ubadge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:8px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;border:2px solid var(--sb)}
.lsb-list{flex:1;overflow-y:auto;padding:6px 10px;display:flex;flex-direction:column;min-height:0;-webkit-overflow-scrolling:touch}
.explore-more{width:100%;margin-top:6px;padding:7px 0;border-radius:9px;border:1px dashed var(--b);background:transparent;color:var(--mu);font-size:11px;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;flex-shrink:0}
.explore-more:hover{border-color:var(--ab);color:var(--sub)}

/* ─── Sort bar ──────────────────────────────────────────────────────────────── */
.sort-bar{display:flex;gap:4px;padding:2px 0 8px;flex-shrink:0;flex-wrap:wrap}
.sort-btn{padding:3px 9px;border-radius:6px;border:1px solid var(--b);background:transparent;color:var(--mu);font-size:10px;font-weight:600;transition:all .12s;white-space:nowrap}
.sort-btn.on{border-color:var(--ab);background:var(--as);color:var(--ac)}
.sort-btn:hover{border-color:var(--bm);color:var(--sub)}

/* ─── Room item ────────────────────────────────────────────────────────────── */
.ri{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:all .14s;margin-bottom:2px}
.ri:hover{background:var(--hover)}.ri.on{background:var(--as);border-color:var(--ab)}
.ri-av{border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;color:#fff}
.ri-name{font-size:13px;font-weight:600;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ri.on .ri-name{font-weight:700;color:var(--tx)}
.ri-desc{font-size:11px;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;margin-bottom:2px}
.ri-meta{font-size:10px;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:4px}
.ri-mdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.ri-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;margin-left:auto}
.ri-unread{min-width:18px;height:18px;border-radius:9px;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(108,92,231,.5);padding:0 5px}
.ri-fav-btn{font-size:14px;cursor:pointer;opacity:.4;transition:opacity .15s;line-height:1}
.ri-fav-btn:hover{opacity:1}
.ri:hover .ri-fav-btn{opacity:.7}

/* ─── PM item ──────────────────────────────────────────────────────────────── */
.pi{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:all .14s;margin-bottom:2px;position:relative}
.pi:hover{background:var(--hover)}.pi.on{background:var(--as);border-color:var(--ab)}
.pi-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;background-size:cover;background-position:center}
.pi-nick{font-size:13px;font-weight:600}
.pi-preview{font-size:11px;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.pm-room-tag{display:inline-flex;align-items:center;font-size:9px;font-weight:700;padding:1px 6px;border-radius:4px;flex-shrink:0;margin-top:2px}
.pm-unread-badge{min-width:18px;height:18px;border-radius:9px;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(108,92,231,.5)}
.pi-close{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:transparent;border:1px solid transparent;color:var(--mu);font-size:11px;line-height:1;display:none;align-items:center;justify-content:center;transition:all .15s;padding:0}
.pi:hover .pi-close{display:flex}.pi-close:hover{background:rgba(255,107,107,.15);border-color:rgba(255,107,107,.3);color:var(--red)}

/* ─── Sidebar footer ──────────────────────────────────────────────────────── */
.lsb-foot{padding:10px 14px;border-top:1px solid var(--b);display:flex;align-items:center;gap:9px;flex-shrink:0}
.my-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;font-size:13px;position:relative;background-size:cover;background-position:center;cursor:pointer}
.my-av::after{content:'';position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;background:var(--green);border:2px solid var(--sb);box-shadow:0 0 6px rgba(0,210,160,.6)}
.my-name{font-size:12px;font-weight:600}.my-status{font-size:10px;color:var(--green);display:flex;align-items:center;gap:4px;margin-top:1px}
.my-dot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 5px var(--green)}
.gear{color:var(--mu);font-size:14px;cursor:pointer;margin-left:auto}

/* ─── Main ─────────────────────────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}

/* ─── Topbar ───────────────────────────────────────────────────────────────── */
.ctb{height:52px;background:var(--panel);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 12px;gap:8px;flex-shrink:0}
.conn-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:all .3s}
.conn-dot.on{background:var(--green);box-shadow:0 0 8px rgba(0,210,160,.6)}.conn-dot.off{background:var(--red);box-shadow:0 0 8px rgba(255,107,107,.5)}
.ctb-ham{width:32px;height:32px;border-radius:8px;border:1px solid var(--b);background:transparent;color:var(--sub);font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ctb-ham:hover{border-color:var(--ab);background:var(--as);color:var(--ac)}
.ctb-back{display:none;background:transparent;border:none;color:var(--sub);font-size:24px;flex-shrink:0;line-height:1;padding:2px 4px}
.ctb-back:hover{color:var(--tx)}
.ctb-av{border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0;width:32px;height:32px;font-size:13px}
.ctb-info-wrap{flex:1;min-width:0;overflow:hidden}
.ctb-name{font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ctb-topic{color:#9a9bc0;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rtb{width:30px;height:30px;border-radius:8px;border:1px solid var(--b);background:transparent;color:var(--sub);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.rtb.on{border-color:var(--ab);background:var(--as);color:var(--ac)}
.rtb-close{color:var(--sub)}.rtb-close:hover{border-color:rgba(255,107,107,.4);color:var(--red);background:rgba(255,107,107,.08)}

/* ─── Right panel ──────────────────────────────────────────────────────────── */
.rp{width:220px;background:var(--sb);border-left:1px solid var(--b);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s,border .2s}
.rp.collapsed{width:0;overflow:hidden;border:none}
.rp-hdr{padding:12px 12px 8px;border-bottom:1px solid var(--b);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}
.rp-title{font-weight:700;font-size:12px;color:var(--tx)}.rp-sub{font-size:10px;color:var(--sub);margin-top:2px}
.rp-close-btn{display:none;width:24px;height:24px;border-radius:6px;border:1px solid var(--b);background:transparent;color:var(--mu);font-size:12px;align-items:center;justify-content:center}
.rp-close-btn:hover{border-color:rgba(255,107,107,.4);color:var(--red)}
.rp-body{flex:1;overflow-y:auto;padding:4px 8px;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}
.ug-lbl{font-size:9px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.7px;padding:8px 6px 4px}
.su{display:flex;align-items:center;gap:8px;padding:6px 6px;border-radius:8px;transition:background .1s}
.su:hover{background:var(--hover)}
.su-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;position:relative;background-size:cover;background-position:center;cursor:pointer;transition:transform .12s}
.su-av:active{transform:scale(.9)}
.su-dot{position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;border-radius:50%;background:var(--green);border:2px solid var(--sb)}
.su-name{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--sub)}
.su-pmsg{font-size:10px;color:var(--mu);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.info-room-av{border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0}
.info-block{background:var(--card);border:1px solid var(--b);border-radius:10px;padding:12px;margin-bottom:8px}
.info-label{font-size:9px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px}
.info-value{font-size:13px;color:var(--sub);line-height:1.5;word-break:break-word}
.info-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.info-stat{background:var(--hover);border-radius:8px;padding:8px 10px}
.info-stat-n{font-size:18px;font-weight:800;color:var(--tx)}.info-stat-l{font-size:10px;color:var(--sub);margin-top:1px}

/* ─── Messages ─────────────────────────────────────────────────────────────── */
.msgs{flex:1;overflow-y:auto;padding:10px 0;min-height:0}
.mr{display:flex;gap:11px;padding:2px 16px;transition:background .1s}.mr:hover{background:rgba(255,255,255,.02)}
.mav{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px;background-size:cover;background-position:center}
.mav-g{flex-shrink:0}
.mb{flex:1;min-width:0}.mh{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.mn{font-weight:700;font-size:13px}.mt{font-size:10px;color:var(--mu)}
.mtx{font-size:13px;color:var(--sub);line-height:1.65;word-break:break-word}
.mr.sys .mtx{color:#8a8baa;font-style:italic;font-size:12px;padding-left:47px;padding-top:2px}
.mr.pm-in{background:rgba(253,121,168,.04)}.mr.pm-in .mn{color:var(--pink)}.mr.pm-in .mtx{color:rgba(253,121,168,.9)}
.mr.emote .mtx{color:var(--blue);font-style:italic}
.mr.join .mtx{color:rgba(0,210,160,.75);font-size:11px;padding-left:47px;padding-top:1px}
.mr.part .mtx{color:rgba(255,107,107,.75);font-size:11px;padding-left:47px;padding-top:1px}

/* ─── Desktop chat input ──────────────────────────────────────────────────── */
.ci-area{flex-shrink:0}
.ci-desktop{background:var(--panel);border-top:1px solid var(--b);padding:12px 16px}
.ci-box{background:var(--inp);border:1px solid var(--bm);border-radius:12px;transition:border .2s}.ci-box:focus-within{border-color:var(--ab)}
.ci-row{padding:9px 14px;display:flex;align-items:center;gap:10px}
.ci-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;background-size:cover;background-position:center;width:26px;height:26px}
.ci-inp{flex:1;background:transparent;border:none;outline:none;color:var(--tx);font-size:13px;font-family:inherit}
.ci-send{background:linear-gradient(135deg,var(--ac),var(--purple));color:#fff;border:none;border-radius:8px;padding:7px 16px;font-size:12px;font-weight:700;flex-shrink:0;box-shadow:0 4px 14px rgba(108,92,231,.35);transition:opacity .2s}.ci-send:hover{opacity:.88}
.ci-hint{padding:4px 14px 7px;border-top:1px solid var(--b);font-size:10px;color:var(--sub);display:flex;gap:8px}.dot-sep{color:var(--mu)}

/* ─── Mobile pill input (hidden on desktop) ────────────────────────────────── */
.ci-mobile{display:none}

/* ─── PM ───────────────────────────────────────────────────────────────────── */
.pm-hdr-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;width:32px;height:32px;font-size:14px;background-size:cover;background-position:center}
.pm-bw{display:flex;padding:2px 16px;align-items:flex-end;gap:6px}.pm-bw.me{justify-content:flex-end}
.pm-bubble{max-width:68%;padding:9px 13px;font-size:13px;line-height:1.55;word-break:break-word}
.pm-bubble.them{background:var(--card);border:1px solid var(--b);border-radius:14px 14px 14px 3px;color:var(--sub)}
.pm-bubble.me{background:linear-gradient(135deg,var(--ac),var(--purple));border-radius:14px 14px 3px 14px;color:#fff;box-shadow:0 4px 18px rgba(108,92,231,.35)}
.pm-ts{font-size:9px;color:var(--mu);padding:0 4px;align-self:flex-end;flex-shrink:0}

/* ─── Explore ──────────────────────────────────────────────────────────────── */
.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);z-index:50;display:none;flex-direction:column}.overlay.open{display:flex}
.ov-bar{height:52px;background:var(--panel);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 18px;gap:10px;flex-shrink:0}
.ov-title{font-weight:800;font-size:14px;flex:1}
.pill{background:var(--ac);color:#fff;font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px;cursor:pointer}.pill:hover{opacity:.8}
.ov-close{width:auto;padding:5px 14px}
.ov-srch{padding:11px 18px;background:var(--panel);border-bottom:1px solid var(--b);flex-shrink:0}
.ov-inp{width:100%;background:var(--inp);border:1px solid var(--b);border-radius:9px;padding:9px 14px;color:var(--tx);font-size:12px;outline:none}.ov-inp:focus{border-color:var(--ab)}
.ov-list{flex:1;overflow-y:auto;padding:12px 18px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;align-content:start}
.ch-card{background:var(--card);border:1px solid var(--b);border-radius:14px;padding:16px;cursor:pointer;display:flex;flex-direction:column;transition:border .18s,box-shadow .18s}
.ch-card:hover{border-color:var(--ab);box-shadow:0 4px 24px rgba(108,92,231,.12)}
.ch-top{display:flex;gap:12px;margin-bottom:12px}.ch-info{flex:1;min-width:0}
.ch-av{border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0}
.ch-name{font-weight:700;font-size:14px;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px}
.ch-topic{color:var(--sub);font-size:11px;line-height:1.45;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ch-mid{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.ch-act{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600}.ch-adot{width:5px;height:5px;border-radius:50%}
.ch-users-count{font-size:11px;color:var(--sub)}
.ch-join-btn{width:100%;padding:8px;border-radius:9px;border:1px solid;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;background:transparent}.ch-join-btn:hover{opacity:.85}

/* ─── User context menu ────────────────────────────────────────────────────── */
.usr-menu-bg{display:none;position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.45)}
.usr-menu-bg.show{display:block}
.usr-menu{display:none;position:fixed;z-index:61;background:#1c1d2e;border:1px solid var(--bm);border-radius:14px;width:200px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.7)}
.usr-menu.show{display:block}
.usr-menu-hdr{padding:12px 14px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:10px}
.usr-menu-hdr-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:14px;flex-shrink:0;background-size:cover;background-position:center}
.usr-menu-hdr-name{font-weight:700;font-size:13px;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.usr-menu-hdr-sub{font-size:10px;color:var(--mu)}
.usr-menu-opts{padding:4px}
.usr-menu-opt{width:100%;display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--sub);font-size:12px;text-align:left;transition:background .12s}
.usr-menu-opt:hover{background:var(--hover)}
.usr-menu-opt.accent{color:var(--ac);font-weight:700}
.usr-menu-opt.accent:hover{background:var(--as)}

/* ─── Avatar lightbox ──────────────────────────────────────────────────────── */
.av-lightbox{display:none;position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.8);backdrop-filter:blur(6px);align-items:center;justify-content:center;flex-direction:column}
.av-lightbox.show{display:flex}
.av-lb-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;position:relative}
.av-lb-img{width:200px;height:200px;border-radius:50%;background-size:cover;background-position:center;border:3px solid var(--ab);box-shadow:0 0 60px rgba(108,92,231,.3)}
.av-lb-name{font-weight:800;font-size:18px;color:var(--tx)}
.av-lb-close{position:absolute;top:-40px;right:-40px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center}

/* ─── Mobile screens (hidden on desktop) ───────────────────────────────────── */
.mob-screen{display:none;flex-direction:column;overflow:hidden}
.mob-screen-hdr{padding:15px 14px 12px;background:var(--panel);border-bottom:1px solid var(--b);flex-shrink:0}
.mob-screen-title{font-weight:800;font-size:16px}
.mob-profile-body{flex:1;overflow-y:auto}
.mob-profile-banner{height:80px;background:linear-gradient(135deg,rgba(108,92,231,.4),rgba(162,155,254,.3))}
.mob-profile-info{padding:0 16px;margin-top:-24px}
.mob-profile-av{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:22px;background-size:cover;background-position:center;border:3px solid var(--sb);position:relative}
.mob-profile-av::after{content:'';position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;background:var(--green);border:2px solid var(--sb)}
.mob-profile-name{font-weight:800;font-size:20px;margin-top:10px}
.mob-profile-status{font-size:12px;color:var(--green);display:flex;align-items:center;gap:5px;margin-top:4px}
.mob-profile-opts{padding:20px 16px}
.mob-profile-opt{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--b);cursor:pointer}
.mob-profile-opt span:first-child{width:34px;height:34px;border-radius:10px;background:var(--card);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.mob-profile-opt span:nth-child(2){flex:1;font-size:13px;color:var(--sub)}
.mob-opt-val{font-size:12px;color:var(--ac)}
.mob-nav{display:none;border-top:1px solid var(--b);background:var(--sb);flex-shrink:0;position:relative;z-index:55}
.mob-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;padding:9px 0 7px;background:none;border:none;gap:3px;position:relative;color:var(--mu)}
.mob-nav-btn.on{color:var(--ac)}
.mob-nav-btn.on::before{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:linear-gradient(90deg,var(--ac),var(--purple));border-radius:2px}
.mob-nav-ico{font-size:20px}.mob-nav-lbl{font-size:9px;font-weight:600}
.mob-nav-badge{position:absolute;top:4px;right:12%;min-width:16px;height:16px;border-radius:8px;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;padding:0 3px;box-shadow:0 0 8px rgba(108,92,231,.5);border:2px solid var(--sb)}
.mob-rp-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);z-index:39;touch-action:none}
.mob-rp-overlay.show{display:block}

/* ─── Modal ─────────────────────────────────────────────────────────────────── */
.modal-bg{display:none;position:fixed;inset:0;z-index:72;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.modal-bg.show{display:block}
.modal{display:none;position:fixed;z-index:73;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;max-width:90vw;background:var(--card);border:1px solid var(--bm);border-radius:16px;padding:24px;box-shadow:0 24px 64px rgba(0,0,0,.7)}
.modal.show{display:block}
.modal-title{font-weight:800;font-size:16px;color:var(--tx);margin-bottom:4px}
.modal-sub{font-size:11px;color:var(--mu);margin-bottom:16px}
.modal-inp{width:100%;background:var(--inp);border:1px solid var(--b);border-radius:9px;padding:11px 14px;color:var(--tx);font-size:14px;outline:none;transition:border .2s;font-family:inherit}
.modal-inp:focus{border-color:var(--ab)}
.modal-btns{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}
.modal-btn-cancel{padding:8px 18px;border-radius:8px;border:1px solid var(--b);background:transparent;color:var(--sub);font-size:13px;font-weight:600;transition:all .15s}
.modal-btn-cancel:hover{border-color:var(--bm);color:var(--tx)}
.modal-btn-ok{padding:8px 22px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--ac),var(--purple));color:#fff;font-size:13px;font-weight:700;box-shadow:0 4px 14px rgba(108,92,231,.35);transition:opacity .15s}
.modal-btn-ok:hover{opacity:.88}

/* ─── Mobile explore rows (rendered by JS, not CSS override) ───────────────── */
.exp-row{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--card);border:1px solid var(--b);border-radius:12px;cursor:pointer;transition:border .15s;overflow:hidden;min-height:64px}
.exp-row:active{border-color:var(--ab);background:var(--hover)}
.exp-row-av{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0}
.exp-row-info{flex:1;min-width:0;overflow:hidden}
.exp-row-name{font-weight:700;font-size:14px;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}
.exp-row-meta{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600}
.exp-row-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.exp-row-users{color:var(--mu);margin-left:2px}

/* ─── Utilities ────────────────────────────────────────────────────────────── */
.empty-state{padding:30px 10px;text-align:center;color:var(--sub);font-size:12px;line-height:1.6;grid-column:1/-1}
.empty-ico{font-size:28px;margin-bottom:10px}.code{color:var(--ac)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ═════════════════════════════════════════════════════════════════════════════ */
/* ═══ MOBILE ══════════════════════════════════════════════════════════════════ */
/* ═════════════════════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* ── Core container ── */
  #vChat{flex-direction:column;overflow:hidden;height:100%}

  /* ── Hide desktop-only ── */
  .ctb-ham{display:none}
  .ci-desktop{display:none}
  .ci-mobile{display:block}

  /* ── Sidebar: full-screen tab, hidden by default ── */
  .lsb{display:none;width:100%;border:none;flex:1;min-height:0;overflow:hidden}
  .lsb.mob-active{display:flex}
  .lsb.mob-active .lsb-foot{display:none}

  /* ── Main chat: hidden by default ── */
  #vChat>.main{display:none !important;min-height:0;overflow:hidden}
  #vChat>.main.mob-active{display:flex !important;flex:1}

  /* ── Mobile screens ── */
  .mob-screen.mob-active{display:flex;flex:1;min-height:0}

  /* ── Right panel: slide-in from right ── */
  .rp{display:none;position:fixed;top:0;right:0;bottom:48px;width:82%;z-index:42;box-shadow:-14px 0 40px rgba(0,0,0,.6);overscroll-behavior:contain}
  .rp.mob-open{display:flex}
  .rp-close-btn{display:flex}

  /* ── Bottom nav: always visible ── */
  .mob-nav{display:flex}

  /* ── Topbar mobile ── */
  .ctb{padding:0 10px;gap:6px;height:48px}
  .ctb-back{display:flex}
  .ctb-back-pm{display:flex}
  .ctb-name{font-size:13px}
  .ctb-topic{font-size:10px}

  /* ── Mobile pill input ── */
  .ci-mobile{padding:8px 10px;background:var(--panel);border-top:1px solid var(--b)}
  .ci-pill{display:flex;align-items:center;gap:8px;background:var(--inp);border-radius:24px;padding:8px 8px 8px 16px;border:1px solid var(--bm)}
  .ci-pill:focus-within{border-color:var(--ab)}
  .ci-pill-inp{flex:1;background:transparent;border:none;outline:none;color:var(--tx);font-size:13px;font-family:inherit;min-width:0}
  .ci-pill-send{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--purple));border:none;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(108,92,231,.5)}
  .ci-pill-send:active{transform:scale(.92)}

  /* ── Messages mobile ── */
  .mr{padding:2px 10px}
  .mr.sys .mtx,.mr.join .mtx,.mr.part .mtx{padding-left:0}
  .pm-bubble{max-width:85%}

  /* ── PM close always visible (touch) ── */
  .pi-close{display:flex}

  /* ── Explore: compact list, not cards ── */
  .overlay{bottom:48px}
  .ov-bar{padding:0 12px;height:48px}
  .ov-srch{padding:8px 12px}
  .ov-list{grid-template-columns:1fr;padding:6px 10px;gap:6px}
  .ch-card{padding:10px 12px;border-radius:12px;flex-direction:row;align-items:center;gap:12px}
  .ch-top{margin-bottom:0;flex:1;min-width:0;display:flex;gap:10px;align-items:center}
  .ch-av{flex-shrink:0}
  .ch-info{flex:1;min-width:0}
  .ch-name{font-size:13px;margin-bottom:1px}
  .ch-topic{font-size:10px}
  .ch-mid{display:none}
  .ch-join-btn{width:auto;padding:5px 12px;font-size:11px;flex-shrink:0;white-space:nowrap;border-radius:7px}

  /* ── Login mobile ── */
  .l-name{font-size:28px}
  .l-sub{padding-left:48px}

  /* ── Lightbox mobile ── */
  .av-lb-close{top:-36px;right:0px}
  .av-lightbox .av-lb-wrap .av-lb-img{width:180px;height:180px}

  /* ── Modal mobile ── */
  .modal{width:auto;left:16px;right:16px;transform:translate(0,-50%)}

  /* ── Userlist avatar bigger for touch ── */
  .su-av{min-width:36px;min-height:36px}
  .su{padding:8px 6px}

  /* ── User menu: bottom sheet ── */{bottom:48px;left:10px;right:10px;width:auto;top:auto;border-radius:14px 14px 0 0;position:fixed}
}

/* ═════════════════════════════════════════════════════════════════════════════ */
/* ═══ DESKTOP ONLY ════════════════════════════════════════════════════════════ */
/* ═════════════════════════════════════════════════════════════════════════════ */
@media(min-width:769px){
  .ctb-back{display:none !important}
  .ctb-back-pm{display:flex !important}
  .mob-nav{display:none !important}
  .mob-screen{display:none !important}
  .mob-rp-overlay{display:none !important}
  .ci-mobile{display:none !important}
}
