

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:      #000;
  --s1:      #0c0c0c;
  --s2:      #111;
  --s3:      #181818;
  --s4:      #1f1f1f;
  --bdr:     #1c1c1c;
  --bdr2:    #282828;
  --txt:     #e8eaf0;
  --txt2:    #7a8099;
  --dim:     #3a3d50;
  --purple:  #7c5cfc;
  --purple2: #9b7dff;
  --purplebg:#7c5cfc18;
  --purplebr:#7c5cfc55;
  --gold:    #f0a500;
  --goldbg:  #f0a50015;
  --goldbr:  #f0a50045;
  --green:   #3dd68c;
  --greenbg: #3dd68c15;
  --greenbr: #3dd68c45;
  --red:     #f25858;
  --redbg:   #f2585815;
  --redbr:   #f2585845;
  --font:    'Inter',sans-serif;
  --nav-w:   224px;
  --ease:    cubic-bezier(.22,1,.36,1);
  --r:       10px;
}

html,body{height:100%;overflow:hidden}
body{background:var(--bg);color:var(--txt);font-family:var(--font);font-size:13px;line-height:1.5}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:#333}

/* ══════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════ */
#screen-auth{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  background:#000;overflow:hidden;
}
.auth-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url('https://images8.alphacoders.com/578/578156.jpg');
  background-size:cover;background-position:center 55%;
  opacity:.70;filter:brightness(.42) saturate(.75);
}
.auth-vignette{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 130% 55% at 50% 100%,rgba(0,0,0,.98) 0%,transparent 65%),
    radial-gradient(ellipse 100% 40% at 50% 0%,  rgba(0,0,0,.80) 0%,transparent 55%),
    radial-gradient(ellipse 60%  100% at 0%  50%,rgba(0,0,0,.50) 0%,transparent 60%),
    radial-gradient(ellipse 60%  100% at 100% 50%,rgba(0,0,0,.50) 0%,transparent 60%);
}
.auth-orb1{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,252,.09) 0%,transparent 70%);
  top:-150px;left:-150px;z-index:2;pointer-events:none;
  animation:aorb1 9s ease-in-out infinite alternate;
}
.auth-orb2{
  position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(240,165,0,.06) 0%,transparent 70%);
  bottom:-80px;right:-80px;z-index:2;pointer-events:none;
  animation:aorb2 11s ease-in-out infinite alternate;
}
@keyframes aorb1{to{transform:translate(80px,50px)}}
@keyframes aorb2{to{transform:translate(-50px,-40px)}}

.auth-card{
  position:relative;z-index:3;
  width:100%;max-width:430px;
  background:rgba(8,8,8,.94);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:36px 32px;
  box-shadow:0 30px 90px rgba(0,0,0,.9),0 0 0 1px rgba(124,92,252,.07),inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(24px);
  animation:slideUp .4s var(--ease) both;
}
@keyframes slideUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

.auth-logo{display:flex;align-items:center;gap:11px;margin-bottom:5px}
.auth-logo-icon{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--purple),#4e20e0);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 24px rgba(124,92,252,.35);
}
.auth-logo-text{font-size:21px;font-weight:800;color:var(--txt)}
.auth-logo-text span{color:var(--purple2)}
.auth-tagline{font-size:11.5px;color:var(--txt2);margin-bottom:24px;letter-spacing:.2px}

.tabs{display:flex;background:rgba(0,0,0,.55);border:1px solid var(--bdr2);border-radius:9px;padding:3px;margin-bottom:22px;gap:3px}
.tab{flex:1;height:33px;border-radius:7px;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--dim);border:none;background:none;transition:all .2s var(--ease)}
.tab.on{background:var(--s3);color:var(--txt);box-shadow:0 2px 8px rgba(0,0,0,.5)}

/* avatar upload */
.av-upload-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:18px}
.av-upload-ring{
  width:72px;height:72px;border-radius:50%;
  background:var(--s3);border:2px dashed var(--bdr2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;overflow:hidden;position:relative;
  transition:border-color .2s,box-shadow .2s;
}
.av-upload-ring:hover{border-color:var(--purplebr);box-shadow:0 0 0 4px rgba(124,92,252,.1)}
.av-upload-ring img{width:100%;height:100%;object-fit:cover;display:none;position:absolute;inset:0}
.av-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--dim);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;z-index:1}
.av-placeholder svg{opacity:.5}
.av-upload-hint{font-size:11px;color:var(--dim);text-align:center}
.av-upload-ring input[type=file]{display:none}

