@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Source+Code+Pro:wght@400;500&family=Instrument+Sans:wght@400;500;600;700&display=swap";:root{--bg-0:#112830;--bg-1:#182f37;--bg-2:#1f363e;--bg-3:#263d46;--bg-4:#2d444c;--bg-5:#334a52;--bg-h:#2a4149;--b1:rgba(255,255,255,.08);--b2:rgba(255,255,255,.13);--t0:#f0f4f6;--t1:#bcc8ce;--t2:#8a9aa2;--t3:#627178;--primary:#00d0fc;--primary-s:rgba(0,208,252,.12);--primary-m:rgba(0,208,252,.24);--primary-h:#33dafd;--green:#6fb07a;--green-s:rgba(111,176,122,.1);--red:#c46b5e;--red-s:rgba(196,107,94,.1);--teal:#5ea5a8;--f-ui:"Instrument Sans",sans-serif;--f-d:"Outfit",sans-serif;--f-m:"Source Code Pro",monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--f-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-5);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#3a525a}*{scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent}@keyframes bip{0%,60%,to{transform:translateY(0);opacity:.35}30%{transform:translateY(-2px);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes ring{0%,to{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(1.25)}}@keyframes vpIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.mqvi-app{display:flex;flex-direction:column;height:100vh;background:var(--bg-0);color:var(--t0);font-family:var(--f-ui);-webkit-font-smoothing:antialiased;overflow:hidden}.top-bar{height:40px;background:var(--bg-1);border-bottom:1px solid var(--b1);display:flex;align-items:center;padding:0 10px;flex-shrink:0}.server-pill{display:flex;align-items:center;gap:7px;padding:4px 12px 4px 6px;background:var(--bg-3);border:1px solid var(--b1);border-radius:999px;cursor:pointer}.server-pill:hover{background:var(--bg-4);border-color:var(--b2)}.sp-avatar{width:26px;height:26px;border-radius:7px;object-fit:cover;flex-shrink:0}.sp-name{font-size:15px;font-weight:700;color:var(--t0);font-family:var(--f-d);letter-spacing:.01em}.sp-chevron{font-size:10px;color:var(--t3)}.tab-strip{display:flex;align-items:stretch;flex:1;min-width:0;margin-left:6px;overflow-x:auto}.tab-strip::-webkit-scrollbar{display:none}.tab{display:flex;align-items:center;gap:5px;padding:0 11px;max-width:170px;cursor:pointer;transition:all .1s;position:relative;flex-shrink:0;border-right:1px solid rgba(255,255,255,.03)}.tab:hover{background:var(--bg-h)}.tab-active{background:var(--bg-2)}.tab-active:after{content:"";position:absolute;bottom:0;left:6px;right:6px;height:2px;background:var(--primary);border-radius:1px 1px 0 0}.tab-icon{font-size:13px;color:var(--t3)}.tab-active .tab-icon{color:var(--primary)}.tab-voice .tab-icon{color:var(--green)}.tab-voice.tab-active:after{background:var(--green)}.tab-screen .tab-icon{color:var(--red)}.tab-screen.tab-active:after{background:var(--red)}.tab-label{font-size:13.5px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tab-active .tab-label{color:var(--t0);font-weight:500}.tab-srv{font-size:10px;color:var(--t3);font-family:var(--f-m);background:var(--bg-4);padding:2px 5px;border-radius:3px}.tab-dot{width:5px;height:5px;background:var(--primary);border-radius:999px}.tab-close{width:17px;height:17px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;opacity:0;margin-left:auto}.tab:hover .tab-close{opacity:1}.tab-close:hover{color:var(--t0);background:var(--bg-h)}.main-area{flex:1;display:flex;min-height:0;position:relative}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-2);min-width:0;min-height:0;position:relative}.chat-area:after{content:"";position:absolute;top:32px;left:0;right:0;height:30%;background:linear-gradient(to bottom,rgba(12,12,14,.55),rgba(12,12,14,.25) 40%,transparent);pointer-events:none;z-index:1}.channel-bar{height:32px;padding:0 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.03);flex-shrink:0}.ch-hash{color:var(--t3);font-size:14px}.ch-name{font-family:var(--f-d);font-size:12.5px;font-weight:600;color:var(--t0)}.ch-divider{width:1px;height:12px;background:var(--b1)}.ch-topic{font-size:10.5px;color:var(--t3)}.ch-actions{margin-left:auto;display:flex;gap:1px}.ch-actions button{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px}.ch-actions button:hover{color:var(--t1);background:var(--bg-h)}.ch-actions button.active{color:var(--primary);background:var(--primary-s)}.messages-scroll{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent;-webkit-mask-image:linear-gradient(to bottom,transparent,black 3%,black);mask-image:linear-gradient(to bottom,transparent,black 3%,black)}.date-divider{display:flex;align-items:center;gap:10px;padding:6px 14px;margin:4px 0}.date-divider:before,.date-divider:after{content:"";flex:1;height:1px;background:var(--b1)}.date-divider span{font-size:9.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-d);white-space:nowrap}.msg{padding:2px 14px;position:relative;transition:background .08s}.msg:hover{background:#00000021}.msg.first-of-group{margin-top:10px}.msg-row{display:flex;gap:9px;align-items:flex-start}.msg.grouped .msg-avatar{visibility:hidden}.msg.grouped .msg-meta{display:none}.msg-gtime{position:absolute;left:14px;width:30px;text-align:center;font-size:8.5px;color:var(--t3);font-family:var(--f-m);opacity:0;top:50%;transform:translateY(-50%)}.msg.grouped:hover .msg-gtime{opacity:1}.msg-avatar{flex-shrink:0}.msg-body{min-width:0;flex:1}.msg-meta{display:flex;align-items:baseline;gap:6px;margin-bottom:1px}.msg-name{font-size:12.5px;font-weight:600;cursor:pointer}.msg-name:hover{opacity:.75}.name-admin{color:var(--primary)}.name-mod{color:var(--green)}.name-default{color:var(--t0)}.msg-time{font-size:9.5px;color:var(--t3);font-family:var(--f-m)}.msg-text{font-size:13px;line-height:1.45;color:var(--t0);white-space:pre-wrap;word-break:break-word}.msg-text code{font-family:var(--f-m);font-size:11.5px;background:var(--bg-0);padding:1px 5px;border-radius:3px;border:1px solid var(--b1);color:var(--teal)}.msg-edited{font-size:10px;color:var(--t3);margin-left:4px}.mention{background:var(--primary-s);color:var(--primary);padding:0 3px;border-radius:3px;font-weight:500;cursor:pointer}.mention:hover{background:var(--primary-m)}.msg-mention{background:var(--primary-s);color:var(--primary);padding:0 3px;border-radius:3px;font-weight:500}.msg-mention:hover{background:var(--primary-m)}.msg-pin-indicator{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--t3);margin-bottom:2px}.msg-pin-indicator svg{color:var(--primary)}.msg-hover-actions{position:absolute;top:-11px;right:14px;display:flex;background:var(--bg-4);border:1px solid var(--b2);border-radius:6px;box-shadow:0 4px 14px #0006;opacity:0;pointer-events:none;transition:opacity .1s}.msg-hover-actions:after{content:"";position:absolute;left:0;right:0;top:100%;height:14px}.msg:hover .msg-hover-actions,.msg.picker-open .msg-hover-actions{opacity:1;pointer-events:auto}.msg-hover-actions button{width:26px;height:24px;border:none;background:transparent;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px}.msg-hover-actions button:hover{color:var(--t0);background:var(--bg-h)}.msg-hover-actions button:first-child{border-radius:5px 0 0 5px}.msg-hover-actions button:last-child{border-radius:0 5px 5px 0}.msg-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.msg-attachment-img{max-height:300px;border-radius:8px;object-fit:contain;cursor:pointer}.msg-attachment-file{display:flex;align-items:center;gap:8px;padding:10px;border-radius:8px;border:1px solid var(--b1);background:var(--bg-1);cursor:pointer;transition:background .1s}.msg-attachment-file:hover{background:var(--bg-h)}.msg-attachment-file-icon{width:28px;height:28px;color:var(--t2);flex-shrink:0}.msg-attachment-file-name{font-size:12px;font-weight:500;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-attachment-file-name:hover{text-decoration:underline}.msg-attachment-file-size{font-size:10px;color:var(--t3)}.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;align-items:center}.msg-reaction-btn{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--b1);background:var(--bg-3);cursor:pointer;transition:all .1s;font-size:13px}.msg-reaction-btn:hover{background:var(--bg-4);border-color:var(--b2)}.msg-reaction-btn.active{border-color:var(--primary);background:var(--primary-s)}.msg-reaction-emoji{font-size:14px;line-height:1}.msg-reaction-count{font-size:11px;color:var(--t1);font-family:var(--f-m);min-width:8px;text-align:center}.msg-reaction-btn.active .msg-reaction-count{color:var(--primary)}.msg-reaction-add-wrap{position:relative}.msg-reaction-add{width:24px;height:24px;border-radius:999px;border:1px solid var(--b1);background:var(--bg-3);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .1s;opacity:0}.msg:hover .msg-reaction-add,.msg.picker-open .msg-reaction-add{opacity:1}.msg-reaction-add:hover{background:var(--bg-4);border-color:var(--b2);color:var(--t0)}.emoji-picker{position:absolute;bottom:100%;left:0;width:320px;background:var(--bg-3);border:1px solid var(--b2);border-radius:10px;box-shadow:0 8px 24px #00000080;z-index:100;overflow:hidden;margin-bottom:6px}.msg-hover-actions .emoji-picker{left:auto;right:0}.emoji-picker-tabs{display:flex;border-bottom:1px solid var(--b1);padding:0 4px}.emoji-picker-tab{flex:1;padding:8px 0;border:none;background:transparent;cursor:pointer;font-size:16px;opacity:.5;transition:opacity .1s;position:relative}.emoji-picker-tab:hover{opacity:.8}.emoji-picker-tab.active{opacity:1}.emoji-picker-tab.active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--primary);border-radius:1px}.emoji-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;max-height:200px;overflow-y:auto}.emoji-picker-btn{width:100%;aspect-ratio:1;border:none;background:transparent;cursor:pointer;font-size:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .08s}.emoji-picker-btn:hover{background:var(--bg-h)}.msg-reply-preview{display:flex;align-items:center;gap:6px;padding:2px 0 4px;cursor:pointer;font-size:11.5px;max-width:400px}.msg-reply-preview:hover{opacity:.8}.msg-reply-bar{width:2px;height:14px;border-radius:1px;background:var(--primary);flex-shrink:0}.msg-reply-author{font-weight:600;color:var(--t1);white-space:nowrap}.msg-reply-content{color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-reply-deleted{color:var(--t3);font-style:italic}.msg-highlight{background:var(--primary-s);transition:background 2s ease-out}.msg-edit-area{margin-top:4px}.msg-edit-textarea{width:100%;resize:none;border-radius:8px;background:var(--bg-3);padding:8px;font-size:13px;color:var(--t0);border:none;outline:none;font-family:var(--f-ui)}.msg-edit-textarea:focus{background:var(--bg-4)}.msg-edit-hint{font-size:10px;color:var(--t3);margin-top:4px}.msg-welcome{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;padding:32px;text-align:center}.msg-welcome-icon{width:76px;height:76px;border-radius:999px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;margin-bottom:16px}.msg-welcome-icon span{font-size:42px;color:var(--t2);line-height:1}.msg-welcome h2{font-size:32px;font-weight:700;color:var(--t0);font-family:var(--f-d);margin-bottom:8px;line-height:1.1}.msg-welcome p{font-size:16px;color:var(--t2);max-width:480px;line-height:1.5}.typing-indicator{height:18px;padding:0 14px;display:flex;align-items:center;gap:4px;flex-shrink:0;position:relative;z-index:2}.typing-dots{display:flex;gap:2px}.typing-dots i{width:3.5px;height:3.5px;background:var(--t3);border-radius:999px;animation:bip 1.4s ease-in-out infinite;display:block}.typing-dots i:nth-child(2){animation-delay:.15s}.typing-dots i:nth-child(3){animation-delay:.3s}.typing-indicator span{font-size:10px;color:var(--t3)}.typing-indicator strong{color:var(--t2);font-weight:600}.input-area{padding:0 10px 10px;flex-shrink:0;position:relative;z-index:2}.reply-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-radius:8px 8px 0 0;border:1px solid var(--b1);border-bottom:none;margin-bottom:-1px}.reply-bar-icon{color:var(--t2);flex-shrink:0}.reply-bar-user{font-size:12px;font-weight:600;color:var(--t0);white-space:nowrap}.reply-bar-text{font-size:12px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.reply-bar-close{width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px}.reply-bar-close:hover{color:var(--t1);background:var(--bg-h)}.reply-bar+.input-box{border-radius:0 0 10px 10px}.input-box{background:var(--bg-3);border:1px solid var(--b1);border-radius:10px;display:flex;align-items:flex-end;padding:3px;transition:border-color .15s}.input-box:focus-within{border-color:var(--primary)}.input-box button{width:30px;height:30px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px}.input-box button:hover{color:var(--t1);background:var(--bg-h)}.send-btn{color:var(--primary)!important}.input-box textarea{flex:1;background:transparent;border:none;outline:none;color:var(--t0);font-family:var(--f-ui);font-size:13px;padding:6px 5px;resize:none;max-height:100px;line-height:1.4}.input-box textarea::placeholder{color:var(--t3)}.input-box-disabled{justify-content:center;padding:10px;cursor:not-allowed;opacity:.6}.input-no-perm{font-size:12px;color:var(--t3);font-style:italic;-webkit-user-select:none;user-select:none}.mention-popup{position:absolute;bottom:100%;left:10px;right:10px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:4px;margin-bottom:4px;max-height:200px;overflow-y:auto;z-index:10;box-shadow:0 -4px 12px #0000004d}.mention-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;background:transparent;color:var(--t0);cursor:pointer;border-radius:6px;text-align:left;font-family:inherit;font-size:13px}.mention-item:hover,.mention-item.active{background:var(--bg-h)}.mention-item-avatar{flex-shrink:0}.mention-item-name{font-weight:500;color:var(--t0)}.mention-item-username{font-size:11px;color:var(--t3);margin-left:auto}.file-preview{display:flex;flex-wrap:wrap;gap:8px;padding:0 10px 6px}.file-preview-item{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;background:var(--bg-3);border:1px solid var(--b1)}.file-preview-item img{width:100%;height:100%;object-fit:cover}.file-preview-name{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background:#000000b3;font-size:8px;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-remove{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:999px;background:var(--bg-5);border:1.5px solid var(--bg-1);color:var(--t1);font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1}.file-preview-remove:hover{background:var(--red);color:#fff}.members-panel{width:0;background:var(--bg-1);border-left:1px solid var(--b1);overflow:hidden;transition:width .25s cubic-bezier(.22,1,.36,1);flex-shrink:0}.members-panel.open{width:240px}.members-inner{width:240px;height:100%;display:flex;flex-direction:column}.members-header{height:38px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b1)}.members-header h3{font-family:var(--f-d);font-size:12px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em}.members-header button{width:22px;height:22px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px}.members-header button:hover{color:var(--t1);background:var(--bg-h)}.members-list{flex:1;overflow-y:auto;padding:4px 6px;scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent}.member-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--t3);padding:9px 6px 3px;font-family:var(--f-d)}.member{display:flex;align-items:center;gap:9px;padding:5px 6px;border-radius:7px;cursor:pointer;transition:background .08s}.member:hover{background:var(--bg-h)}.member-info{display:flex;flex-direction:column;min-width:0}.member-av-wrap{position:relative;flex-shrink:0}.member-status{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:999px;border:2px solid var(--bg-1)}.status-on{background:var(--green)}.status-idle{background:var(--primary)}.status-dnd{background:var(--red)}.status-off{background:var(--t3)}.member-name{font-size:13px;font-weight:500;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member:hover .member-name{color:var(--t0)}.member-activity{font-size:11px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member.offline{opacity:.4}.member-card-backdrop{position:fixed;inset:0;z-index:50}.member-card{position:fixed;width:288px;background:#112830eb;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--b2);border-radius:12px;box-shadow:0 12px 48px #0000008c;z-index:51;overflow:hidden}.member-card-banner{height:64px;background:linear-gradient(135deg,var(--primary),#0088a3)}.member-card-avatar{position:relative;margin-top:-32px;margin-left:16px}.member-card-body{padding:8px 16px 16px}.member-card-name{font-size:18px;font-weight:700;color:var(--t0);font-family:var(--f-d);margin-top:8px}.member-card-username{font-size:12px;color:var(--t2)}.member-card-divider{height:1px;background:var(--b1);margin:10px 0}.member-card-section-title{font-size:10px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.member-card-roles{display:flex;flex-wrap:wrap;gap:4px}.member-card-joined{font-size:11px;color:var(--t2)}.member-card-actions{display:flex;gap:4px;margin-top:10px}.member-card-btn{flex:1;height:28px;border:none;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;font-family:var(--f-ui);display:flex;align-items:center;justify-content:center}.member-card-btn-kick{background:var(--bg-4);color:var(--t1)}.member-card-btn-kick:hover{background:var(--bg-5);color:var(--t0)}.member-card-btn-ban{background:var(--red-s);color:var(--red)}.member-card-btn-ban:hover{background:var(--red);color:#fff}.role-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--bg-4);border:1px solid var(--b1);font-size:10px;font-weight:500;color:var(--t1)}.role-badge-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.avatar{border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--f-d);font-weight:600;color:#fff;flex-shrink:0}.avatar-round{border-radius:999px}.av-admin{background:linear-gradient(135deg,#00b8d9,#0088a3)}.av-mod{background:linear-gradient(135deg,#6fb07a,#4d8a5a)}.av-default{background:linear-gradient(135deg,var(--primary),#0088a3)}.av-u1{background:linear-gradient(135deg,#8a7ab8,#6a5a98)}.av-u2{background:linear-gradient(135deg,#b87a6a,#986050)}.av-u3{background:linear-gradient(135deg,#5ea5a8,#468588)}.av-u4{background:linear-gradient(135deg,#b8a87a,#988a60)}.dock-area{flex-shrink:0;display:flex;justify-content:center;padding:8px 0 12px;background:linear-gradient(to bottom,var(--bg-0),#0d2228);border-top:1px solid var(--b1);position:relative}.dock-container{position:relative;display:flex;flex-direction:column;align-items:center}.dock-svg{position:absolute;pointer-events:none;z-index:0;overflow:visible}.dock-svg-path{fill:#112830e6;stroke:#ffffff1a;stroke-width:1;transition:d .3s cubic-bezier(.22,1,.36,1)}.dock-ch-row{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:3px;padding:6px 16px 4px;min-height:34px}.dock-ch-item{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:10px;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap;background:transparent;border:none;color:inherit;font-family:inherit;font-size:inherit;touch-action:none}.dock-ch-item:hover{background:#ffffff0f}.dock-ch-item.active{background:var(--primary-s)}.dock-ch-icon{font-size:14px;color:var(--t3)}.dock-ch-item.active .dock-ch-icon{color:var(--primary)}.dock-ch-item.voice .dock-ch-icon{color:var(--green)}.dock-ch-name{font-size:13px;color:var(--t1);font-weight:500}.dock-ch-item.active .dock-ch-name{color:var(--t0)}.dock-ch-badge{min-width:16px;height:16px;padding:0 5px;background:var(--primary);color:#fff;font-size:9px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center}.dock-unread-badge{min-width:16px;height:16px;padding:0 5px;background:var(--primary);color:#fff;font-size:9px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;margin-left:2px;line-height:1}.dock-ch-item.has-unread .dock-ch-name{color:var(--t0);font-weight:600}.dock-ch-item.dragging{cursor:grabbing}.dock-ch-sep{width:1px;height:22px;background:#ffffff14;margin:0 3px}.dock-ch-add{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:1px dashed var(--t3);background:none;color:var(--t3);font-size:17px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.dock-ch-add:hover{background:var(--bg-4);color:var(--t0);border-color:var(--t1)}.dock-create-popover{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;padding:12px;min-width:220px;box-shadow:0 4px 16px #0006;z-index:100;display:flex;flex-direction:column;gap:8px}.dock-create-label{font-size:12px;font-weight:600;color:var(--t1);text-transform:uppercase;letter-spacing:.04em}.dock-create-input{background:var(--bg-4);border:1px solid var(--b1);border-radius:4px;padding:6px 8px;color:var(--t0);font-size:13px;outline:none;transition:border-color .15s}.dock-create-input:focus{border-color:var(--primary)}.dock-create-input::placeholder{color:var(--t3)}.dock-create-actions{display:flex;gap:6px}.dock-create-btn{flex:1;padding:6px 10px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:background .15s}.dock-create-btn:not(.secondary){background:var(--primary);color:var(--bg-1)}.dock-create-btn:not(.secondary):hover{background:var(--primary-h)}.dock-create-btn:not(.secondary):disabled{opacity:.5;cursor:not-allowed}.dock-create-btn.secondary{background:var(--bg-4);color:var(--t2)}.dock-create-btn.secondary:hover{background:var(--bg-5);color:var(--t0)}.dock-srv-row{position:relative;z-index:2;display:flex;align-items:flex-end;gap:6px;padding:5px 10px 6px}.dock-item{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s cubic-bezier(.22,1,.36,1);position:relative;background:var(--bg-3);border:1px solid transparent;color:var(--t1);font-family:var(--f-d);font-size:15px;font-weight:700}.dock-item:hover{transform:translateY(-8px) scale(1.12);background:var(--bg-4);border-color:var(--b2);box-shadow:0 6px 20px #0006}.dock-item:hover+.dock-item{transform:translateY(-2px) scale(1.04)}.dock-srv.active{background:transparent;border-color:transparent;overflow:hidden;padding:0}.dock-srv-icon{width:100%;height:100%;border-radius:inherit;object-fit:cover}.dock-add{border:1px dashed var(--b2);background:transparent;color:var(--t3);font-size:20px}.dock-util-icon{font-size:19px;color:var(--t1);transition:color .1s}.dock-item:hover .dock-util-icon{color:var(--t0)}.dock-tooltip{position:absolute;top:-34px;left:50%;transform:translate(-50%);background:var(--bg-0);color:var(--t0);font-family:var(--f-d);font-size:12px;font-weight:500;padding:4px 10px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s;box-shadow:0 4px 14px #00000080;border:1px solid var(--b2);z-index:10}.dock-item:hover .dock-tooltip{opacity:1}.dock-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;padding:0 4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(17,40,48,.88)}.dock-dot{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:5px;height:5px;background:var(--primary);border-radius:999px}.dock-separator{width:1px;height:30px;background:#ffffff14;margin:0 4px;align-self:center}.dock-profile{border-radius:999px;width:44px;height:44px}.voice-popup{position:fixed;width:240px;background:#112830eb;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--b2);border-radius:14px;box-shadow:0 12px 48px #0000008c;z-index:60;display:flex;flex-direction:column;overflow:hidden;transition:width .3s,border-radius .3s;animation:vpIn .3s cubic-bezier(.22,1,.36,1)}.vp-mini{width:42px!important;border-radius:999px;cursor:pointer}.vp-mini .vp-body{display:none}.vp-mini .vp-bar{padding:0;border:none;height:42px;justify-content:center}.vp-mini .vp-bar-main{display:none}.vp-bar{height:32px;padding:0 8px;display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--b1);cursor:grab}.vp-bar:active{cursor:grabbing}.vp-pulse{width:7px;height:7px;background:var(--green);border-radius:999px;animation:pulse 2s ease-in-out infinite}.vp-bar-main{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.vp-title{font-size:10.5px;font-weight:600;color:var(--green);font-family:var(--f-d)}.vp-ch{font-size:9.5px;color:var(--t2)}.vp-btns{display:flex;gap:1px;margin-left:auto}.vp-btns button{width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px}.vp-btns button:hover{color:var(--t0);background:var(--bg-h)}.vp-mini-icon{display:none;font-size:15px;position:relative}.vp-mini .vp-mini-icon{display:flex;align-items:center;justify-content:center}.vp-mini-ring{position:absolute;inset:-3px;border-radius:999px;border:2px solid var(--green);animation:ring 2s ease-in-out infinite}.vp-body{padding:6px 8px}.vp-controls{display:flex;gap:3px;margin-bottom:6px}.vp-ctrl{flex:1;height:26px;border:none;background:var(--bg-4);color:var(--t1);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--f-ui)}.vp-ctrl:hover{background:var(--bg-5);color:var(--t0)}.vp-ctrl.active{background:var(--primary-s);color:var(--primary)}.vp-end{background:var(--red-s)!important;color:var(--red)!important;flex:0!important;width:26px!important}.vp-end:hover{background:var(--red)!important;color:#fff!important}.vp-users{display:flex;flex-direction:column;gap:1px}.vp-user{display:flex;align-items:center;gap:6px;padding:3px 5px;border-radius:6px}.vp-user:hover{background:var(--bg-h)}.vp-user.speaking{background:var(--green-s)}.vp-uname{font-size:10.5px;color:var(--t1);font-weight:500}.vp-user.speaking .vp-uname{color:var(--green)}.vp-speak-dot{width:5px;height:5px;border-radius:999px;background:var(--green);animation:pulse 1.5s ease-in-out infinite;margin-left:auto}.split-container{display:flex;flex:1;min-height:0;min-width:0}.split-container.vertical{flex-direction:column}.split-pane{display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.split-handle{background:transparent;flex-shrink:0;position:relative;z-index:5;transition:background .15s}.split-handle:hover{background:var(--primary)}.split-handle.horizontal{width:4px;cursor:col-resize}.split-handle.vertical{height:4px;cursor:row-resize}.split-handle-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:999px;background:var(--t3);opacity:0;transition:opacity .15s}.split-handle:hover .split-handle-dot{opacity:1}.panel-tab-bar{display:flex;align-items:stretch;background:var(--bg-1);border-bottom:1px solid var(--b1);min-height:32px;overflow-x:auto}.panel-tab-bar::-webkit-scrollbar{display:none}.panel-tab{display:flex;align-items:center;gap:5px;padding:0 12px;cursor:pointer;font-size:13px;color:var(--t2);position:relative;flex-shrink:0;border-right:1px solid rgba(255,255,255,.03);transition:background .1s;max-width:180px}.panel-tab:hover{background:var(--bg-h)}.panel-tab.active{background:var(--bg-2);color:var(--t0)}.panel-tab.active:after{content:"";position:absolute;bottom:0;left:4px;right:4px;height:2px;background:var(--primary);border-radius:1px 1px 0 0}.panel-tab-close{width:16px;height:16px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;opacity:0;margin-left:auto}.panel-tab:hover .panel-tab-close{opacity:1}.panel-tab-close:hover{color:var(--t0);background:var(--bg-h)}.drop-zone-overlay{position:absolute;inset:0;z-index:20;pointer-events:none}.drop-zone{position:absolute;border-radius:4px;border:2px solid transparent;transition:background .15s,border-color .15s}.drop-zone.highlight{background:var(--primary-m);border-color:var(--primary)}.drop-zone-left{top:10%;left:0;width:25%;bottom:10%}.drop-zone-right{top:10%;right:0;width:25%;bottom:10%}.drop-zone-top{top:0;left:10%;right:10%;height:25%}.drop-zone-bottom{bottom:0;left:10%;right:10%;height:25%}.drop-zone-center{inset:25%}.no-channel{display:flex;align-items:center;justify-content:center;flex:1;color:var(--t3);font-size:13px}.settings-placeholder{flex-direction:column;gap:8px}.settings-placeholder-text{font-size:13px;color:var(--t2)}.channel-settings-list{display:flex;flex-direction:column;gap:4px;margin-top:12px}.channel-settings-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-radius:6px;transition:background .15s}.channel-settings-item:hover{background:var(--bg-4)}.channel-settings-icon{font-size:16px;color:var(--t2);width:20px;text-align:center;flex-shrink:0}.channel-settings-name{flex:1;font-size:14px;color:var(--t0);font-weight:500}.channel-settings-type{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}.channel-settings-delete{background:none;border:none;color:var(--t3);font-size:14px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:color .15s,background .15s}.channel-settings-delete:hover{color:var(--red);background:var(--red-s)}.channel-settings-create-form{margin-top:12px;padding:12px;background:var(--bg-3);border-radius:8px}.channel-settings-wrapper{display:flex;height:100%}.channel-settings-header{display:flex;align-items:center;justify-content:space-between;padding:10px 8px}.channel-settings-header-label{font-size:13px;font-weight:600;color:var(--t0)}.channel-settings-header-btn{height:28px;padding:0 10px;font-size:11px}.channel-settings-create-inline{padding:0 8px 8px}.channel-settings-create-inline .settings-input,.channel-settings-create-inline .settings-btn{width:100%;margin-bottom:4px}.channel-settings-create-inline .settings-btn{font-size:11px}.channel-settings-ch-list{flex:1;overflow-y:auto;padding:0 4px}.channel-settings-ch-row .channel-settings-delete{margin-left:auto}.channel-settings-ch-icon{width:16px;text-align:center;font-size:13px;color:var(--t2);flex-shrink:0}.channel-settings-right{padding:24px}.channel-settings-right-title{margin-bottom:16px}.channel-perm-section{max-width:560px}.perm-tri-section-desc{font-size:12px;color:var(--t2);margin-bottom:16px;line-height:1.5}.perm-tri-role-select{display:flex;align-items:center;gap:8px}.perm-tri-role-select .role-list-dot{flex-shrink:0}.perm-tri-role-dropdown{flex:1}.perm-tri-container{background:var(--bg-1);border-radius:8px;overflow:hidden}.perm-tri{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--b1);gap:16px}.perm-tri:last-child{border-bottom:none}.perm-tri-info{flex:1;min-width:0}.perm-tri-label{font-size:13px;font-weight:500;color:var(--t0)}.perm-tri-desc{font-size:11px;color:var(--t3);margin-top:2px}.perm-tri-controls{display:flex;gap:2px;flex-shrink:0}.perm-tri-btn{width:28px;height:28px;border-radius:4px;border:1px solid transparent;background:var(--bg-3);color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;opacity:.4}.perm-tri-btn:hover{opacity:.7}.perm-tri-btn.active{opacity:1}.perm-tri-btn.deny.active{background:var(--red-s);border-color:var(--red);color:var(--red)}.perm-tri-btn.inherit.active{background:var(--bg-4);border-color:var(--t3);color:var(--t2);opacity:.8}.perm-tri-btn.allow.active{background:var(--green-s);border-color:var(--green);color:var(--green)}.voice-settings{max-width:660px;padding:16px 0}.vs-section{margin-bottom:24px}.vs-label{font-size:11px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.vs-desc{font-size:12px;color:var(--t3);margin-top:4px}.vs-radio-group{display:flex;gap:10px}.vs-radio{flex:1;display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:var(--bg-3);border:2px solid var(--b1);border-radius:8px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.vs-radio:hover{border-color:var(--t3);background:var(--bg-4)}.vs-radio.active{border-color:var(--primary);background:var(--primary-s)}.vs-radio-dot{width:18px;height:18px;border-radius:999px;border:2px solid var(--t3);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.vs-radio.active .vs-radio-dot{border-color:var(--primary)}.vs-radio.active .vs-radio-dot:after{content:"";width:10px;height:10px;border-radius:999px;background:var(--primary)}.vs-radio-title{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:2px}.vs-slider-row{display:flex;align-items:center;gap:12px}.vs-range{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-5);border-radius:3px;outline:none;cursor:pointer}.vs-range::-webkit-slider-runnable-track{height:6px;border-radius:3px}.vs-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:999px;background:var(--primary);cursor:pointer;margin-top:-6px;box-shadow:0 1px 4px #0006}.vs-range::-moz-range-track{height:6px;border-radius:3px;background:var(--bg-5)}.vs-range::-moz-range-progress{height:6px;border-radius:3px;background:var(--primary)}.vs-range::-moz-range-thumb{width:18px;height:18px;border-radius:999px;background:var(--primary);border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.vs-range:hover::-webkit-slider-thumb{transform:scale(1.15)}.vs-range:hover::-moz-range-thumb{transform:scale(1.15)}.vs-slider-value{font-size:13px;font-weight:500;color:var(--primary);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.vs-select{width:100%;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:13px;font-family:var(--f-ui);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23949BA4' stroke-width='2'%3E%3Cpath d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.vs-select:focus{border-color:var(--primary)}.vs-keybind{display:inline-flex;align-items:center;justify-content:center;min-width:120px;height:38px;padding:0 20px;background:var(--bg-3);border:2px solid var(--b1);border-radius:6px;color:var(--t0);font-size:14px;font-weight:500;font-family:var(--f-m);cursor:pointer;transition:border-color .15s,color .15s}.vs-keybind:hover{border-color:var(--primary);color:var(--primary)}.vs-keybind.listening{border-color:var(--primary);color:var(--primary);animation:pulse 1.5s ease-in-out infinite}.vs-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.vs-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.vs-switch input{opacity:0;width:0;height:0;position:absolute}.vs-switch-slider{position:absolute;inset:0;background:var(--bg-5);border:2px solid var(--t3);border-radius:999px;cursor:pointer;transition:background .2s,border-color .2s}.vs-switch-slider:before{content:"";position:absolute;left:2px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:999px;background:var(--t3);transition:transform .2s,background .2s}.vs-switch input:checked+.vs-switch-slider{background:var(--primary);border-color:var(--primary)}.vs-switch input:checked+.vs-switch-slider:before{transform:translate(20px) translateY(-50%);background:#fff}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-0)}.auth-card{width:100%;max-width:480px;padding:40px;background:var(--bg-2);border:1px solid var(--b1);border-radius:12px}.auth-title{font-family:var(--f-d);font-size:26px;font-weight:700;color:var(--t0);text-align:center;margin-bottom:8px}.auth-subtitle{font-size:14px;color:var(--t2);text-align:center;margin-bottom:28px}.auth-error{background:var(--red-s);border:1px solid var(--red);border-radius:8px;padding:10px 14px;margin-bottom:16px;font-size:13px;color:var(--red)}.auth-label{display:block;font-size:11px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.auth-input{width:100%;height:44px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 14px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;transition:border-color .15s}.auth-input:focus{border-color:var(--primary)}.auth-input::placeholder{color:var(--t3)}.auth-field{margin-bottom:16px}.auth-btn{width:100%;height:44px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--f-ui);transition:background .15s}.auth-btn:hover{background:#0088a3}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-link{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--t2)}.auth-link a{color:var(--primary);text-decoration:none}.auth-link a:hover{text-decoration:underline}.settings-overlay{position:fixed;inset:0;z-index:50;display:flex;background:var(--bg-0)}.settings-nav{width:218px;background:var(--bg-1);border-right:1px solid var(--b1);display:flex;flex-direction:column;padding:16px 10px;overflow-y:auto;flex-shrink:0}.settings-nav-label{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;padding:12px 8px 4px;font-family:var(--f-d)}.settings-nav-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--t2);border:none;background:transparent;width:100%;text-align:left;font-family:var(--f-ui);transition:background .08s}.settings-nav-item:hover{background:var(--bg-h);color:var(--t1)}.settings-nav-item.active{background:var(--bg-4);color:var(--t0)}.settings-content{flex:1;overflow-y:auto;padding:32px 40px;max-width:740px}.settings-close{position:fixed;top:16px;right:16px;width:36px;height:36px;border:1px solid var(--b1);border-radius:999px;background:var(--bg-3);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:51;transition:background .1s}.settings-close:hover{background:var(--bg-4);color:var(--t0)}.settings-section{margin-bottom:32px}.settings-section-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--t0);margin-bottom:16px}.settings-label{display:block;font-size:11px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.settings-input{width:100%;max-width:400px;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;transition:border-color .15s}.settings-input:focus{border-color:var(--primary)}.settings-input::placeholder{color:var(--t3)}.settings-textarea{width:100%;max-width:400px;min-height:80px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:10px 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;resize:vertical;transition:border-color .15s}.settings-textarea:focus{border-color:var(--primary)}.settings-select{width:100%;max-width:400px;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;cursor:pointer;appearance:none}.settings-field{margin-bottom:16px}.settings-btn{height:36px;padding:0 20px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--f-ui);transition:background .15s}.settings-btn:hover{background:#0088a3}.settings-btn:disabled{opacity:.5;cursor:not-allowed}.settings-btn-danger{background:var(--red-s);color:var(--red)}.settings-btn-danger:hover{background:var(--red);color:#fff}.settings-btn-secondary{background:var(--bg-4);color:var(--t1)}.settings-btn-secondary:hover{background:var(--bg-5);color:var(--t0)}.avatar-upload{position:relative;cursor:pointer;display:inline-block}.avatar-upload-overlay{position:absolute;inset:0;border-radius:inherit;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;font-size:12px;color:#fff}.avatar-upload:hover .avatar-upload-overlay{opacity:1}.color-picker{display:grid;grid-template-columns:repeat(10,1fr);gap:4px;max-width:280px}.color-swatch{width:24px;height:24px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:border-color .1s}.color-swatch.selected{border-color:var(--t0);box-shadow:0 0 0 2px var(--bg-0)}.color-hex-row{display:flex;align-items:center;gap:8px;margin-top:8px}.color-hex-preview{width:32px;height:32px;border-radius:6px;border:1px solid var(--b1);flex-shrink:0}.color-hex-input{width:100px;height:32px;background:var(--bg-3);border:1px solid var(--b1);border-radius:6px;padding:0 8px;color:var(--t0);font-size:12px;font-family:var(--f-m);outline:none}.color-hex-input:focus{border-color:var(--primary)}.permission-toggle{display:flex;align-items:flex-start;gap:12px;padding:8px 0}.permission-toggle-checkbox{width:20px;height:20px;border-radius:4px;border:2px solid var(--b2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}.permission-toggle-checkbox.checked{background:var(--primary);border-color:var(--primary)}.permission-toggle-check{width:12px;height:12px;color:#fff}.permission-toggle-label{font-size:13px;font-weight:500;color:var(--t0)}.permission-toggle-desc{font-size:11px;color:var(--t2);margin-top:2px}.permission-toggle-warn{font-size:10px;color:var(--red);margin-top:2px}.role-list{width:200px;border-right:1px solid var(--b1);flex-shrink:0;overflow-y:auto}.role-list-item{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:6px;transition:background .08s}.role-list-item:hover{background:var(--bg-h)}.role-list-item.active{background:var(--bg-4)}.role-list-dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.role-list-name{font-size:13px;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-list-item.active .role-list-name{color:var(--t0);font-weight:500}.toast-container{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column-reverse;gap:8px}.toast{width:360px;background:var(--bg-3);border:1px solid var(--b1);border-radius:10px;padding:12px 14px;box-shadow:0 8px 32px #0006;display:flex;align-items:flex-start;gap:10px;animation:vpIn .3s cubic-bezier(.22,1,.36,1)}.toast-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}.toast-success .toast-icon{color:var(--green)}.toast-error .toast-icon{color:var(--red)}.toast-warning .toast-icon{color:var(--primary)}.toast-info .toast-icon{color:var(--teal)}.toast-body{flex:1;min-width:0}.toast-title{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:2px}.toast-message{font-size:12px;color:var(--t2)}.toast-close{width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}.toast-close:hover{color:var(--t1);background:var(--bg-h)}.toast-border-success{border-left:3px solid var(--green)}.toast-border-error{border-left:3px solid var(--red)}.toast-border-warning{border-left:3px solid var(--primary)}.toast-border-info{border-left:3px solid var(--teal)}.modal-backdrop{position:fixed;inset:0;background:#0009;z-index:50;display:flex;align-items:center;justify-content:center}.modal-card{background:var(--bg-3);border:1px solid var(--b2);border-radius:12px;max-width:480px;width:100%;padding:24px;box-shadow:0 12px 48px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--t0)}.modal-text{font-size:14px;color:var(--t2);margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.voice-room{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-2)}.voice-room-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:13px}.voice-room-grid{flex:1;display:flex;flex-wrap:wrap;gap:16px;padding:24px;align-content:center;justify-content:center;overflow-y:auto}.voice-grid-strip{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 16px;border-top:1px solid var(--b1)}.voice-participant{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px}.voice-participant-avatar{width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg,var(--primary),#0088a3);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;font-family:var(--f-d);transition:box-shadow .15s;position:relative}.voice-participant-avatar.speaking{box-shadow:0 0 0 2px var(--bg-2),0 0 0 4px var(--green)}.voice-participant-name{font-size:13px;font-weight:500;color:var(--t0);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-participant-overlay{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;border-radius:999px;background:var(--bg-3);display:flex;align-items:center;justify-content:center}.voice-participant-overlay svg{width:13px;height:13px;color:var(--red)}.voice-participant-compact{display:flex;align-items:center;gap:8px}.voice-participant-compact .voice-participant-avatar{width:32px;height:32px;font-size:11px}.voice-participant-compact .voice-participant-avatar.speaking{box-shadow:0 0 0 1.5px var(--bg-2),0 0 0 3px var(--green)}.voice-participant-compact .voice-participant-name{font-size:11px;color:var(--t1);max-width:96px;margin-top:0}.voice-participant-compact .voice-participant-overlay{width:16px;height:16px;bottom:-1px;right:-1px}.voice-participant-compact .voice-participant-overlay svg{width:10px;height:10px}.vp-vol-popup{background:var(--bg-4);border:1px solid var(--b1);border-radius:8px;padding:12px 16px;min-width:200px;box-shadow:0 4px 16px #00000080}.vp-vol-header{font-size:12px;font-weight:600;color:var(--t0);margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vp-vol-slider{display:flex;align-items:center;gap:10px}.vp-vol-slider svg{color:var(--primary)}.vp-vol-range{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-5);border-radius:3px;outline:none;cursor:pointer}.vp-vol-range::-webkit-slider-runnable-track{height:6px;border-radius:3px}.vp-vol-range::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:999px;background:var(--primary);cursor:pointer;margin-top:-5px;box-shadow:0 1px 4px #0006}.vp-vol-range::-moz-range-track{height:6px;border-radius:3px;background:var(--bg-5)}.vp-vol-range::-moz-range-progress{height:6px;border-radius:3px;background:var(--primary)}.vp-vol-range::-moz-range-thumb{width:16px;height:16px;border-radius:999px;background:var(--primary);border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.vp-vol-value{font-size:12px;font-weight:500;color:var(--primary);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.voice-connection-status{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#112830cc}.voice-connection-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.voice-connection-dot.connecting{background:var(--primary);animation:pulse 1.5s ease-in-out infinite}.voice-connection-dot.error{background:var(--red)}.voice-connection-text{font-size:12px;font-weight:500}.voice-connection-text.warning{color:var(--primary)}.voice-connection-text.error{color:var(--red)}.voice-connection-text.muted{color:var(--t2)}.screen-share-view{flex:1;display:flex;min-height:0;padding:8px;position:relative}.screen-share-split{display:flex;flex:1;min-height:0;min-width:0;gap:0}.screen-share-split.vertical{flex-direction:column}.screen-share-split.horizontal{flex-direction:row}.screen-share-pane{min-height:0;min-width:0;overflow:hidden}.screen-share-panel{width:100%;height:100%;position:relative;overflow:hidden;border-radius:8px;background:var(--bg-1)}.screen-share-panel video{width:100%;height:100%;object-fit:contain}.screen-share-panel-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4),transparent 40%);opacity:0;transition:opacity .2s;pointer-events:none}.screen-share-panel:hover .screen-share-panel-overlay{opacity:1}.screen-share-panel-label{position:absolute;bottom:8px;left:8px;background:#112830cc;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:500;color:var(--t0);pointer-events:auto}.screen-share-panel-btn{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border:none;border-radius:6px;background:#112830cc;color:var(--t1);cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;transition:background .15s,color .15s}.screen-share-panel-btn:hover{background:var(--bg-h);color:var(--t0)}.screen-share-panel-btn svg{width:16px;height:16px}.screen-share-toggle{position:absolute;top:12px;right:12px;z-index:10;width:32px;height:32px;border:none;border-radius:6px;background:#112830cc;color:var(--t1);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.screen-share-toggle:hover{background:var(--bg-h);color:var(--t0)}.screen-share-toggle svg{width:16px;height:16px}.screen-share-resize{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center}.screen-share-resize.vertical{height:8px;width:100%;cursor:row-resize}.screen-share-resize.horizontal{width:8px;height:100%;cursor:col-resize}.screen-share-resize-line{border-radius:999px;background:var(--bg-5);transition:background .15s}.screen-share-resize:hover .screen-share-resize-line{background:var(--primary)}.screen-share-resize.vertical .screen-share-resize-line{height:2px;width:48px}.screen-share-resize.horizontal .screen-share-resize-line{width:2px;height:48px}.spinner{width:24px;height:24px;border:2px solid var(--b1);border-top-color:var(--primary);border-radius:999px;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pinned-panel{position:absolute;top:33px;right:0;width:360px;max-height:420px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;z-index:30;display:flex;flex-direction:column;box-shadow:0 8px 24px #0006}.pinned-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--b1)}.pinned-header-title{font-size:13px;font-weight:600;color:var(--t0)}.pinned-close{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.pinned-close:hover{color:var(--t1);background:var(--bg-h)}.pinned-list{flex:1;overflow-y:auto;padding:8px}.pinned-empty{text-align:center;font-size:12px;color:var(--t2);padding:24px 12px}.pinned-item{position:relative;padding:10px 12px;background:var(--bg-3);border-radius:6px;margin-bottom:6px}.pinned-item:hover{background:var(--bg-4)}.pinned-item-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.pinned-item-author{font-size:12px;font-weight:500;color:var(--t0)}.pinned-item-time{font-size:10px;color:var(--t3);margin-left:auto}.pinned-item-content{font-size:13px;color:var(--t1);line-height:1.4;word-break:break-word}.pinned-item-unpin{position:absolute;top:8px;right:8px;width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.pinned-item:hover .pinned-item-unpin{opacity:1}.pinned-item-unpin:hover{color:var(--red);background:var(--red-s)}.search-panel{position:absolute;top:33px;right:0;width:400px;max-height:480px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;z-index:30;display:flex;flex-direction:column;box-shadow:0 8px 24px #0006}.search-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--b1)}.search-header-title{font-size:13px;font-weight:600;color:var(--t0)}.search-close{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.search-close:hover{color:var(--t1);background:var(--bg-h)}.search-input-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--b1)}.search-input-icon{color:var(--t3);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--t0);font-size:13px;font-family:var(--f-ui)}.search-input::placeholder{color:var(--t3)}.search-results{flex:1;overflow-y:auto;padding:8px}.search-empty{text-align:center;font-size:12px;color:var(--t2);padding:24px 12px}.search-count{font-size:11px;color:var(--t2);padding:0 4px 6px;border-bottom:1px solid var(--b1);margin-bottom:6px}.search-result-item{padding:10px 12px;background:var(--bg-3);border-radius:6px;margin-bottom:6px;cursor:pointer}.search-result-item:hover{background:var(--bg-4)}.search-result-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.search-result-author{font-size:12px;font-weight:500;color:var(--t0)}.search-result-time{font-size:10px;color:var(--t3);margin-left:auto}.search-result-content{font-size:13px;color:var(--t1);line-height:1.4;word-break:break-word;max-height:60px;overflow:hidden;text-overflow:ellipsis}.search-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0 4px}.search-page-btn{border:none;background:var(--bg-4);color:var(--t1);font-size:11px;padding:4px 10px;border-radius:4px;cursor:pointer}.search-page-btn:hover{background:var(--bg-5);color:var(--t0)}.search-page-btn:disabled{opacity:.4;cursor:default}.search-page-info{font-size:11px;color:var(--t2)}.dm-header{display:flex;align-items:center;gap:8px;padding:6px 14px;border-bottom:1px solid var(--b1);background:var(--bg-3);flex-shrink:0;height:33px}.dm-header-name{font-size:13px;font-weight:600;color:var(--t0)}.dm-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:13px}.dm-list-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:260px;max-height:360px;background:var(--bg-3);border:1px solid var(--b1);border-radius:10px;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;z-index:40;overflow:hidden}.dm-list-header{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--b1)}.dm-list-header span{font-size:13px;font-weight:600;color:var(--t0)}.dm-list-items{flex:1;overflow-y:auto;padding:4px}.dm-list-empty{text-align:center;font-size:12px;color:var(--t2);padding:24px 12px}.dm-list-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:background .08s;font-family:var(--f-ui)}.dm-list-item:hover{background:var(--bg-h)}.dm-list-item.active{background:var(--bg-4)}.dm-list-avatar{flex-shrink:0}.dm-list-info{min-width:0;flex:1;text-align:left}.dm-list-name{font-size:13px;font-weight:500;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.dm-list-item:hover .dm-list-name{color:var(--t0)}.dm-list-item.has-unread .dm-list-name{color:var(--t0);font-weight:600}.dm-unread-badge{flex-shrink:0;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;background:var(--red);border-radius:8px;padding:0 4px;font-family:var(--f-ui)}.dock-unread-badge.dm-badge{position:absolute;top:-4px;right:-4px;min-width:14px;height:14px;font-size:9px;font-weight:700;color:#fff;background:var(--red);border-radius:7px;padding:0 3px;display:flex;align-items:center;justify-content:center;line-height:1}.member-card-btn-dm{background:var(--primary-s);color:var(--primary)}.member-card-btn-dm:hover{background:var(--primary);color:#fff}.quick-switcher-overlay{position:fixed;inset:0;background:#00000080;z-index:60;display:flex;align-items:flex-start;justify-content:center;padding-top:120px}.quick-switcher{width:480px;max-height:420px;background:var(--bg-2);border:1px solid var(--b1);border-radius:10px;box-shadow:0 12px 40px #0009;display:flex;flex-direction:column;overflow:hidden;animation:vpIn .12s ease-out}.qs-input{width:100%;padding:14px 16px;border:none;border-bottom:1px solid var(--b1);background:transparent;color:var(--t0);font-size:15px;font-family:var(--f-ui);outline:none}.qs-input::placeholder{color:var(--t3)}.qs-results{flex:1;overflow-y:auto;padding:6px}.qs-empty{text-align:center;font-size:13px;color:var(--t2);padding:20px 12px}.qs-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-family:var(--f-ui);color:var(--t1);font-size:13px;text-align:left;transition:background .08s}.qs-item:hover,.qs-selected{background:var(--bg-h);color:var(--t0)}.qs-icon{font-size:14px;color:var(--t3);min-width:18px;text-align:center}.qs-selected .qs-icon{color:var(--primary)}.qs-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qs-category{font-size:11px;color:var(--t3);margin-left:auto}.qs-footer{display:flex;gap:16px;padding:8px 14px;border-top:1px solid var(--b1);font-size:11px;color:var(--t3)}.ctx-menu{position:fixed;z-index:70;min-width:160px;max-width:240px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;box-shadow:0 8px 24px #00000080;padding:4px;animation:vpIn .1s ease-out}.ctx-item{display:block;width:100%;padding:7px 10px;border:none;background:transparent;color:var(--t1);font-size:12px;font-family:var(--f-ui);text-align:left;border-radius:4px;cursor:pointer;transition:background .08s}.ctx-item:hover{background:var(--bg-h);color:var(--t0)}.ctx-danger{color:var(--red)}.ctx-danger:hover{background:var(--red-s);color:var(--red)}.ctx-disabled{opacity:.4;cursor:default}.ctx-disabled:hover{background:transparent;color:var(--t1)}.ctx-separator{height:1px;background:var(--b1);margin:4px 0}.sk-container{padding:8px}.sk-line{height:10px;border-radius:4px;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.sk-short{width:30%;margin-bottom:6px}.sk-medium{width:60%;margin-top:4px}.sk-long{width:80%}.sk-name{width:50%}.sk-message{display:flex;gap:10px;padding:8px 14px;align-items:flex-start}.sk-avatar{width:30px;height:30px;border-radius:50%;background:var(--bg-4);flex-shrink:0;animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%}.sk-body{flex:1;min-width:0}.sk-member{display:flex;gap:8px;padding:4px 10px;align-items:center}.sk-avatar-sm{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.sk-channel{display:flex;gap:6px;padding:5px 10px;align-items:center}.sk-ch-icon{width:12px;height:12px;border-radius:3px;background:var(--bg-4);flex-shrink:0}.sk-ch-name{width:60px}