/* form */
.f{margin-bottom:13px}
.f label{display:flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--txt2);margin-bottom:6px}
.f label svg{opacity:.55;flex-shrink:0}
.f input,.f select{width:100%;background:rgba(0,0,0,.5);border:1px solid var(--bdr2);border-radius:8px;padding:10px 13px;color:var(--txt);font-family:var(--font);font-size:13px;font-weight:500;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.f input:focus,.f select:focus{border-color:var(--purplebr);box-shadow:0 0 0 3px rgba(124,92,252,.11)}
.f input::placeholder{color:var(--dim)}
.f select option{background:#111}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.ferr{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--red);min-height:18px;margin:-2px 0 10px}

.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:14px}
.topt{border:1px solid var(--bdr);border-radius:9px;padding:11px 8px;text-align:center;cursor:pointer;background:rgba(0,0,0,.45);transition:all .2s var(--ease)}
.topt:hover{border-color:var(--bdr2);transform:translateY(-1px)}
.topt.on{border-color:var(--purplebr);background:var(--purplebg);box-shadow:0 0 18px rgba(124,92,252,.14)}
.topt-icon{font-size:22px;display:block;margin-bottom:5px;transition:transform .2s var(--ease)}
.topt:hover .topt-icon{transform:scale(1.15)}
.topt-lbl{font-size:10px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:var(--txt2);transition:color .15s}
.topt.on .topt-lbl{color:var(--purple2)}

.abtn{width:100%;height:43px;border-radius:9px;font-family:var(--font);font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .2s var(--ease);display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.2px}
.abtn-purple{background:linear-gradient(135deg,var(--purple),#4e20e0);color:#fff;box-shadow:0 4px 22px rgba(124,92,252,.38)}
.abtn-purple:hover{transform:translateY(-1px);box-shadow:0 7px 30px rgba(124,92,252,.5)}
.abtn-purple:active{transform:none}
.abtn-ghost{background:rgba(0,0,0,.4);border:1px solid var(--bdr2);color:var(--txt2);margin-top:8px}
.abtn-ghost:hover{background:var(--s3);color:var(--txt)}

/* ══════════════════════════════════════
   APP SHELL
══════════════════════════════════════ */
#screen-app{display:none;height:100vh;flex-direction:row;overflow:hidden}

/* sidebar */
.sidebar{width:var(--nav-w);flex-shrink:0;background:var(--s1);border-right:1px solid var(--bdr);display:flex;flex-direction:column;overflow:hidden}
.sb-logo{height:56px;display:flex;align-items:center;gap:10px;padding:0 15px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.sb-logo-icon{width:30px;height:30px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,var(--purple),#4e20e0);display:flex;align-items:center;justify-content:center;box-shadow:0 0 14px rgba(124,92,252,.4)}
.sb-logo-text{font-size:15px;font-weight:800;color:var(--txt);white-space:nowrap}
.sb-logo-text span{color:var(--purple2)}

.sb-section{padding:14px 12px 5px;font-size:9.5px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--dim)}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 11px;margin:1px 7px;border-radius:8px;cursor:pointer;transition:all .15s;color:var(--txt2);white-space:nowrap;border:1px solid transparent}
.sb-item:hover{background:var(--s2);color:var(--txt)}
.sb-item.active{background:var(--purplebg);color:var(--purple2);border-color:var(--purplebr)}
.sb-item svg{flex-shrink:0;width:15px;height:15px}
.sb-item-label{font-size:13px;font-weight:500}
.sb-badge{margin-left:auto;font-size:10px;font-weight:800;background:var(--purple);color:#fff;border-radius:10px;padding:1px 7px;min-width:20px;text-align:center;animation:badgePop .25s var(--ease)}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}

.sb-user{margin-top:auto;padding:11px 10px;border-top:1px solid var(--bdr);display:flex;align-items:center;gap:9px}
.sb-av-wrap{width:34px;height:34px;border-radius:9px;flex-shrink:0;overflow:hidden;position:relative}
.sb-av-wrap img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;display:none}
.sb-av-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-rank{font-size:11px;color:var(--txt2);white-space:nowrap}
.sb-logout{width:28px;height:28px;border-radius:7px;border:1px solid var(--bdr);background:none;color:var(--txt2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.sb-logout:hover{background:var(--redbg);border-color:var(--redbr);color:var(--red)}

/* main */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);min-width:0}

/* topbar */
.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;flex-shrink:0;background:var(--s1);border-bottom:1px solid var(--bdr)}
.topbar-left{display:flex;align-items:center;gap:10px}
.topbar-title{font-size:16px;font-weight:800;color:var(--txt)}
.topbar-sub{font-size:12px;color:var(--txt2)}
.topbar-right{display:flex;align-items:center;gap:8px;position:relative}

.notif-btn{position:relative;width:34px;height:34px;border-radius:8px;border:1px solid var(--bdr);background:var(--s2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;color:var(--txt2)}
.notif-btn:hover{background:var(--s3);color:var(--txt);border-color:var(--bdr2)}
.notif-dot{position:absolute;top:5px;right:5px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--s2);display:none;animation:ndpulse 1.6s ease infinite}
.notif-dot.show{display:block}
@keyframes ndpulse{0%,100%{box-shadow:0 0 0 0 rgba(242,88,88,.5)}60%{box-shadow:0 0 0 5px rgba(242,88,88,0)}}
.notif-drop{position:absolute;top:44px;right:0;width:320px;z-index:600;background:var(--s1);border:1px solid var(--bdr2);border-radius:11px;box-shadow:0 18px 55px rgba(0,0,0,.65);display:none;overflow:hidden;animation:dropIn .2s var(--ease)}
.notif-drop.open{display:block}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.nd-head{display:flex;align-items:center;justify-content:space-between;padding:11px 15px;border-bottom:1px solid var(--bdr)}
.nd-title{font-size:13px;font-weight:700;color:var(--txt)}
.nd-clear{font-size:11px;color:var(--txt2);cursor:pointer;transition:color .15s}
.nd-clear:hover{color:var(--red)}
.nd-list{max-height:290px;overflow-y:auto}
.nd-item{display:flex;align-items:flex-start;gap:10px;padding:10px 15px;border-bottom:1px solid var(--bdr);transition:background .1s}
.nd-item:hover{background:var(--s2)}
.nd-item:last-child{border-bottom:none}
.nd-icon{width:30px;height:30px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}
.nd-icon.chat{background:var(--purplebg);color:var(--purple2)}
.nd-icon.join{background:var(--greenbg);color:var(--green)}
.nd-icon.match{background:var(--goldbg);color:var(--gold)}
.nd-text{font-size:12px;font-weight:500;color:var(--txt);line-height:1.4}
.nd-time{font-size:10px;color:var(--dim);margin-top:2px}
.nd-empty{padding:26px;text-align:center;font-size:12px;color:var(--dim)}

.tbtn{height:34px;padding:0 14px;border-radius:8px;border:1px solid var(--bdr);background:var(--s2);color:var(--txt2);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}
.tbtn:hover{background:var(--s3);color:var(--txt);border-color:var(--bdr2)}
.tbtn.purple{background:var(--purplebg);border-color:var(--purplebr);color:var(--purple2)}
.tbtn.purple:hover{background:rgba(124,92,252,.22)}
.tbtn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* content */
.content{flex:1;display:flex;overflow:hidden;min-height:0}
.view{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.view-body{flex:1;display:flex;overflow:hidden;min-height:0}

/* ══════════════════════════════════════
   LOBBY PANE
══════════════════════════════════════ */
.lp{flex:1;overflow-y:auto;padding:18px 20px;min-width:0}

.search-strip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:12px 15px;margin-bottom:18px}
.strip-label{font-size:10.5px;font-weight:800;letter-spacing:1.1px;text-transform:uppercase;color:var(--txt2);margin-right:2px;white-space:nowrap}
.mc{font-size:12px;font-weight:600;padding:5px 12px;border-radius:7px;border:1px solid var(--bdr);background:var(--s2);color:var(--txt2);cursor:pointer;transition:all .15s;white-space:nowrap}
.mc:hover{color:var(--txt);border-color:var(--bdr2)}
.mc.on{background:var(--purplebg);border-color:var(--purplebr);color:var(--purple2)}
.search-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.search-status{font-size:12px;font-weight:500;color:var(--txt2);display:flex;align-items:center;gap:7px}
.spin{width:13px;height:13px;border:2px solid var(--bdr2);border-top-color:var(--purple2);border-radius:50%;animation:sp .7s linear infinite;display:none;flex-shrink:0}
@keyframes sp{to{transform:rotate(360deg)}}
.searching .spin{display:block}

.lobby-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:13px;align-content:start}

.lc{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:15px;transition:border-color .2s,transform .2s,box-shadow .2s;animation:cardIn .3s var(--ease) both;display:flex;flex-direction:column}
@keyframes cardIn{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:none}}
.lc:hover{border-color:var(--bdr2);transform:translateY(-2px);box-shadow:0 10px 32px rgba(0,0,0,.55)}
.lc.mine{border-color:var(--purplebr);background:linear-gradient(160deg,rgba(124,92,252,.06),var(--s1) 70%)}

.lc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px}
.lc-mode-line{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.lc-mode-icon{font-size:12px;line-height:1}
.lc-mode-txt{font-size:10.5px;font-weight:600;color:var(--txt2)}
.lc-name{font-size:15px;font-weight:800;color:var(--txt);line-height:1.2;word-break:break-word}
.lc-status-badge{font-size:9.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;border-radius:5px;flex-shrink:0;margin-top:2px;white-space:nowrap}
.mb-open{background:var(--greenbg);border:1px solid var(--greenbr);color:var(--green)}
.mb-full{background:var(--redbg);border:1px solid var(--redbr);color:var(--red)}
.mb-mine{background:var(--purplebg);border:1px solid var(--purplebr);color:var(--purple2)}

.lc-slots{display:flex;gap:4px;margin-bottom:10px}
.lcs{flex:1;height:5px;border-radius:3px;background:var(--s3);transition:background .3s,box-shadow .3s}
.lcs.on{background:var(--purple);box-shadow:0 0 7px rgba(124,92,252,.45)}
.lcs.on.gold{background:var(--gold);box-shadow:0 0 7px rgba(240,165,0,.4)}

.lc-members{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px;min-height:22px}
.lc-member{display:flex;align-items:center;gap:5px;background:var(--s2);border:1px solid var(--bdr);border-radius:6px;padding:3px 8px}
.lc-member-av{width:18px;height:18px;border-radius:4px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:800}
.lc-member-av img{width:100%;height:100%;object-fit:cover;display:block}
.lc-member-name{font-size:11px;font-weight:500;color:var(--txt2)}
.lc-member.host .lc-member-name{color:var(--txt);font-weight:700}

.lc-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:9px 0 0;border-top:1px solid var(--bdr);margin-top:auto}
.lc-meta-item{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:var(--txt2)}
.lc-meta-item svg{width:11px;height:11px;opacity:.55;flex-shrink:0}
.ping-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ping-lo{background:var(--green);box-shadow:0 0 5px rgba(61,214,140,.6)}
.ping-md{background:var(--gold);box-shadow:0 0 5px rgba(240,165,0,.5)}
.ping-hi{background:var(--red);box-shadow:0 0 5px rgba(242,88,88,.5)}

.lc-actions{display:flex;gap:6px;margin-top:10px}
.lbtn{flex:1;height:31px;border-radius:7px;border:1px solid var(--bdr2);font-family:var(--font);font-size:12px;font-weight:700;background:var(--s2);color:var(--txt2);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px}
.lbtn:hover{background:var(--s3);color:var(--txt)}
.lbtn.purple{background:var(--purplebg);border-color:var(--purplebr);color:var(--purple2)}
.lbtn.purple:hover{background:rgba(124,92,252,.22)}
.lbtn.red{background:var(--redbg);border-color:var(--redbr);color:var(--red)}
.lbtn.red:hover{background:rgba(242,88,88,.22)}
.lbtn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.lbtn svg{width:12px;height:12px}

/* ══════════════════════════════════════
   PLAYERS PANEL
══════════════════════════════════════ */
.players-panel{width:268px;flex-shrink:0;background:var(--s1);border-left:1px solid var(--bdr);display:flex;flex-direction:column}
.pp-head{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.pp-label{font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt2)}
.pp-num{font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;background:var(--s3);border:1px solid var(--bdr);color:var(--txt2)}
.pp-scroll{flex:1;overflow-y:auto;padding:8px}

.pr{display:flex;align-items:center;gap:9px;padding:8px 7px;border-radius:8px;margin-bottom:1px;transition:background .12s}
.pr:hover{background:var(--s2)}
.pr-av-wrap{width:34px;height:34px;border-radius:9px;flex-shrink:0;overflow:hidden;position:relative}
.pr-av-wrap img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;display:none}
.pr-av-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.pr-info{flex:1;min-width:0}
.pr-name{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-sub{font-size:10.5px;color:var(--txt2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-st{font-size:10px;font-weight:800;letter-spacing:.4px;padding:2px 8px;border-radius:5px;flex-shrink:0;white-space:nowrap}
.ps-idle{background:var(--s3);color:var(--dim)}
.ps-search{background:var(--goldbg);border:1px solid var(--goldbr);color:var(--gold)}
.ps-lobby{background:var(--greenbg);border:1px solid var(--greenbr);color:var(--green)}

/* ══════════════════════════════════════
   CHAT PANEL
══════════════════════════════════════ */
.chat-panel{width:300px;flex-shrink:0;background:var(--s1);border-left:1px solid var(--bdr);display:none;flex-direction:column}
.chat-panel.open{display:flex}

.cp-head{height:50px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--bdr);flex-shrink:0;gap:8px}
.cp-title-wrap{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.cp-live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px rgba(61,214,140,.7);flex-shrink:0;animation:livepulse 2s ease infinite}
@keyframes livepulse{0%,100%{opacity:1}50%{opacity:.5}}
.cp-lobby-name{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-members-count{font-size:11px;color:var(--txt2);white-space:nowrap;flex-shrink:0}
.cp-close{width:26px;height:26px;border-radius:7px;border:1px solid var(--bdr);background:none;color:var(--txt2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.cp-close:hover{background:var(--redbg);border-color:var(--redbr);color:var(--red)}

.chat-msgs{flex:1;overflow-y:auto;padding:10px 10px;display:flex;flex-direction:column;gap:6px}

.msg-sys{font-size:10.5px;color:var(--dim);font-style:italic;padding:2px 4px;display:flex;align-items:center;gap:6px;margin:4px 0}
.msg-sys::before,.msg-sys::after{content:'';flex:1;height:1px;background:var(--bdr)}

.msg-row{display:flex;align-items:flex-end;gap:7px;max-width:100%}
.msg-row.mine{flex-direction:row-reverse}

.msg-av-sm{width:26px;height:26px;border-radius:7px;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;align-self:flex-end}
.msg-av-sm img{width:100%;height:100%;object-fit:cover;display:block}

.msg-bubble-wrap{display:flex;flex-direction:column;gap:2px;max-width:calc(100% - 36px)}
.msg-row.mine .msg-bubble-wrap{align-items:flex-end}

.msg-sender{font-size:10.5px;font-weight:700;color:var(--purple2);margin-left:4px;line-height:1}
.msg-row.mine .msg-sender{color:var(--gold);margin-left:0;margin-right:4px}

.msg-bubble{
  background:var(--s3);border:1px solid var(--bdr2);
  border-radius:13px 13px 13px 3px;
  padding:8px 12px;font-size:13px;color:var(--txt);line-height:1.45;
  word-break:break-word;max-width:100%;
  animation:bubbleIn .2s var(--ease);
}
.msg-row.mine .msg-bubble{
  background:linear-gradient(135deg,rgba(124,92,252,.22),rgba(78,32,224,.17));
  border-color:rgba(124,92,252,.35);
  border-radius:13px 13px 3px 13px;
}
@keyframes bubbleIn{from{opacity:0;transform:scale(.96) translateY(4px)}to{opacity:1;transform:none}}
.msg-new .msg-bubble{box-shadow:0 0 0 2px rgba(124,92,252,.25)}

.msg-meta{display:flex;align-items:center;gap:5px;padding:0 4px}
.msg-row.mine .msg-meta{justify-content:flex-end}
.msg-time{font-size:10px;color:var(--dim)}

.chat-in-row{display:flex;gap:7px;padding:10px 10px 12px;border-top:1px solid var(--bdr);flex-shrink:0;align-items:center}
.chat-inp{flex:1;height:36px;background:var(--s2);border:1px solid var(--bdr2);border-radius:10px;padding:0 12px;color:var(--txt);font-family:var(--font);font-size:13px;font-weight:500;outline:none;transition:border-color .15s,box-shadow .15s}
.chat-inp:focus{border-color:var(--purplebr);box-shadow:0 0 0 3px rgba(124,92,252,.1)}
.chat-inp::placeholder{color:var(--dim)}
.chat-send{width:36px;height:36px;border-radius:10px;flex-shrink:0;border:none;background:linear-gradient(135deg,var(--purple),#4e20e0);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease);box-shadow:0 2px 12px rgba(124,92,252,.4)}
.chat-send:hover{transform:scale(1.07);box-shadow:0 4px 18px rgba(124,92,252,.55)}
.chat-send:active{transform:scale(.96)}

/* ══════════════════════════════════════
   OVERLAYS
══════════════════════════════════════ */
.ov{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.8);backdrop-filter:blur(7px);align-items:center;justify-content:center;padding:24px}
.ov.on{display:flex}
.obox{width:100%;max-width:400px;background:var(--s1);border:1px solid var(--bdr2);border-radius:13px;padding:28px 26px;box-shadow:0 28px 90px rgba(0,0,0,.75);animation:slideUp .3s var(--ease)}
.obox-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.obox-icon{width:36px;height:36px;border-radius:9px;background:var(--purplebg);border:1px solid var(--purplebr);display:flex;align-items:center;justify-content:center;color:var(--purple2);flex-shrink:0}
.obox-title{font-size:18px;font-weight:800;color:var(--txt)}
.obox-sub{font-size:12px;color:var(--txt2);margin-bottom:20px;margin-left:46px}

#match-modal{display:none;position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.9);backdrop-filter:blur(9px);align-items:center;justify-content:center;padding:24px}
#match-modal.on{display:flex}
.mbox{width:100%;max-width:400px;background:var(--s1);border:1px solid var(--goldbr);border-radius:13px;padding:36px 30px;text-align:center;box-shadow:0 0 70px rgba(240,165,0,.14),0 28px 90px rgba(0,0,0,.85);animation:slideUp .4s var(--ease)}
.m-icon-wrap{width:72px;height:72px;border-radius:50%;margin:0 auto 16px;background:linear-gradient(135deg,var(--gold),#c87800);display:flex;align-items:center;justify-content:center;font-size:32px;box-shadow:0 0 45px rgba(240,165,0,.45);animation:iconBounce .5s var(--ease) .1s both}
@keyframes iconBounce{from{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}
.m-title{font-size:32px;font-weight:900;color:var(--gold);letter-spacing:1px;margin-bottom:6px}
.m-id{font-size:11.5px;color:var(--txt2);letter-spacing:2px;margin-bottom:18px}
.m-players{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;margin-bottom:24px}
.m-player{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 11px;border-radius:7px;background:var(--s2);border:1px solid var(--bdr2);color:var(--txt2)}
.m-player-av{width:20px;height:20px;border-radius:5px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;flex-shrink:0}
.m-player-av img{width:100%;height:100%;object-fit:cover;display:block}

/* ══════════════════════════════════════
   TOASTS
══════════════════════════════════════ */
#toasts{position:fixed;bottom:18px;right:18px;z-index:999;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;background:var(--s1);border:1px solid var(--bdr2);border-radius:10px;padding:11px 14px;min-width:220px;max-width:340px;box-shadow:0 10px 35px rgba(0,0,0,.55);animation:toastIn .3s var(--ease);pointer-events:all}
@keyframes toastIn{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:none}}
.toast-icon{width:28px;height:28px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}
.ti-ok{background:var(--greenbg);color:var(--green)}
.ti-er{background:var(--redbg);color:var(--red)}
.ti-mt{background:var(--goldbg);color:var(--gold)}
.ti-info{background:var(--purplebg);color:var(--purple2)}
.toast-body{flex:1;min-width:0}
.toast-title{font-size:13px;font-weight:700;color:var(--txt)}
.toast-sub{font-size:11px;color:var(--txt2);font-weight:400;margin-top:1px}

/* empty */
.empty{grid-column:1/-1;padding:44px 24px;text-align:center;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--dim);border:1px dashed var(--bdr);border-radius:var(--r)}
.empty svg{margin:0 auto 12px;display:block;opacity:.25;width:34px;height:34px}

/* responsive */
@media(max-width:900px){.players-panel{display:none}}
@media(max-width:700px){.chat-panel.open{width:100%;border:none;position:absolute;inset:0;z-index:300}.search-strip{gap:6px}}
