:root{--bg-tertiary: #1e1f22;--bg-secondary: #2b2d31;--bg-primary: #313338;--bg-input: #383a40;--bg-hover: #35373c;--bg-active: #404249;--bg-overlay: rgba(0, 0, 0, .7);--bg-modifier-hover: rgba(79, 84, 92, .16);--bg-modifier-active: rgba(79, 84, 92, .24);--bg-modifier-selected: rgba(79, 84, 92, .32);--accent: #5865f2;--accent-hover: #4752c4;--accent-active: #3c45a5;--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-gradient: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));--border-glow: transparent;--text-normal: #dbdee1;--text-muted: #949ba4;--text-faint: #80848e;--text-micro: #6d6f78;--text-link: #00a8fc;--text-positive: #23a55a;--text-warning: #f0b232;--text-danger: #f23f43;--header-primary: #f2f3f5;--header-secondary: #b5bac1;--interactive-normal: #b5bac1;--interactive-hover: #dbdee1;--interactive-active: #fff;--interactive-muted: #4e5058;--channel-icon: #80848e;--green: #23a55a;--yellow: #f0b232;--red: #f23f43;--border: #3f4147;--border-strong: #4e5058;--role-owner: #e74c3c;--role-admin: #f39c12;--role-mod: #2ecc71;--role-member: #949ba4;--elevation-low: 0 1px 0 rgba(4, 4, 5, .2), 0 1.5px 0 rgba(4, 4, 5, .05);--elevation-high: 0 8px 16px rgba(0, 0, 0, .24);--scrollbar-thin-thumb: #1a1b1e;--scrollbar-auto-thumb: #1a1b1e;--scrollbar-auto-track: transparent;--transition-fast: .1s ease;--transition-normal: .17s ease;--transition-slow: .2s ease;--font-display: "Segoe UI Variable Display", "Segoe UI", system-ui, sans-serif;--font-body: "Segoe UI Variable Text", "Segoe UI", system-ui, sans-serif;--font-mono: "Cascadia Code", "Consolas", monospace;--font-size-xxs: 10px;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-xxl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-pill: 24px;--radius-circle: 50%;--sidebar-width: 240px;--header-height: 48px;--message-group-spacing: 17px;--message-inline-spacing: 0;--avatar-size: 40px;--avatar-offset-left: 16px;--message-content-left: 72px;--message-content-right: 48px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-body);font-size:14px;color:var(--text-normal);background:var(--bg-tertiary);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1}#app{height:100%}button{font-family:inherit;border:none;cursor:pointer;outline:none;background:none;color:inherit}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea,select{font-family:inherit;border:none;outline:none}a{color:var(--text-link);text-decoration:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--scrollbar-auto-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-auto-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#232428}.channel-list::-webkit-scrollbar,.member-list::-webkit-scrollbar{width:6px}.channel-list::-webkit-scrollbar-thumb,.member-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thin-thumb)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.connect-page{display:flex;height:100vh;position:relative;overflow:hidden;background:var(--bg-tertiary)}.connect-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 800px 550px at 50% 38%,color-mix(in srgb,var(--accent) 8%,transparent) 0%,transparent 70%),radial-gradient(ellipse 350px 350px at 12% 80%,color-mix(in srgb,var(--accent-hover) 6%,transparent) 0%,transparent 65%),radial-gradient(ellipse 300px 300px at 88% 18%,color-mix(in srgb,var(--accent) 5%,transparent) 0%,transparent 65%);opacity:var(--border-glow-opacity, 1);pointer-events:none;z-index:0;animation:bgShift 20s ease-in-out infinite alternate}.settings-gear{position:absolute;top:16px;right:16px;z-index:10;width:36px;height:36px;border-radius:var(--radius-md);background:transparent;color:var(--text-faint);display:flex;align-items:center;justify-content:center;transition:all .2s}.settings-gear:hover{background:var(--bg-hover);color:var(--text-normal);transform:rotate(30deg)}.settings-gear svg{width:20px;height:20px}.server-panel{width:320px;background:linear-gradient(160deg,#1a1a2e,#0f3460,#16213e);display:flex;flex-direction:column;flex-shrink:0;z-index:1;position:relative;overflow:hidden;animation:slideInLeft .5s ease-out}.server-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 200px 200px at 30% 20%,rgba(139,92,246,.12) 0%,transparent 70%),radial-gradient(ellipse 150px 150px at 70% 80%,rgba(35,165,90,.06) 0%,transparent 70%);animation:bgShift 20s ease-in-out infinite alternate}.server-panel-header{padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.server-panel-header h2{font-size:11px;font-weight:700;color:#ffffff4d;letter-spacing:.05em;text-transform:uppercase}.server-branding{padding:24px 20px 20px;text-align:center;position:relative;z-index:1}.oc-logo{display:block;margin:0 auto 8px}.oc-glow-layer{animation:glowPulse 4s ease-in-out infinite}.brand-name{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}.brand-tagline{font-size:12px;color:#ffffff73;line-height:1.4}.header-actions{display:flex;gap:4px}.header-btn{width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;color:#ffffff4d;display:flex;align-items:center;justify-content:center;transition:all .15s;font-size:14px}.header-btn:hover{background:var(--bg-hover);color:#ffffffb3}.header-btn svg{width:14px;height:14px}.server-list{flex:1;overflow-y:auto;padding:8px}.server-item{display:flex;align-items:center;gap:8px;border-left:3px solid transparent;border-radius:0 8px 8px 0;padding:8px 10px;cursor:pointer;transition:background .15s;position:relative;opacity:0;animation:slideInLeft .4s ease-out forwards}.server-item:nth-child(1){animation-delay:.3s}.server-item:nth-child(2){animation-delay:.4s}.server-item:nth-child(3){animation-delay:.5s}.server-item:nth-child(4){animation-delay:.6s}.server-item:nth-child(5){animation-delay:.7s}.server-item:hover{background:#ffffff0a}.server-item.active{background:#8b5cf626;border-left-color:#8b5cf6}.server-item .srv-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;flex-shrink:0;transition:border-radius .2s;position:relative}.server-item:hover .srv-icon,.server-item.active .srv-icon{border-radius:10px}.server-item .srv-info{flex:1;min-width:0}.server-item .srv-name{font-size:12px;font-weight:600;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.server-item.active .srv-name{color:#fff}.server-item .srv-meta{display:flex;align-items:center;gap:6px;margin-top:2px}.server-item .srv-host{font-size:10px;color:#ffffff4d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.server-item .srv-last{font-size:10px;color:var(--text-micro);white-space:nowrap}.srv-status-dot{width:10px;height:10px;border-radius:50%;margin-left:auto;flex-shrink:0;position:static}.srv-status-dot.online{background:var(--green)}.srv-status-dot.slow{background:var(--yellow)}.srv-status-dot.offline{background:var(--red)}.srv-status-dot.unknown{background:var(--text-micro)}.srv-status-dot.checking{background:var(--text-micro);animation:pulse 1s ease-in-out infinite}.srv-status-text{font-size:9px;font-weight:600;margin-left:auto;flex-shrink:0;text-transform:uppercase}.srv-status-text.online{color:var(--green)}.srv-status-text.offline{color:var(--red)}.srv-status-text.unknown{color:var(--text-micro)}.srv-latency{font-size:10px;color:var(--text-micro);font-family:var(--font-mono);white-space:nowrap}.srv-latency.good{color:var(--green)}.srv-latency.warn{color:var(--yellow)}.srv-latency.bad{color:var(--red)}.srv-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s;flex-shrink:0}.server-item:hover .srv-actions{opacity:1}.srv-actions:has(.auto-login.active){opacity:1}.srv-btn{width:26px;height:26px;border-radius:var(--radius-sm);background:transparent;color:var(--text-faint);display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .15s}.srv-btn:hover{background:var(--bg-active);color:var(--text-normal)}.srv-btn.danger:hover{background:var(--red);color:#fff}.srv-btn.auto-login{color:var(--text-micro)}.srv-btn.auto-login.active{color:var(--accent);opacity:1}.srv-btn.auto-login:hover{color:var(--accent)}.srv-online-users{font-size:10px;color:var(--text-micro);white-space:nowrap}.srv-online-users.has-users{color:var(--green)}.srv-auto{font-size:10px;color:var(--accent);margin-left:4px}.server-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px}.server-empty-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;margin-bottom:8px}.server-empty-icon svg{width:28px;height:28px;color:var(--text-micro)}.server-empty h3{font-size:16px;color:var(--text-faint);font-weight:600}.server-empty p{font-size:13px;color:var(--text-micro);text-align:center;line-height:1.5}.server-panel-footer{padding:10px 12px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;gap:6px}.btn-add-server{flex:1;padding:8px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:13px;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-add-server:hover{background:var(--bg-hover);color:var(--text-normal)}.btn-footer-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--text-faint);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.btn-footer-icon:hover{background:var(--bg-hover);color:var(--text-normal)}.btn-footer-icon svg{width:16px;height:16px}.protocol-tip{padding:6px 20px 10px;font-size:11px;color:var(--text-micro);text-align:center;line-height:1.4}.protocol-tip code{font-family:var(--font-mono);font-size:10px;background:var(--bg-hover);padding:1px 4px;border-radius:2px;color:var(--text-faint)}.form-panel{flex:1;display:flex;align-items:center;justify-content:center;z-index:1;position:relative;padding:40px;animation:formSlideIn .45s cubic-bezier(.16,1,.3,1)}.form-container{width:100%;max-width:420px;background:var(--bg-primary);border:1px solid var(--border);border-radius:20px;padding:36px 40px 32px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 64px #00000059,0 0 0 1px color-mix(in srgb,var(--accent) 6%,transparent),inset 0 1px #ffffff0d;animation:formSlideIn .5s cubic-bezier(.16,1,.3,1)}.ac-logo{display:block;margin:0 auto 8px}.ac-glow-layer{animation:glowPulse 4s ease-in-out infinite}.form-logo{text-align:center;margin-bottom:32px;display:flex;flex-direction:column;align-items:center}.form-logo-mark{width:56px;height:56px;border-radius:16px;background:var(--accent);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px;box-shadow:0 8px 32px color-mix(in srgb,var(--accent) 25%,transparent)}.form-logo-mark svg{width:32px;height:32px}.form-logo h1{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--header-primary);letter-spacing:-.01em;margin-bottom:2px}.form-logo p{font-size:13px;color:var(--text-faint);margin-top:2px}.form-title{font-size:18px;font-weight:700;color:var(--header-primary);margin:0 0 20px;text-align:center}.error-banner{background:#2d1214;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px;display:none;align-items:flex-start;gap:8px;animation:shakeX .4s ease-in-out}.error-banner.visible{display:flex}.error-banner-icon{color:#f38688;font-size:16px;flex-shrink:0;margin-top:1px}.error-banner-text{color:#f38688;font-size:13px;line-height:1.4}.success-banner{background:#23a55a1f;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px;display:none;align-items:center;gap:8px}.success-banner.visible{display:flex}.success-banner-icon{color:var(--green);font-size:16px;flex-shrink:0}.success-banner-text{color:var(--green);font-size:13px}.form-group{margin-bottom:16px}.form-group--hidden{display:none}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-row .form-group.port-field{flex:0 0 100px}.form-label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase;margin-bottom:6px}.form-label .required{color:var(--red);margin-left:2px}.form-input{width:100%;padding:12px 14px;background:var(--bg-input);color:var(--text-normal);border:1px solid var(--border);border-radius:12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input::placeholder{color:var(--text-micro)}.form-input:hover{border-color:var(--border-strong)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.form-input.error{border-color:var(--red)}.password-wrapper{position:relative}.password-wrapper .form-input{padding-right:40px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;color:var(--text-faint);padding:4px;border-radius:var(--radius-sm);font-size:16px;transition:color .15s}.password-toggle:hover{color:var(--text-normal)}.form-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:16px;-webkit-user-select:none;user-select:none}.form-checkbox input{display:none}.checkbox-box{width:18px;height:18px;border-radius:var(--radius-sm);border:2px solid var(--border-strong);background:transparent;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.checkbox-box svg{opacity:0;transition:opacity .15s}.form-checkbox:hover .checkbox-box{border-color:var(--accent)}.form-checkbox input:checked+.checkbox-box{background:var(--accent);border-color:var(--accent)}.form-checkbox input:checked+.checkbox-box svg{opacity:1}.checkbox-label{font-size:13px;color:var(--text-muted)}.remember-password-group{display:flex;align-items:center;gap:8px;margin-bottom:16px;margin-top:-8px}.remember-password-group input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;margin:0;border-radius:6px}.remember-password-label{font-size:13px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.btn-primary{width:100%;padding:12px;border-radius:12px;background:var(--accent-gradient);color:#fff;font-size:15px;font-weight:600;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px color-mix(in srgb,var(--accent) 30%,transparent)}.btn-primary:hover{filter:brightness(1.08);box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 40%,transparent)}.btn-primary:hover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 25%,rgba(255,255,255,.1) 50%,transparent 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.btn-primary:active{filter:brightness(.92)}.btn-primary:disabled{background:var(--border-strong);color:var(--text-faint);cursor:not-allowed}.btn-primary.loading{pointer-events:none}.btn-primary.loading .btn-text{opacity:0}.btn-primary .btn-spinner{position:absolute;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center}.btn-primary.loading .btn-spinner{display:flex}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.btn-primary .spinner{border-color:#ffffff4d;border-top-color:#fff}.form-switch{margin-top:12px;font-size:13px;color:var(--text-faint)}.form-switch a{color:var(--text-link);cursor:pointer;text-decoration:none}.form-switch a:hover{text-decoration:underline}.form-forgot-link{display:block;text-align:right;margin:-4px 0 12px;font-size:13px;color:var(--text-link);cursor:pointer;text-decoration:none}.form-forgot-link:hover{text-decoration:underline}.form-forgot-link.form-group--hidden{display:none}.totp-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:10;animation:formSlideIn .3s cubic-bezier(.16,1,.3,1)}.totp-overlay--hidden{display:none}.auto-connect-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:10;animation:formSlideIn .3s cubic-bezier(.16,1,.3,1)}.auto-connect-overlay--hidden{display:none}.auto-connect-card{text-align:center;padding:40px}.auto-connect-spinner{margin:0 auto 20px;width:48px;height:48px}.auto-connect-spinner .spinner{width:48px;height:48px;border-width:3px}.auto-connect-title{font-size:20px;font-weight:700;color:var(--header-primary);margin-bottom:8px}.auto-connect-server{display:block;font-size:14px;color:var(--accent);margin-bottom:24px}.auto-connect-cancel{font-size:13px;color:var(--text-faint);cursor:pointer;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);padding:6px 20px;transition:all .15s}.auto-connect-cancel:hover{color:var(--text-normal);border-color:var(--text-muted)}.totp-icon{width:64px;height:64px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 32px color-mix(in srgb,var(--accent) 25%,transparent)}.totp-icon svg{width:32px;height:32px;color:#fff}.totp-title{text-align:center;font-size:22px;font-weight:700;color:var(--header-primary);margin-bottom:6px}.totp-subtitle{text-align:center;font-size:14px;color:var(--text-muted);margin-bottom:24px;line-height:1.5}.totp-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.totp-digit{width:48px;height:56px;border-radius:var(--radius-md);background:var(--bg-input);border:2px solid var(--border);color:var(--header-primary);font-size:24px;font-weight:700;text-align:center;transition:border-color .2s;font-family:var(--font-mono)}.totp-digit:focus{border-color:var(--accent)}.totp-digit.filled{border-color:var(--accent)}.totp-back{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--text-faint);cursor:pointer}.totp-back:hover{color:var(--text-link)}.totp-backup-link{display:block;text-align:center;margin-top:8px;font-size:12px;color:var(--text-micro);cursor:pointer}.totp-backup-link:hover{color:var(--text-link);text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);display:none;align-items:center;justify-content:center;z-index:100}.modal-overlay.visible{display:flex}.modal{background:var(--bg-primary);border-radius:var(--radius-md);width:440px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 48px #00000080;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1)}.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:18px;font-weight:700;color:var(--header-primary)}.modal-close{background:transparent;color:var(--text-faint);font-size:20px;padding:4px;border-radius:var(--radius-sm);transition:color .15s}.modal-close:hover{color:var(--text-normal)}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;background:var(--bg-secondary);border-radius:0 0 var(--radius-md) var(--radius-md);display:flex;justify-content:flex-end;gap:8px}.btn-cancel{padding:8px 16px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:13px;transition:all .15s}.btn-cancel:hover{color:var(--text-normal);text-decoration:underline}.btn-modal-save{padding:8px 20px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;transition:background .15s}.btn-modal-save:hover{background:var(--accent-hover)}.modal-danger-text{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:8px}.modal-danger-text strong{color:var(--header-primary)}.btn-danger{padding:8px 20px;border-radius:var(--radius-sm);background:var(--red);color:#fff;font-size:13px;font-weight:600;transition:background .15s}.btn-danger:hover{background:#d83135}.cert-warning{width:64px;height:64px;border-radius:50%;background:#f0b2321f;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.cert-warning svg{width:32px;height:32px;color:var(--yellow)}.cert-title{text-align:center;font-size:18px;font-weight:700;color:var(--header-primary);margin-bottom:8px}.cert-desc{text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}.cert-details{background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px;font-size:12px}.cert-row{display:flex;padding:4px 0}.cert-label{color:var(--text-faint);width:90px;flex-shrink:0}.cert-value{color:var(--text-normal);font-family:var(--font-mono);font-size:11px;word-break:break-all}.cert-fingerprint{color:var(--yellow)}.cert-actions{display:flex;gap:8px;justify-content:center;margin-top:8px}.btn-ghost{padding:8px 16px;border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text-muted);font-size:13px;transition:all .15s}.btn-ghost:hover{background:var(--bg-active);color:var(--text-normal)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:none;z-index:300;animation:settingsFadeIn .2s}.settings-overlay.visible{display:flex}.settings-layout{display:flex;width:100%;height:100%}.settings-nav{width:220px;background:var(--bg-secondary);padding:60px 8px 20px;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.settings-nav-title{font-size:11px;font-weight:700;color:var(--text-faint);letter-spacing:.05em;text-transform:uppercase;padding:8px 12px 4px;margin-top:8px}.settings-nav-title:first-child{margin-top:0}.settings-nav-item{padding:8px 12px;border-radius:var(--radius-sm);font-size:14px;color:var(--text-muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;background:transparent;text-align:left;width:100%}.settings-nav-item svg{width:16px;height:16px;flex-shrink:0}.settings-nav-sep{height:1px;background:var(--border);margin:4px 12px}.settings-content{flex:1;padding:60px 40px 40px;overflow-y:auto;max-width:740px}.settings-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:2px solid var(--border-strong);background:transparent;color:var(--text-faint);display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .15s;z-index:310}.settings-close:hover{border-color:var(--text-normal);color:var(--text-normal)}.settings-section-title{font-size:18px;font-weight:700;color:var(--header-primary);margin-bottom:20px}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.setting-info{flex:1}.setting-label{font-size:14px;color:var(--text-normal);margin-bottom:2px}.setting-desc{font-size:12px;color:var(--text-faint)}.setting-control{flex-shrink:0;margin-left:16px}.toggle{width:40px;height:22px;border-radius:11px;background:var(--border-strong);cursor:pointer;position:relative;transition:background .2s}.toggle:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s}.toggle.on:after{transform:translate(18px)}.setting-select{padding:6px 28px 6px 10px;border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-normal);border:1px solid var(--border);font-size:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2380848e' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;min-width:180px}.setting-select:hover{border-color:var(--border-strong)}.setting-select:focus{border-color:var(--accent)}.setting-slider{width:160px;height:6px;border-radius:3px;background:var(--border);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0000004d}.vu-meter{height:6px;border-radius:3px;background:var(--border);overflow:hidden;margin-top:8px}.vu-meter-fill{height:100%;border-radius:3px;background:var(--green);transition:width .1s}.keybind-btn{padding:6px 14px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);color:var(--text-normal);font-size:13px;font-family:var(--font-mono);cursor:pointer;transition:border-color .2s;min-width:100px;text-align:center}.keybind-btn:hover{border-color:var(--border-strong)}.keybind-btn.listening{border-color:var(--accent);color:var(--accent);animation:pulse 1s ease-in-out infinite}.mic-test-btn{padding:8px 16px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;transition:background .15s}.mic-test-btn:hover{background:var(--accent-hover)}.mic-test-btn.active{background:var(--red)}.mic-test-btn.active:hover{background:#d83135}.about-logo{text-align:center;margin-bottom:24px}.about-version{text-align:center;font-size:13px;color:var(--text-faint);margin-top:8px}.about-links{display:flex;gap:16px;justify-content:center;margin-top:16px}.about-link{font-size:13px;color:var(--text-link);cursor:pointer;background:transparent;padding:0}.about-link:hover{text-decoration:underline}.status-bar{position:absolute;bottom:0;left:0;right:0;height:4px;z-index:50;overflow:hidden;display:none}.status-bar.visible{display:block}.status-bar-fill{height:100%;background:var(--accent);width:0;box-shadow:0 0 12px #5865f240}.status-bar.indeterminate .status-bar-fill{width:30%;animation:indeterminate 1.2s ease-in-out infinite}.connected-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;z-index:200}.connected-overlay.visible{display:flex}.connected-icon-wrap{position:relative;margin-bottom:4px}.connected-srv-icon{width:72px;height:72px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;animation:checkPop .4s cubic-bezier(.16,1,.3,1)}.connected-check-badge{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;border:3px solid var(--bg-primary);animation:checkPop .5s cubic-bezier(.16,1,.3,1) .1s both}.connected-check-badge svg{width:14px;height:14px;color:#fff}.connected-text{font-size:20px;font-weight:700;color:var(--header-primary)}.connected-user{font-size:14px;color:var(--text-muted)}.connected-motd{font-size:13px;color:var(--text-faint);text-align:center;max-width:340px;line-height:1.5;margin-top:4px;font-style:italic}.connected-loader{margin-top:12px;display:flex;align-items:center;gap:8px;color:var(--text-micro);font-size:12px}.connected-loader .spinner{width:14px;height:14px;border-width:1.5px}@media(max-width:700px){.server-panel{width:260px}.form-container{max-width:340px}}@keyframes bgShift{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes formSlideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shakeX{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(2px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes settingsFadeIn{0%{opacity:0}to{opacity:1}}@keyframes indeterminate{0%{transform:translate(-100%)}to{transform:translate(440%)}}@keyframes checkPop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-30px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(30px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes glowPulse{0%,to{filter:blur(4px);opacity:.35}50%{filter:blur(6px);opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(prefers-reduced-motion:reduce){.server-panel,.form-panel,.form-container,.server-item{animation:none!important;opacity:1!important}.connect-page:before,.server-panel:before,.oc-glow-layer{animation:none!important}.btn-primary:hover:after{animation:none!important}}.app{display:flex;flex:1;min-height:0}.server-strip{width:64px;flex-shrink:0;background:var(--bg-tertiary, #1a1a1d);display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:8px;border-right:1px solid var(--border-glow, var(--border));overflow-y:auto;overflow-x:hidden}.server-strip::-webkit-scrollbar{width:0}.server-strip-stack{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.server-strip-divider{width:32px;height:1px;background:var(--border-glow, var(--border));margin:4px 0}.server-strip .server-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-radius var(--transition-fast);position:relative;flex-shrink:0}.server-strip .server-icon:hover{border-radius:16px}.server-strip .server-icon.active{border-radius:16px;box-shadow:0 0 0 2px var(--accent-primary, var(--accent))}.server-strip .server-icon.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:4px;height:28px;background:var(--header-primary);border-radius:0 2px 2px 0}.server-strip .server-icon-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;pointer-events:none}.server-strip .server-icon.add{background:var(--bg-secondary);color:var(--green, #43b581);border:1px dashed var(--border-glow, var(--border));font-size:22px;line-height:1}.server-strip .server-icon.add:hover{color:#fff;background:var(--green, #43b581);border-style:solid}.server-strip .server-icon.browse{width:48px;height:48px;border-radius:12px;background:var(--bg-hover);color:var(--accent);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:4px;transition:background var(--transition-fast),color var(--transition-fast)}.server-strip .server-icon.browse:hover{color:#fff;background:var(--accent)}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}.unified-sidebar{width:260px;background:var(--bg-secondary);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;min-height:0}.unified-sidebar-header{height:44px;padding:0 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-glow, var(--border));flex-shrink:0}.unified-sidebar-header .server-icon-sm{width:28px;height:28px;border-radius:var(--radius-md);background:var(--accent-gradient, var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700}.unified-sidebar-header .server-name{color:var(--header-primary);font-weight:700;font-size:13px}.unified-sidebar-header .server-online{color:var(--text-micro);font-size:9px}.sidebar-invite-btn{margin-left:auto;padding:4px 10px;border-radius:var(--radius-sm);background:var(--accent-primary, var(--accent));color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);flex-shrink:0}.sidebar-invite-btn:hover{opacity:.85}.sidebar-divider{height:1px;background:var(--border-glow, var(--border));margin:8px 12px}.channel-sidebar{width:260px;background:var(--bg-secondary);display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.channel-sidebar-header{height:48px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:none;box-shadow:var(--elevation-low);cursor:pointer;flex-shrink:0;transition:background .1s ease}.channel-sidebar-header:hover{background:var(--bg-hover)}.channel-sidebar-header h2{font-size:15px;font-weight:700;color:var(--header-primary)}.channel-list{flex:1;overflow-y:auto;padding:8px 0}.channel-list::-webkit-scrollbar-thumb,.dm-item-list::-webkit-scrollbar-thumb,.member-list::-webkit-scrollbar-thumb{background:transparent;transition:background .15s ease}.channel-sidebar:hover .channel-list::-webkit-scrollbar-thumb,.unified-sidebar:hover .dm-item-list::-webkit-scrollbar-thumb,.right-member-panel:hover .member-list::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--header-primary) 16%,transparent)}.channel-list::-webkit-scrollbar-thumb:hover,.dm-item-list::-webkit-scrollbar-thumb:hover,.member-list::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--header-primary) 28%,transparent)}.category{padding:16px 8px 4px 16px;display:flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.category-arrow{color:var(--text-muted);transition:transform .2s;display:inline-flex;align-items:center}.category-name{font-size:11px;font-weight:700;color:var(--text-faint);letter-spacing:.5px;text-transform:uppercase}.category-add-btn{margin-left:auto;font-size:16px;color:var(--text-faint);cursor:pointer;padding:0 4px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.category:hover .category-add-btn{opacity:1}.category-add-btn:hover{color:var(--text-normal)}.category-channels{overflow:hidden;transition:max-height .2s}.category.collapsed+.category-channels{max-height:0!important;overflow:hidden}.channel-item{display:flex;align-items:center;gap:6px;padding:6px 8px;margin:1px 8px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .1s;position:relative}.channel-item:hover{background:var(--bg-hover);color:var(--text-normal)}.channel-item.active{background:var(--bg-active);color:var(--accent)}.channel-draggable{cursor:grab}.channel-draggable:active{cursor:grabbing}.channel-reordering{-webkit-user-select:none;user-select:none;cursor:grabbing!important}.channel-reordering *{cursor:grabbing!important}.channel-draggable.dragging{opacity:.3}.channel-drop-indicator{box-shadow:0 2px 0 var(--accent) inset,0 -2px 0 var(--accent) inset;background:color-mix(in srgb,var(--accent) 15%,transparent);border-radius:var(--radius-sm)}.channel-item .ch-icon{opacity:.6;flex-shrink:0;width:20px;text-align:center;display:flex;align-items:center;justify-content:center}.channel-item.active .ch-icon{opacity:1}.channel-item .ch-name{font-size:14px;flex:1}.channel-item .unread-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.channel-item .unread-badge:empty{display:none}.channel-item.unread .ch-name{color:var(--header-primary);font-weight:600}.channel-item.unread:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:8px;border-radius:0 4px 4px 0;background:#fff}.voice-users-list{padding:2px 0 4px 36px}.voice-user-item{display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-muted);overflow:hidden}.voice-user-item .vu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.voice-user-item:hover{background:var(--bg-hover);color:var(--text-normal)}.voice-user-item .vu-avatar{width:20px;height:20px;border-radius:var(--radius-circle);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}.voice-user-item.speaking .vu-avatar{box-shadow:0 0 0 2px var(--green),0 0 8px #23a55a4d}.voice-user-item .vu-status,.voice-user-item .vu-muted{margin-left:2px;display:flex;align-items:center;flex-shrink:0}.voice-user-item--draggable{cursor:grab;user-select:none;-webkit-user-select:none;touch-action:none}.voice-user-item--draggable:active{cursor:grabbing}body.voice-user-dragging,body.voice-user-dragging *{cursor:grabbing!important}.voice-user-item.dragging{opacity:.4}.channel-item--drop-target{background:var(--accent);color:#fff;outline:2px solid var(--accent);outline-offset:-2px}.voice-user-item .vu-status{color:var(--text-muted)}.voice-user-item .vu-muted{color:var(--red)}.voice-user-item .vu-muted-local{color:var(--text-muted);opacity:.75}.voice-user-item .vu-name+.vu-status,.voice-user-item .vu-name+.vu-muted{margin-left:auto}.vu-live-badge{background:#ed4245;color:#fff;font-size:10px;font-weight:700;padding:1px 4px;border-radius:3px;margin-left:2px;flex-shrink:0}.vu-preview{margin:2px 0;height:0;overflow:hidden;transition:height var(--transition-slow) ease}.vu-preview video{width:100%;aspect-ratio:16 / 9;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-strong);box-shadow:0 0 4px var(--border-glow);display:block}.vu-preview video.preview-camera{object-fit:cover}.vu-preview video.preview-screen{object-fit:cover}.vu-preview-placeholder{width:100%;aspect-ratio:16 / 9;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-faint);font-size:var(--font-size-xxs);cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.voice-widget{background:var(--bg-secondary);border-top:1px solid var(--border);padding:8px;flex-shrink:0;display:none}.voice-widget.visible{display:block}.vw-header{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:12px}.vw-connected{color:var(--green);font-weight:700}.vw-connecting{color:var(--yellow, #f0b232)!important;animation:vw-pulse 1.4s ease-in-out infinite}@keyframes vw-pulse{0%,to{opacity:1}50%{opacity:.45}}.vw-timer{color:var(--green);font-size:11px;opacity:.8;font-variant-numeric:tabular-nums}.vw-channel{color:var(--text-muted)}.vw-controls{display:flex;gap:4px;padding:4px 4px 0}.vw-controls button{flex:1;height:32px;border-radius:var(--radius-sm);background:var(--bg-active);color:var(--text-muted);font-size:14px;transition:all .1s;display:flex;align-items:center;justify-content:center}.vw-controls button:hover{background:var(--bg-hover);color:var(--text-normal)}.vw-controls button:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.vw-controls button.active-ctrl{background:#f23f4333;color:var(--red)}.vw-controls button.disconnect{background:transparent;color:var(--red)}.vw-controls button.disconnect:hover{background:#f23f4326}.vw-grant-mic{display:block;width:calc(100% - 8px);margin:4px 4px 0;padding:6px 12px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:filter var(--transition-normal)}.vw-grant-mic:hover{filter:brightness(1.1)}.vw-grant-mic:disabled{opacity:.6;cursor:wait}.vw-signal{margin-left:auto;display:flex;align-items:center;gap:4px;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);transition:background .1s;position:relative}.vw-signal:hover{background:var(--bg-active)}.vw-signal-warn:after{content:"!";position:absolute;top:-3px;right:-3px;width:12px;height:12px;border-radius:50%;background:var(--red, #f23f43);color:#fff;font-size:9px;font-weight:700;line-height:12px;text-align:center;pointer-events:none;animation:vw-bad-pulse 1.6s ease-in-out infinite}@keyframes vw-bad-pulse{0%,to{box-shadow:0 0 #f23f438c}50%{box-shadow:0 0 0 5px #f23f4300}}.vw-ping{font-size:11px;font-weight:600}.vw-stats{padding:10px 12px;background:var(--bg-tertiary);border-bottom:1px solid var(--border);display:none}.vw-stats.visible{display:block}.vw-stats-title{font-size:11px;font-weight:700;color:var(--text-normal);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.vw-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.vw-stats-col-label{font-size:11px;font-weight:700;margin-bottom:4px}.vw-stats-col-label.out{color:var(--green)}.vw-stats-col-label.in{color:var(--yellow, #f0b232)}.vw-stats-row{font-size:11px;color:var(--text-muted);line-height:1.7}.vw-stats-row span{color:var(--text-normal)}.vw-stats-totals{border-top:1px solid var(--border);padding-top:8px}.vw-stats-totals-label{font-size:11px;font-weight:700;color:var(--accent, #5865f2);margin-bottom:4px}.vw-stats-totals-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.vw-stats-totals-row span{color:var(--text-normal)}.user-bar{height:52px;background:var(--bg-secondary);display:flex;align-items:center;padding:0 8px;gap:8px;flex-shrink:0}.user-bar .ub-avatar{width:32px;height:32px;border-radius:var(--radius-circle);flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;cursor:pointer}.user-bar .status-dot{position:absolute;bottom:-1px;right:-1px;width:12px;height:12px;border-radius:var(--radius-circle);border:3px solid var(--bg-secondary)}.user-bar .ub-info{flex:1;min-width:0;display:flex;flex-direction:column}.user-bar .ub-name{font-size:13px;font-weight:600;color:var(--header-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.user-bar .ub-status{font-size:11px;color:var(--text-muted);line-height:1.2}.user-bar .ub-controls{display:flex;gap:2px}.user-bar .ub-controls button{width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .1s}.user-bar .ub-controls button:hover{background:var(--bg-hover);color:var(--text-normal)}.user-bar .ub-controls button.active-ctrl{color:var(--red)}.status-picker{position:absolute;bottom:60px;left:8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:6px;box-shadow:0 8px 24px #00000080;z-index:100;display:none;min-width:160px}.status-picker.open{display:block}.status-option{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-normal);background:transparent;width:100%;text-align:left;transition:background .1s ease}.status-option:hover{background:var(--bg-hover)}.status-option .so-dot{width:10px;height:10px;border-radius:var(--radius-circle);flex-shrink:0}.chat-area{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.chat-header{height:48px;padding:0 16px;display:flex;align-items:center;gap:12px;border-bottom:none;box-shadow:var(--elevation-low);flex-shrink:0}.chat-header .ch-hash{color:var(--text-micro);font-size:22px;font-weight:600}.chat-header .ch-name{font-size:15px;font-weight:700;color:var(--header-primary)}.chat-header .ch-divider{width:1px;height:24px;background:var(--border)}.chat-header .ch-topic{font-size:13px;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header .ch-tools{display:flex;gap:4px;flex-shrink:0}.chat-header .ch-tools button{width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:16px;transition:all .1s;display:flex;align-items:center;justify-content:center}.chat-header .ch-tools button:hover{background:var(--bg-hover);color:var(--text-normal)}.chat-header .ch-tools button.active{color:var(--header-primary)}.chat-header .search-input{width:160px;height:28px;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-muted);font-size:12px;padding:0 8px;transition:width .3s}.chat-header .search-input::placeholder{color:var(--text-micro)}.chat-header .search-input:focus{width:240px;color:var(--text-normal)}.messages-slot{flex:1;min-height:0;display:flex;flex-direction:column}.typing-slot,.input-slot{flex-shrink:0}.messages-list-root{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}.messages-container{flex:1;overflow-y:auto;padding:16px 0;overscroll-behavior:contain;contain:strict;position:relative}.messages-container::-webkit-scrollbar-thumb{background:transparent;transition:background .15s ease}.messages-list-root:hover .messages-container::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--header-primary) 16%,transparent)}.messages-list-root .messages-container::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--header-primary) 28%,transparent)}.messages-container>*{overflow-anchor:none}.scroll-anchor{overflow-anchor:auto;height:1px}.scroll-to-bottom-btn{position:absolute;bottom:16px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-normal);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(10px);transition:opacity .15s ease,transform .15s ease,background .1s ease;pointer-events:none;z-index:5;box-shadow:0 4px 14px #00000059}.scroll-to-bottom-btn.visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-to-bottom-btn:hover{background:var(--bg-hover);color:var(--text-normal)}.scroll-to-bottom-btn__badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;background:var(--accent);color:#fff;border:2px solid var(--bg-primary);border-radius:10px;font-size:11px;font-weight:700;line-height:1;display:none;align-items:center;justify-content:center;pointer-events:none}.scroll-to-bottom-btn__badge.visible{display:flex}.channel-welcome{display:flex;flex-direction:column;align-items:flex-start;padding:16px 32px;margin-bottom:16px}.channel-welcome-icon{width:80px;height:80px;border-radius:var(--radius-circle);background:var(--bg-tertiary);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:68px;font-weight:700;line-height:1;margin-bottom:16px;flex-shrink:0}.channel-welcome-title{font-size:24px;font-weight:700;color:var(--header-primary);margin:0 0 8px}.channel-welcome-text{font-size:14px;color:var(--text-muted);margin:0}.msg-day-divider{display:flex;align-items:center;gap:8px;padding:8px 16px 16px;margin-bottom:8px}.msg-day-divider .line{flex:1;height:1px;background:var(--border)}.msg-day-divider .date{font-size:12px;font-weight:700;color:var(--text-muted)}.msg-unread-divider{display:flex;align-items:center;gap:8px;padding:4px 16px;margin:4px 0}.msg-unread-divider .line{flex:1;height:1px;background:var(--danger, #f04747)}.msg-unread-divider .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--danger, #f04747);padding:1px 6px;border-radius:4px}.message{padding:2px var(--message-content-right) 2px var(--message-content-left);position:relative;min-height:2.75rem;margin-top:var(--message-group-spacing);contain:layout style;transition:background .1s ease;border-left:2px solid transparent}.message:first-child,.msg-day-divider+.message{margin-top:0}.message:hover{background:var(--bg-modifier-hover)}.message.grouped{min-height:1.375rem;margin-top:var(--message-inline-spacing)}.message .msg-avatar{position:absolute;left:var(--avatar-offset-left);top:4px;width:var(--avatar-size);height:var(--avatar-size);border-radius:var(--radius-circle);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;cursor:pointer;overflow:hidden}.message .msg-avatar:hover{opacity:.8}.message.grouped .msg-avatar{display:none}.message .msg-hover-time{position:absolute;left:var(--avatar-offset-left);top:50%;transform:translateY(-50%);width:var(--avatar-size);text-align:center;font-size:.6875rem;color:var(--text-micro);font-variant-numeric:tabular-nums;display:none}.message.grouped:hover .msg-hover-time{display:block}.message .msg-header{display:flex;align-items:baseline;gap:8px}.message.grouped .msg-header{display:none}.message .msg-author{font-weight:600;font-size:var(--font-size-lg);cursor:pointer;text-decoration-color:currentColor}.message .msg-author:hover{text-decoration:underline;text-decoration-color:currentColor}.message .msg-time{font-size:var(--font-size-xs);color:var(--text-micro);font-variant-numeric:tabular-nums}.message .msg-edited{font-size:10px;color:var(--text-micro)}.msg-status{display:inline-flex;align-items:center;margin-left:4px;vertical-align:middle;opacity:.6}.msg-status-sending{color:var(--text-muted);animation:statusPulse 1.2s ease-in-out infinite}.msg-status-sent{color:var(--text-muted)}.msg-status-read{color:var(--accent, #00c8ff);opacity:.9}@keyframes statusPulse{0%,to{opacity:.4}50%{opacity:.9}}.msg-retry-btn{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;font-size:11px;border-radius:4px;background:var(--danger, #ed4245);color:#fff;border:none;cursor:pointer;opacity:.85}.msg-retry-btn:hover{opacity:1}.message .msg-text{line-height:1.45;word-break:break-word}.message .msg-text code{font-family:var(--font-mono);background:var(--bg-tertiary);padding:2px 5px;border-radius:3px;font-size:13px}.message .msg-text strong{font-weight:700}.message .msg-text em{font-style:italic}.message .msg-text s{text-decoration:line-through;opacity:.7}.message .msg-quote{margin:2px 0;padding:4px 10px;border-left:3px solid var(--text-muted);color:var(--text-muted);border-radius:0 3px 3px 0}.mention{background:color-mix(in srgb,var(--accent) 30%,transparent);color:var(--text-link);border-radius:3px;padding:0 2px;font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.mention:hover{background:var(--accent);color:#fff}.message.mentioned{background:#f0b23214;border-left:2px solid var(--yellow)}.message.mentioned:hover{background:#f0b2321f}.msg-reply-ref{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:4px;margin-left:-36px;padding-left:36px;position:relative;cursor:pointer}.msg-reply-ref:before{content:"";position:absolute;left:20px;bottom:50%;width:24px;height:12px;border-left:2px solid var(--text-micro);border-top:2px solid var(--text-micro);border-radius:6px 0 0}.msg-reply-ref .rr-author{color:var(--text-normal);font-weight:600}.msg-reply-ref .rr-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.msg-reply-ref:hover .rr-text{color:var(--text-normal)}.rr-avatar{width:16px;height:16px;border-radius:var(--radius-circle);font-size:8px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.msg-link{color:var(--text-link, #00aff4);text-decoration:none}.msg-link:hover{text-decoration:underline}.msg-embed{margin-top:8px;border-left:4px solid var(--accent);border-radius:var(--radius-sm);background:var(--bg-secondary);overflow:hidden;max-width:420px}.msg-embed-youtube{width:420px;max-width:100%}.msg-embed-yt-header{padding:10px 12px 6px}.msg-embed-yt-title{font-size:14px;font-weight:600;color:var(--text-link, #00aff4);text-decoration:none;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-embed-yt-title:hover{text-decoration:underline}.msg-embed-yt-player{position:relative;cursor:pointer}.msg-embed-thumb{display:block;width:100%;height:auto}.msg-embed-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:var(--radius-circle);background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:background .15s}.msg-embed-yt-player:hover .msg-embed-play{background:var(--red)}.msg-embed-iframe{width:100%;height:236px;border:none}.msg-embed-link{display:flex;flex-direction:column;padding:12px 16px;max-width:520px}.msg-embed-link-content{min-width:0}.msg-embed-host{font-size:12px;font-weight:600;color:var(--text-faint);margin-bottom:4px}.msg-embed-link-title{font-size:16px;font-weight:600;color:var(--text-link, #00aff4);text-decoration:none;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.msg-embed-link-title:hover{text-decoration:underline}.msg-embed-link-desc{font-size:14px;color:var(--text-muted);margin-top:6px;line-height:1.45;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.msg-embed-link-image{margin-top:10px}.msg-embed-link-img{max-width:100%;max-height:300px;object-fit:cover;border-radius:var(--radius-sm)}.msg-embed-url{font-size:13px;color:var(--text-link, #00aff4);text-decoration:none;word-break:break-all}.msg-embed-url:hover{text-decoration:underline}.msg-reactions{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.reaction-chip{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-md);background:color-mix(in srgb,var(--accent) 15%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);font-size:14px;cursor:pointer;transition:all .1s}.reaction-chip:hover{background:color-mix(in srgb,var(--accent) 30%,transparent)}.reaction-chip.me{border-color:var(--accent)}.reaction-chip .rc-count{font-size:12px;color:var(--text-normal)}.reaction-chip.add-reaction{background:transparent;border:1px dashed var(--border);color:var(--text-micro);font-size:14px;padding:2px 6px}.reaction-chip.add-reaction:hover{border-color:var(--text-muted);color:var(--text-muted)}.msg-codeblock-wrap{position:relative}.msg-codeblock{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin-top:4px;font-family:var(--font-mono);font-size:13px;line-height:1.5;overflow-x:auto;white-space:pre}.msg-codeblock-copy{position:absolute;top:4px;right:4px;padding:2px 8px;font-size:12px;background:var(--bg-tertiary);border:1px solid var(--border-color, rgba(255,255,255,.1));border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .15s ease,background .1s ease}.msg-codeblock-wrap:hover .msg-codeblock-copy{opacity:1;pointer-events:auto}.msg-codeblock-copy:hover{background:var(--bg-hover);color:var(--text-primary)}.msg-image{margin-top:4px;max-width:550px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;contain:layout style}.msg-image img{display:block;max-width:100%;max-height:300px;object-fit:contain;border-radius:var(--radius-md)}.msg-image .placeholder-img{width:100%;height:200px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);display:flex;align-items:center;justify-content:center;color:var(--text-micro);font-size:12px}.msg-image .placeholder-img.loading{opacity:.6}.gif-play-btn{position:absolute;bottom:8px;left:8px;width:32px;height:32px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:14px;line-height:32px;text-align:center;opacity:0;transition:opacity .15s ease;z-index:2;padding:0;display:flex;align-items:center;justify-content:center}.msg-image:hover .gif-play-btn,.gif-paused .gif-play-btn{opacity:1}.gif-play-btn:hover{background:#000000e6}.gif-play-btn.playing{font-size:11px;letter-spacing:1px}.gif-paused:after{content:"GIF";position:absolute;top:8px;left:8px;background:#000000b3;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.5px;pointer-events:none}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:zoom-in;animation:fadeIn .2s ease}.image-lightbox.dragging{cursor:grabbing}.image-lightbox-wrap{display:flex;align-items:center;justify-content:center;overflow:visible}.image-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 8px 48px #00000080;transition:transform .1s ease;cursor:zoom-in;-webkit-user-select:none;user-select:none}.image-lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:var(--radius-circle);background:#0009;color:#fff;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1}.image-lightbox-close:hover{background:#fff3}.msg-file{margin-top:4px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;max-width:400px}.msg-file-inner{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary)}.msg-file-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.msg-file-name{font-size:13px;color:var(--text-link);cursor:pointer}.msg-file-name:hover{text-decoration:underline}.msg-file-size{font-size:11px;color:var(--text-muted)}.msg-file-download{margin-left:auto;width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;border:none;transition:all .15s;flex-shrink:0}.msg-file-download:hover{background:var(--bg-hover);color:var(--text-normal)}.update-banner{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--accent);color:#fff;font-size:13px;font-weight:500;flex-shrink:0;z-index:100}.update-banner-text{flex:1}.update-banner-btn{padding:4px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.update-banner-btn:hover{opacity:.85}.update-banner-install{background:#fff;color:var(--accent)}.update-banner-later{background:#fff3;color:#fff}.system-msg{display:flex;align-items:center;gap:8px;padding:4px var(--message-content-right) 4px var(--message-content-left);margin-top:4px;position:relative}.system-msg .sm-icon{color:var(--green);display:inline-flex;align-items:center}.system-msg .sm-text{font-size:13px;color:var(--text-muted)}.system-msg .sm-text strong{color:var(--text-normal)}.system-msg .sm-time{font-size:11px;color:var(--text-micro);margin-left:auto}.msg-actions-bar{position:absolute;top:-16px;right:16px;display:flex;gap:2px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;opacity:0;pointer-events:none;transition:opacity .1s ease;box-shadow:0 2px 8px #0000004d;z-index:5}.message:hover .msg-actions-bar{opacity:1;pointer-events:auto;animation:actionBarPop .1s ease}.msg-actions-bar button{width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:14px;transition:all .1s;display:flex;align-items:center;justify-content:center}.msg-actions-bar button:hover{background:var(--bg-hover);color:var(--text-normal)}.reply-bar{display:none;padding:8px 16px 0;flex-shrink:0}.reply-bar.visible{display:flex;align-items:center;gap:8px}.reply-bar-inner{flex:1;background:var(--bg-input);border-radius:var(--radius-md) var(--radius-md) 0 0;padding:8px 12px;font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.reply-bar-inner strong{color:var(--text-normal)}.reply-bar .reply-close{width:24px;height:24px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;margin-left:auto}.reply-bar .reply-close:hover{color:var(--text-normal)}.typing-bar{height:24px;padding:0 16px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);flex-shrink:0}.typing-bar:empty{height:0}.typing-dots{display:inline-flex;gap:3px}.typing-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-muted);animation:typingAnim 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.message-input-wrap{padding:0 16px 20px;flex-shrink:0;position:relative}.message-input-wrap.reply-active{padding-top:0}.attachment-preview-bar{display:none;gap:8px;padding:8px 8px 4px;background:var(--bg-input);border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.attachment-preview-bar.visible{display:flex}.attachment-preview-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-secondary)}.attachment-preview-img{display:block;max-width:120px;max-height:120px;object-fit:cover;border-radius:var(--radius-sm)}.attachment-preview-file{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:20px}.attachment-preview-name{font-size:12px;color:var(--text-muted);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-preview-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:var(--radius-circle);background:#000000b3;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:background .15s}.attachment-preview-remove:hover{background:#fff3}.attachment-preview-item.uploading{opacity:.6}.attachment-preview-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:spinCentered 1s linear infinite}@keyframes spinCentered{to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes iconSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon[data-icon=loader]{animation:iconSpin 1s linear infinite}.attachment-upload-error{padding:6px 10px;font-size:12px;color:var(--red);background:#ed42451a;border-radius:var(--radius-sm)}.attachment-preview-bar.visible+.message-input-box{border-radius:0 0 var(--radius-md) var(--radius-md)}.message-input-box{background:var(--bg-input);border-radius:var(--radius-md);display:flex;align-items:flex-end;padding:4px;border:1px solid transparent;transition:border-color .15s ease;position:relative}.message-input-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.message-input-box.reply-mode{border-radius:0 0 var(--radius-md) var(--radius-md)}.input-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:18px;transition:background .1s ease,color .1s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.input-btn:hover{background:var(--bg-hover);color:var(--text-normal)}.msg-editor{flex:1;background:transparent;color:var(--text-normal);font-size:14px;padding:8px 4px;min-height:36px;max-height:200px;line-height:1.4;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;word-break:break-word;white-space:pre-wrap;outline:none}.msg-editor::-webkit-scrollbar{display:none}.msg-editor:empty:before{content:attr(data-placeholder);color:var(--text-micro);pointer-events:none}.msg-editor.msg-editor-over-limit{box-shadow:inset 0 0 0 1px var(--red, #ed4245);border-radius:var(--radius-sm)}.msg-counter{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none;pointer-events:none}.msg-counter.msg-counter--floating{position:absolute;bottom:calc(100% + 4px);right:96px}.msg-counter.msg-counter--inline{align-self:center;margin-left:auto;padding-right:8px}.reply-bar-inner .msg-counter--inline+.reply-close{margin-left:0}.msg-counter.msg-counter-over{color:var(--red, #ed4245);font-weight:600}.msg-editor strong,.msg-editor b{font-weight:700}.msg-editor em,.msg-editor i{font-style:italic}.msg-editor s,.msg-editor strike,.msg-editor del{text-decoration:line-through;opacity:.8}.msg-editor code{font-family:var(--font-mono);font-size:13px;background:var(--bg-tertiary);padding:1px 4px;border-radius:3px}.msg-editor-quote{margin:2px 0;padding:3px 10px;border-left:3px solid var(--text-muted);color:var(--text-muted);border-radius:0 3px 3px 0}.format-toolbar{position:absolute;display:none;align-items:center;gap:1px;padding:3px 5px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:0 2px 10px #00000059;z-index:50;left:50%;transform:translate(-50%);pointer-events:auto}.format-btn{background:none;border:none;color:var(--text-muted);width:28px;height:26px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.format-btn:hover{background:var(--bg-hover);color:var(--text-normal)}.member-list{width:240px;background:var(--bg-secondary);flex-shrink:0;overflow-y:auto;padding:8px 0;transition:width .2s}.member-list.hidden{width:0;padding:0;overflow:hidden}.sidebar-members-section{border-top:1px solid var(--border-glow, var(--border));overflow:hidden;display:flex;flex-direction:column;flex-shrink:0}.sidebar-members-header{padding:8px 8px 4px 16px;cursor:pointer;flex-shrink:0}.sidebar-members-content{flex:1;overflow-y:auto;min-height:0}.sidebar-resize-handle{height:4px;cursor:ns-resize;background:transparent;transition:background .15s;flex-shrink:0}.sidebar-resize-handle:hover{background:var(--accent-primary, var(--accent))}.sidebar-dm-section{border-bottom:1px solid var(--border-glow, var(--border));flex-shrink:0}.sidebar-dm-list{overflow:hidden;transition:max-height .2s}.sidebar-dm-section .category.collapsed+.sidebar-dm-list{max-height:0!important;overflow:hidden}.dm-header-unread-badge{background:var(--red);color:#fff;border-radius:10px;padding:0 6px;font-size:.65rem;font-weight:700;min-width:16px;text-align:center;line-height:16px;margin-left:4px;flex-shrink:0}.sidebar-dm-view-all{display:block;width:100%;padding:4px 16px;background:transparent;border:none;color:var(--text-link);font-size:.75rem;cursor:pointer;text-align:left;transition:color .15s}.sidebar-dm-view-all:hover{color:var(--accent)}.sidebar-members-section .member-list{width:100%}.sidebar-members-section .member-role-group{padding:8px 12px 2px;font-size:10px}.sidebar-members-section .member-item{padding:2px 8px;margin:0 6px;gap:6px}.sidebar-members-section .member-item .mi-avatar{width:22px;height:22px;font-size:9px}.sidebar-members-section .member-item .mi-status{width:8px;height:8px;border-width:2px}.sidebar-members-section .member-item .mi-name{font-size:12px}.member-role-group{padding:16px 16px 4px;font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}.member-item{display:flex;align-items:center;gap:8px;padding:4px 8px;margin:1px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s}.member-item:hover{background:var(--bg-hover)}.member-item .mi-avatar{width:32px;height:32px;border-radius:var(--radius-circle);flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff}.member-item .mi-status{position:absolute;bottom:-1px;right:-1px;width:12px;height:12px;border-radius:var(--radius-circle);border:3px solid var(--bg-secondary)}.member-item .mi-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-item.offline{opacity:.3}.member-item.offline .mi-avatar{filter:saturate(.3)}.member-item .mi-owner-crown{margin-left:auto;font-size:13px;line-height:1;flex-shrink:0;opacity:.9;filter:drop-shadow(0 0 2px rgba(243,156,18,.6))}.user-popup{position:fixed;z-index:200;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);width:300px;box-shadow:0 8px 32px #0009;display:none;overflow:hidden}.user-popup.open{display:block}.up-banner{height:60px}.up-body{padding:36px 16px 16px;position:relative}.up-avatar{width:64px;height:64px;border-radius:var(--radius-circle);position:absolute;top:-32px;left:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;color:#fff;border:4px solid var(--bg-primary)}.up-name{font-size:18px;font-weight:700;color:var(--header-primary)}.up-role{font-size:12px;margin-top:2px}.up-section{margin-top:12px;background:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.up-section-title{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.up-section-text{font-size:13px;color:var(--text-normal)}.up-roles{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px}.up-role-tag{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);background:var(--bg-hover);font-size:11px;color:var(--text-normal)}.up-role-dot{width:8px;height:8px;border-radius:50%}.up-avatar-status{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;border:3px solid var(--bg-primary)}.up-actions{margin-top:12px;background:var(--bg-secondary);border-radius:var(--radius-md);padding:8px}.up-msg-btn{width:100%;padding:8px 12px;background:var(--accent-primary, var(--accent));color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s;text-align:center}.up-msg-btn:hover{opacity:.85}.emoji-picker{position:absolute;z-index:200;bottom:100%;right:0;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);width:320px;box-shadow:0 8px 32px #0009;display:none;overflow:hidden;margin-bottom:4px}.emoji-picker.open{display:block}.ep-header{padding:12px;border-bottom:1px solid var(--border)}.ep-search{width:100%;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);padding:8px 10px;color:var(--text-normal);font-size:13px}.ep-search::placeholder{color:var(--text-micro)}.ep-category-label{padding:8px 12px 4px;font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}.ep-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:4px 8px 8px}.ep-emoji{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;border-radius:var(--radius-sm);background:transparent;transition:background .1s}.ep-emoji:hover{background:var(--bg-hover)}.gif-picker{position:absolute;z-index:200;bottom:100%;right:0;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);width:320px;height:400px;box-shadow:0 8px 32px #0009;display:none;overflow:hidden;margin-bottom:4px;flex-direction:column}.gif-picker.open{display:flex}.gp-header{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0}.gp-search{width:100%;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);padding:8px 10px;color:var(--text-normal);font-size:13px}.gp-search::placeholder{color:var(--text-micro)}.gp-attribution{font-size:10px;color:var(--text-micro);padding:4px 0 0;text-align:center}.gp-grid-area{flex:1;overflow-y:auto;padding:8px}.gp-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.gp-item{cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;transition:transform .1s}.gp-item:hover{transform:scale(1.03)}.gp-img{width:100%;display:block;object-fit:cover;border-radius:var(--radius-sm);min-height:80px;background:var(--bg-tertiary)}.gp-loading,.gp-empty{padding:48px 0;text-align:center;color:var(--text-faint);font-size:13px}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-tertiary);z-index:500;display:none}.settings-overlay.open{display:block}.settings-panel{display:flex;width:100%;height:100%;background:var(--bg-primary);overflow:hidden;position:relative}.settings-sidebar{width:220px;background:var(--bg-secondary);padding:24px 8px 16px;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.settings-cat{padding:8px 12px 4px;font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}.settings-nav-item{display:flex;align-items:center;gap:8px;padding:6px 12px;margin:1px 0;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;color:var(--text-muted);transition:all .1s;background:transparent;width:100%;text-align:left}.settings-nav-item:hover{background:var(--bg-hover);color:var(--text-normal)}.settings-nav-item.active{background:var(--bg-active);color:var(--header-primary)}.settings-sep{height:1px;background:var(--border);margin:8px 12px}.settings-nav-item.danger{color:var(--red)}.settings-nav-item.danger:hover{background:#f23f431a}.settings-content{flex:1;overflow-y:auto;padding:48px 40px;max-width:720px}.settings-content h1{font-size:20px;font-weight:700;color:var(--header-primary);margin-bottom:24px}.settings-content h3{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;margin:24px 0 8px}.settings-close-btn{width:36px;height:36px;border-radius:var(--radius-circle);background:transparent;border:2px solid var(--border-strong);color:var(--text-muted);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.settings-close-btn:hover{border-color:var(--text-normal);color:var(--text-normal)}.settings-pane{display:none}.settings-pane.active{display:block}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:14px;color:var(--text-normal)}.setting-desc{font-size:13px;color:var(--text-muted);margin-top:4px}.toggle{width:40px;height:24px;border-radius:12px;background:var(--text-faint);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--green)}.toggle:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s}.toggle.on:after{transform:translate(16px)}.settings-select{background:var(--bg-tertiary);color:var(--text-normal);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;width:200px;cursor:pointer}.mic-meter-wrap{margin-bottom:12px}.mic-meter-bar{position:relative;height:8px;border-radius:4px;background:var(--bg-tertiary);overflow:visible;cursor:pointer}.mic-meter-level{height:100%;border-radius:4px;width:0%;background:#43b581;transition:width 50ms linear;pointer-events:none}.mic-meter-threshold{position:absolute;top:-5px;width:12px;height:18px;background:#fff;border-radius:6px;left:50%;transform:translate(-50%);opacity:.9;cursor:grab;pointer-events:auto;z-index:1;box-shadow:0 1px 3px #0006;transition:opacity .1s;outline:none}.mic-meter-threshold:hover{opacity:1}.mic-meter-threshold:active{cursor:grabbing;opacity:1}.mic-meter-threshold:focus-visible{opacity:1;box-shadow:0 0 0 2px var(--accent-primary, var(--accent)),0 1px 3px #0006}.mic-meter-value{display:inline-block;margin-top:6px;font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.calibrate-row{display:flex;align-items:center;gap:10px;margin:6px 0 4px}.calibrate-status{font-size:12px;color:var(--text-muted);line-height:1.4}.mic-test-mode-group{display:inline-flex;gap:2px;padding:2px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.mic-test-mode-btn{background:transparent;color:var(--text-muted);border:none;padding:6px 12px;font-size:13px;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:background .1s,color .1s}.mic-test-mode-btn:hover:not(:disabled){color:var(--text-normal);background:var(--bg-hover)}.mic-test-mode-btn.active{background:var(--accent, #5865f2);color:#fff}.mic-test-mode-btn:disabled{opacity:.5;cursor:not-allowed}.mic-test-status{line-height:1.4}.mic-test-ptt-btn{display:inline-flex;align-items:center;justify-content:center;margin:8px 0;padding:10px 16px;background:var(--bg-input);color:var(--text-normal);border:1px solid var(--border-strong);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast),transform 60ms ease}.mic-test-ptt-btn:hover{background:var(--bg-hover)}.mic-test-ptt-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(.97);box-shadow:0 0 0 3px #5865f240}.mic-test-player{display:flex;align-items:center;gap:12px;padding:8px 12px;margin-top:4px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.mic-test-player-play{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;border:none;padding:0;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.mic-test-player-play:hover{background:var(--accent-hover)}.mic-test-player-play:active{background:var(--accent-active)}.mic-test-player-time{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:80px;text-align:center}.mic-test-player-progress{flex:1;height:6px;border-radius:3px;background:var(--bg-input);cursor:pointer;position:relative}.mic-test-player-progress-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:0%;border-radius:3px;background:var(--accent);pointer-events:none;transition:width 80ms linear}.slider-row{display:flex;align-items:center;gap:12px}.settings-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer}.slider-val{font-size:13px;color:var(--text-muted);min-width:40px;text-align:right}.account-card{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;margin-bottom:24px}.ac-btn{padding:8px 16px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;transition:background .15s;margin-left:auto}.ac-btn:hover{background:var(--accent-hover)}.ac-btn.account-delete-btn{background:var(--red);margin-left:0}.ac-btn.account-delete-btn:hover{background:#d83135}.ac-btn.account-delete-btn:disabled{opacity:.6;cursor:not-allowed}.account-delete-confirm{background:#f23f430f;border:1px solid rgba(242,63,67,.2);border-radius:var(--radius-sm);padding:16px;margin-top:12px}.account-banner{height:100px;border-radius:var(--radius-md) var(--radius-md) 0 0;background:var(--accent)}.account-avatar-wrap{position:relative;margin-top:-40px;margin-left:16px;width:80px}.account-avatar-large{width:80px;height:80px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:32px;color:#fff;border:4px solid var(--bg-secondary)}.account-status-dot{position:absolute;bottom:4px;right:4px;width:14px;height:14px;border-radius:50%;background:var(--green);border:3px solid var(--bg-secondary)}.account-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 16px}.account-header-name{font-size:20px;font-weight:700;color:var(--header-primary)}.account-fields{background:var(--bg-primary);border-radius:var(--radius-md);margin:0 16px 16px;padding:0}.account-field{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-bottom:1px solid var(--border)}.account-field:last-child{border-bottom:none}.account-field-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase}.account-field-value{font-size:15px;color:var(--text-normal);margin-top:4px}.account-field-edit{padding:4px 16px;border-radius:var(--radius-sm);background:var(--bg-active);color:var(--header-primary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.account-field-edit:hover{background:var(--bg-hover)}.settings-separator{height:1px;background:var(--border);margin:24px 0}.settings-section-title{font-size:18px;font-weight:700;color:var(--header-primary);margin-bottom:16px}.sound-row{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid var(--border)}.sound-row:last-child{border-bottom:none}.sound-row-head{display:flex;flex-direction:column;gap:2px}.sound-row-label{font-size:14px;font-weight:600;color:var(--header-primary)}.sound-row-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.sound-row-controls{display:flex;align-items:center;gap:12px}.sound-row-slider{flex:1;min-width:120px}.sound-row-volume-pct{min-width:40px;text-align:right;font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.sound-row-preview{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}.sound-row-preview svg{color:var(--accent)}.settings-status-options{display:flex;flex-direction:column;gap:2px}.settings-status-option{display:flex;align-items:center;padding:8px 12px;border-radius:4px;cursor:pointer;gap:12px;transition:background .1s ease}.settings-status-option:hover,.settings-status-option.active{background:var(--bg-active)}.settings-status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.settings-status-label{font-size:14px;font-weight:500;color:var(--text-normal)}.settings-status-desc{font-size:12px;color:var(--text-muted);margin-top:1px}.settings-sidebar-profile{display:flex;align-items:center;gap:12px;padding:0 12px 16px;margin-bottom:8px}.settings-sidebar-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;flex-shrink:0}.settings-sidebar-name{font-size:14px;font-weight:600;color:var(--header-primary)}.settings-sidebar-edit{font-size:12px;color:var(--text-muted);cursor:pointer}.settings-sidebar-edit:hover{color:var(--text-normal);text-decoration:underline}.settings-nav-item .icon{width:18px;height:18px;opacity:.7;flex-shrink:0}.settings-nav-item.active .icon{opacity:1}.settings-close-wrap{position:absolute;top:12px;right:16px;text-align:center;z-index:10;display:flex;flex-direction:column;align-items:center;gap:4px}.settings-esc-label{font-size:11px;color:var(--text-muted);font-weight:600}.settings-sidebar-logout{margin-top:auto;padding-top:8px}.theme-options{display:flex;gap:12px;margin-top:8px}.theme-opt{width:80px;height:56px;border-radius:var(--radius-md);cursor:pointer;border:2px solid transparent;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;transition:all .15s}.theme-opt:hover{border-color:var(--border-strong)}.theme-opt.active{border-color:var(--accent)}.theme-opt.dark{background:#313338;color:#fff}.theme-opt.light{background:#f2f3f5;color:#313338}.theme-opt.midnight{background:#0d0d0d;color:#b5bac1}.keybind-section-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:4px 0 8px}.keybind-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;column-gap:10px;padding:12px 8px 12px 0;border-bottom:1px solid var(--border)}.keybind-row__action{grid-column:2}.keybind-row__bind{grid-column:3;justify-self:end}.kbd{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-family:var(--font-mono);font-size:12px;color:var(--text-normal)}.kbd--static{background:var(--bg-hover);border-color:transparent;color:var(--text-muted);cursor:default}.kbd-wrap{position:relative;display:inline-flex}.kbd-clear{position:absolute;top:-7px;right:-7px;width:16px;height:16px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;background:var(--bg-primary);color:var(--text-muted);font-size:12px;line-height:1;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.kbd-clear:hover{background:var(--red, #e74c3c);border-color:var(--red, #e74c3c);color:#fff}.context-menu{position:fixed;z-index:300;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;box-shadow:0 8px 24px #00000080;min-width:180px;animation:contextMenuPop .1s ease}.context-menu-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-normal);background:transparent;width:100%;text-align:left;transition:background .1s ease,color .1s ease}.context-menu-item:hover{background:var(--accent);color:#fff}.context-menu-item.danger{color:var(--red)}.context-menu-item.danger:hover{background:var(--red);color:#fff}.context-menu-sep{height:1px;background:var(--border);margin:4px 0}.context-menu__item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-normal);background:transparent;width:100%;text-align:left;transition:background .1s ease,color .1s ease;position:relative}.context-menu__item:hover{background:var(--accent);color:#fff}.context-menu__item--danger{color:var(--red)}.context-menu__item--danger:hover{background:var(--red);color:#fff}.context-menu__item--has-submenu:after{content:"▶";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:9px;opacity:.55}.context-menu__item--has-submenu:hover:after{opacity:1}.context-menu__separator{height:1px;background:var(--border);margin:4px 0}.context-menu__submenu{position:fixed;z-index:1001;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;box-shadow:0 4px 12px #0006;min-width:160px;animation:contextMenuPop .1s ease}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 20px;font-size:13px;color:var(--text-normal);box-shadow:0 8px 24px #00000080;opacity:0;transition:opacity .3s;pointer-events:none}.toast.show{opacity:1;animation:toastSlideUp .3s ease}.toast-info{border-left:4px solid var(--accent)}.toast-error{border-left:4px solid var(--red)}.toast-success{border-left:4px solid var(--green)}.reconnecting-banner{background:var(--yellow);color:#1e1f22;text-align:center;padding:6px 16px;font-size:13px;font-weight:600;flex-shrink:0;display:none}.reconnecting-banner.visible{display:block}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);display:none;align-items:flex-start;justify-content:center;padding-top:80px;z-index:400}.search-overlay.open{display:flex}.search-overlay-box{width:540px;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:0 8px 48px #00000080;overflow:hidden}.search-overlay-input{width:100%;padding:16px 20px;background:transparent;color:var(--text-normal);font-size:16px;border:none;outline:none}.search-overlay-input:focus,.search-overlay-input:focus-visible{outline:none}.search-overlay-input::placeholder{color:var(--text-micro)}.search-overlay-results{max-height:400px;overflow-y:auto;border-top:1px solid var(--border)}.search-overlay-status{padding:12px 20px;color:var(--text-micro);font-size:14px}.search-result-item{padding:10px 20px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.search-result-item:hover,.search-result-item--active{background:var(--bg-secondary)}.search-result-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:12px}.search-result-channel{color:var(--text-micro);font-weight:600}.search-result-author{color:var(--text-normal);font-weight:600}.search-result-time{color:var(--text-micro);margin-left:auto;font-size:11px}.search-result-content{color:var(--text-muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qs-box{width:480px}.qs-input-row{display:flex;align-items:center;gap:10px;padding:0 16px;border-bottom:1px solid var(--border)}.qs-search-icon{color:var(--text-micro);display:flex;flex-shrink:0}.qs-input{flex:1;padding:16px 0;background:transparent;color:var(--text-normal);font-size:16px;border:none;outline:none}.qs-input:focus,.qs-input:focus-visible{outline:none}.qs-input::placeholder{color:var(--text-micro)}.qs-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;transition:background .1s}.qs-item:hover{background:var(--bg-hover)}.qs-item--active{background:var(--bg-secondary)}.qs-item__icon{color:var(--text-muted);display:flex;flex-shrink:0}.qs-item__name{color:var(--text-normal);font-size:14px;flex:1;min-width:0}.qs-item__category{color:var(--text-micro);font-size:11px;font-weight:500;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}.qs-empty{padding:24px 16px;text-align:center;color:var(--text-micro);font-size:14px}.qs-hint{display:flex;gap:16px;padding:8px 16px;border-top:1px solid var(--border);background:var(--bg-secondary)}.qs-hint__item{display:flex;align-items:center;gap:5px;color:var(--text-micro);font-size:11px}.qs-hint__item kbd{display:inline-flex;align-items:center;justify-content:center;padding:1px 5px;border-radius:3px;font-size:11px;background:var(--bg-active);color:var(--text-muted);border:1px solid var(--border);font-family:inherit;min-width:18px}.dm-back-header{height:44px;padding:0 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-glow, var(--border));cursor:pointer;transition:background var(--transition-fast)}.dm-back-header:hover{background:var(--bg-hover)}.dm-back-arrow{color:var(--accent-primary, var(--accent));font-size:16px}.dm-back-info{flex:1}.dm-back-title{color:var(--accent-primary, var(--accent));font-weight:600;font-size:12px}.dm-back-subtitle{color:var(--text-micro);font-size:9px}.dm-sidebar-header{padding:8px;flex-shrink:0}.dm-search{width:100%;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);padding:8px 10px;color:var(--text-normal);font-size:13px}.dm-search::placeholder{color:var(--text-micro)}.dm-nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin:1px 8px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .1s;font-size:14px}.dm-nav-item:hover{background:var(--bg-hover);color:var(--text-normal)}.dm-nav-item.active{background:var(--bg-active);color:var(--header-primary)}.dm-nav-item .dm-nav-icon{font-size:18px;width:20px;text-align:center}.dm-section-label{padding:16px 16px 4px;font-size:11px;font-weight:700;color:var(--text-faint);letter-spacing:.5px;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.dm-section-label .dm-add{width:18px;height:18px;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .1s}.dm-section-label .dm-add:hover{color:var(--text-normal)}.dm-item{display:flex;align-items:center;gap:10px;padding:6px 8px;margin:1px 8px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .1s}.dm-item:hover{background:var(--bg-hover);color:var(--text-normal)}.dm-item.active{background:var(--bg-active);color:var(--header-primary)}.dm-item .dm-avatar{width:32px;height:32px;border-radius:var(--radius-circle);flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff}.dm-item .dm-avatar .dm-status{position:absolute;bottom:-1px;right:-1px;width:12px;height:12px;border-radius:var(--radius-circle);border:3px solid var(--bg-secondary)}.dm-item.active .dm-avatar .dm-status{border-color:var(--bg-active)}.dm-item .dm-name{font-size:14px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-item .dm-close{width:20px;height:20px;border-radius:var(--radius-sm);background:transparent;color:var(--text-micro);font-size:14px;display:none;align-items:center;justify-content:center;cursor:pointer}.dm-item:hover .dm-close{display:flex}.dm-item .dm-close:hover{color:var(--text-normal)}.dm-item .dm-unread{width:8px;height:8px;border-radius:50%;background:#fff;flex-shrink:0}.dm-item-list{flex:1;min-height:0;overflow-y:auto}.friends-view{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}.friends-header{height:48px;padding:0 16px;display:flex;align-items:center;gap:16px;border-bottom:none;box-shadow:var(--elevation-low);flex-shrink:0}.friends-header .fh-title{font-size:15px;font-weight:700;color:var(--header-primary);display:flex;align-items:center;gap:8px}.friends-header .fh-title .fh-icon{font-size:20px}.friends-header .fh-divider{width:1px;height:24px;background:var(--border)}.friends-tab{padding:4px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .1s;background:transparent}.friends-tab:hover{background:var(--bg-hover);color:var(--text-normal)}.friends-tab.active{background:var(--bg-active);color:var(--header-primary)}.friends-tab.add-friend{background:var(--green);color:#fff;font-weight:600}.friends-tab.add-friend:hover{background:#1e8e4c}.friends-list{flex:1;overflow-y:auto;padding:8px 16px}.friends-search-bar{padding:8px 0 16px}.friends-search{width:100%;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);padding:10px 12px;color:var(--text-normal);font-size:13px}.friends-search::placeholder{color:var(--text-micro)}.friends-count{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;padding:8px 0}.friend-item{display:flex;align-items:center;gap:12px;padding:10px 8px;border-top:1px solid var(--border);cursor:pointer;transition:background .1s;border-radius:var(--radius-sm)}.friend-item:hover{background:var(--bg-hover)}.friend-item .fi-avatar{width:40px;height:40px;border-radius:var(--radius-circle);flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff}.friend-item .fi-status-dot{position:absolute;bottom:0;right:0;width:14px;height:14px;border-radius:var(--radius-circle);border:3px solid var(--bg-primary)}.friend-item:hover .fi-status-dot{border-color:var(--bg-hover)}.friend-item .fi-info{flex:1}.friend-item .fi-name{font-size:14px;font-weight:600;color:var(--header-primary)}.friend-item .fi-status-text{font-size:12px;color:var(--text-muted)}.friend-item .fi-actions{display:flex;gap:6px;opacity:0;transition:opacity .1s}.friend-item:hover .fi-actions{opacity:1}.fi-action-btn{width:36px;height:36px;border-radius:var(--radius-circle);background:var(--bg-secondary);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .1s;cursor:pointer;border:none}.fi-action-btn:hover{background:var(--bg-active);color:var(--text-normal)}.add-friend-form{padding:24px}.add-friend-form h2{font-size:16px;font-weight:700;color:var(--header-primary);margin-bottom:4px}.add-friend-form p{font-size:13px;color:var(--text-muted);margin-bottom:16px}.add-friend-input-row{display:flex;gap:8px}.add-friend-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--text-normal);font-size:14px}.add-friend-input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.add-friend-input::placeholder{color:var(--text-micro)}.add-friend-submit{padding:12px 20px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:14px;font-weight:600;transition:background .15s;white-space:nowrap}.add-friend-submit:hover{background:var(--accent-hover)}.dm-chat-header{height:48px;padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:none;box-shadow:var(--elevation-low);flex-shrink:0}.dm-chat-header .dch-avatar{width:24px;height:24px;border-radius:var(--radius-circle);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px;color:#fff}.dm-chat-header .dch-name{font-size:15px;font-weight:700;color:var(--header-primary)}.dm-chat-header .dch-status{font-size:12px;color:var(--text-muted)}.dm-profile{width:340px;background:var(--bg-secondary);flex-shrink:0;overflow-y:auto;transition:width .2s}.dm-profile.hidden{width:0;overflow:hidden}.dm-profile-banner{height:120px}.dm-profile-body{padding:48px 16px 16px;position:relative}.dm-profile-avatar{width:80px;height:80px;border-radius:var(--radius-circle);position:absolute;top:-40px;left:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:28px;color:#fff;border:6px solid var(--bg-secondary)}.dm-profile-name{font-size:20px;font-weight:700;color:var(--header-primary)}.dm-profile-role{font-size:12px;margin-top:2px}.dm-profile-section{margin-top:16px;background:var(--bg-primary);border-radius:var(--radius-md);padding:12px}.dm-profile-section-title{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.dm-profile-section-text{font-size:13px;color:var(--text-normal);line-height:1.5}.dm-profile-mutual{display:flex;align-items:center;gap:8px;padding:6px 0}.dm-profile-mutual .dpm-avatar{width:24px;height:24px;border-radius:var(--radius-circle);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:9px;color:#fff;flex-shrink:0}.dm-profile-mutual .dpm-name{font-size:13px;color:var(--text-muted)}.virtual-content{animation:virtualFadeIn .1s ease}@keyframes virtualFadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes typingAnim{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}@keyframes contextMenuPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pickerPop{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes actionBarPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.user-popup.open{animation:slideIn .15s cubic-bezier(.34,1.56,.64,1)}.emoji-picker.open,.gif-picker.open{animation:pickerPop .15s cubic-bezier(.4,0,.2,1)}.settings-overlay.open{animation:fadeIn .2s ease}.settings-panel{animation:settingsScale .2s cubic-bezier(.2,0,0,1)}@keyframes settingsScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.compact-mode .message{padding:2px 16px 2px 40px;min-height:20px;margin-top:4px}.compact-mode .message.grouped{min-height:16px;margin-top:0}.compact-mode .message .msg-avatar{width:24px;height:24px;font-size:10px;top:2px;left:8px}.compact-mode .message.grouped .msg-avatar,.compact-mode .message .msg-hover-time{display:none}.compact-mode .message.grouped .msg-hover-time{display:block}.compact-mode .message .msg-header{display:flex}.compact-mode .message.grouped .msg-header{display:none}.compact-mode .message .msg-text{line-height:1.25;font-size:13px}.compact-mode .message .msg-time{display:none}.compact-mode .msg-reactions{margin-top:2px}.compact-mode .msg-day-divider{padding:4px 16px;margin-bottom:2px}.compact-mode .channel-item{padding:3px 8px}.compact-mode .channel-item .ch-name{font-size:13px}.compact-mode .channel-sidebar-header{height:40px}.compact-mode .category{padding:10px 8px 2px 16px}.compact-mode .chat-header{height:38px}.channel-list-empty,.member-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;gap:4px}.channel-list-empty-text,.member-list-empty-text{color:var(--text-muted);font-size:var(--font-size-md)}.channel-list-empty-hint{color:var(--text-faint);font-size:var(--font-size-xs)}.compact-mode .member-item{padding:2px 8px}.compact-mode .member-item .mi-avatar{width:24px;height:24px;font-size:10px}.compact-mode .member-item .mi-name{font-size:13px}.compact-mode .member-role-group{padding:12px 16px 2px}.compact-mode .voice-user-item{padding:2px 8px;font-size:12px}.compact-mode .voice-user-item .vu-avatar{width:16px;height:16px;font-size:7px}.compact-mode .vu-preview{margin:1px 0}.compact-mode .vu-preview video,.compact-mode .vu-preview-placeholder{aspect-ratio:16 / 9}.compact-mode .user-bar{height:42px}.compact-mode .user-bar .ub-avatar{width:28px;height:28px;font-size:12px}.compact-mode .messages-container{padding:8px 0}@keyframes pinned-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pinned-panel{position:absolute;top:0;right:0;z-index:200;width:420px;max-height:80vh;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000080;display:flex;flex-direction:column;animation:pinned-enter .15s ease-out}.pinned-panel__header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.pinned-panel__header h3{font-size:16px;font-weight:600;color:var(--text-normal);margin:0;display:flex;align-items:center;gap:8px}.pinned-panel__title-group{display:flex;align-items:center;gap:8px}.pinned-panel__count{background:var(--bg-active);border-radius:var(--radius-pill);font-size:11px;color:var(--text-muted);padding:2px 6px;font-weight:500}.pinned-panel__close{width:24px;height:24px;color:var(--text-muted);border:none;background:none;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color .15s}.pinned-panel__close:hover{color:var(--text-normal)}.pinned-panel__list{flex:1;overflow-y:auto;padding:8px;scrollbar-width:thin;scrollbar-color:var(--bg-active) transparent}.pinned-panel__list::-webkit-scrollbar{width:6px}.pinned-panel__list::-webkit-scrollbar-track{background:transparent}.pinned-panel__list::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:3px}.pinned-msg{background:var(--bg-secondary);border-radius:var(--radius-md);padding:12px;margin-bottom:8px;border-left:3px solid var(--yellow);position:relative;transition:background .15s}.pinned-msg:last-child{margin-bottom:0}.pinned-msg:hover{background:var(--bg-hover)}.pinned-msg--skeleton{border-left-color:var(--bg-hover);pointer-events:none}.pinned-msg--skeleton:hover{background:var(--bg-secondary)}.pinned-msg--skeleton .pinned-msg__avatar{background:transparent}.pinned-msg__row{display:flex;gap:12px;align-items:flex-start}.pinned-msg__avatar{width:32px;height:32px;border-radius:var(--radius-circle);flex-shrink:0;font-size:14px;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:center}.pinned-msg__body{flex:1;min-width:0}.pinned-msg__head{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.pinned-msg__author{font-weight:600;font-size:14px;color:var(--text-normal)}.pinned-msg__time{font-size:11px;color:var(--text-micro);margin-left:auto}.pinned-msg__content{font-size:13px;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pinned-msg__actions{position:absolute;top:8px;right:8px;display:none;flex-direction:row;gap:4px}.pinned-msg:hover .pinned-msg__actions{display:flex}.pinned-msg__actions button{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--bg-primary);border:1px solid var(--border);color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.pinned-msg__actions button:hover{color:var(--text-normal);background:var(--bg-hover)}.pinned-msg__actions button.pinned-msg__unpin:hover{color:var(--red)}.pinned-panel__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.pinned-panel__empty-icon{font-size:48px;opacity:.4;margin-bottom:4px}.pinned-panel__empty-text{font-size:14px;color:var(--text-muted);margin-top:12px;line-height:1.5}.skeleton{background:var(--bg-secondary);border-radius:var(--radius-sm)}.skeleton--shimmer{background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-hover) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-circle)}.skeleton-line{height:16px;margin-bottom:4px;border-radius:var(--radius-sm)}.skeleton-line--short{width:60%}.skeleton-line--medium{width:80%}.skeleton-line--long{width:95%}.skeleton-msg{display:flex;gap:12px;padding:8px 16px 8px 72px;position:relative}.skeleton-msg .skeleton-avatar{position:absolute;left:16px}.skeleton-messages{display:flex;flex-direction:column;gap:4px;padding-top:8px;min-height:200px}.messages-loading-older{min-height:0;padding:8px 0}.skeleton-messages .skeleton--shimmer{background:linear-gradient(90deg,var(--bg-active) 0%,rgba(255,255,255,.1) 50%,var(--bg-active) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.skeleton-lines{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-channel-item{display:flex;align-items:center;gap:8px;padding:4px 8px;margin:2px 0}.skeleton-channel-icon{width:16px;height:16px;flex-shrink:0;border-radius:var(--radius-sm)}.skeleton-member-list{padding:8px 0;display:flex;flex-direction:column;gap:4px}.skeleton-member-row{display:flex;align-items:center;gap:10px;padding:4px 8px}.skeleton-member-row .skeleton-avatar{width:32px;height:32px;flex-shrink:0}.tooltip{position:fixed;background:#111214;color:#fff;font-size:var(--font-size-sm);font-weight:600;padding:8px 12px;border-radius:var(--radius-sm);pointer-events:none;z-index:9999;box-shadow:var(--elevation-high);animation:tooltipFadeIn .1s ease;white-space:nowrap;max-width:200px}.tooltip:after{content:"";position:absolute;border:5px solid transparent}.tooltip--top:after{top:100%;left:50%;transform:translate(-50%);border-top-color:#111214}.tooltip--right:after{right:100%;top:50%;transform:translateY(-50%);border-right-color:#111214}.tooltip--bottom:after{bottom:100%;left:50%;transform:translate(-50%);border-bottom-color:#111214}.tooltip--left:after{left:100%;top:50%;transform:translateY(-50%);border-left-color:#111214}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){.member-list{width:0;padding:0;overflow:hidden}}@media(max-width:800px){.channel-sidebar,.unified-sidebar{width:0;overflow:hidden}}.video-grid-slot{flex:1;min-height:0;overflow:hidden}.video-grid{display:flex;flex-wrap:wrap;gap:4px;padding:8px;height:100%;align-content:center;justify-content:center;background:var(--bg-primary, #313338)}.video-cell{position:relative;overflow:hidden;border-radius:var(--radius-md);background:var(--bg-tertiary);display:grid;grid-template-rows:1fr auto;grid-template-columns:1fr}.video-cell>video{grid-row:1;grid-column:1;width:100%;height:100%;min-height:0;object-fit:contain;background:#000}.video-username{position:absolute;bottom:8px;left:8px;color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.6);padding:2px 6px;border-radius:4px;background:#00000080}.video-cell:has(.video-tile-overlay) .video-username{bottom:40px}.vw-controls .active-ctrl{background:var(--brand-primary, #5865f2);color:#fff}.video-tile-overlay{grid-row:2;grid-column:1;display:flex;gap:6px;align-items:center;padding:6px 8px;background:#000000bf}.tile-mute-btn{background:#0009;border:none;border-radius:4px;color:var(--text-normal);padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tile-mute-btn:hover{background:#000c}.tile-fullscreen-btn{background:#0009;border:none;border-radius:4px;color:var(--text-normal);padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tile-fullscreen-btn:hover{background:#000c}.invite-preview-card{display:flex;align-items:center;gap:12px;margin-top:6px;padding:10px 12px;background:var(--bg-secondary, #2b2d31);border:1px solid var(--border, #3a3d44);border-radius:6px;max-width:480px}.invite-preview-card__icon,.invite-preview-card__icon-skeleton{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff;overflow:hidden;background:var(--bg-tertiary, #1f2125)}.invite-preview-card__icon-img{width:100%;height:100%;object-fit:cover}.invite-preview-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.invite-preview-card__name{font-weight:600;color:var(--text-normal, #dcddde);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-preview-card__meta{font-size:12px;color:var(--text-muted, #949ba4)}.invite-preview-card__desc{font-size:13px;color:var(--text-muted, #949ba4);margin-top:2px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.invite-preview-card__cta{flex-shrink:0;background:var(--accent, #5865f2);color:#fff;border:none;border-radius:4px;padding:8px 14px;font-weight:600;cursor:pointer}.invite-preview-card__cta:hover{filter:brightness(1.1)}.invite-preview-card__name-skel{height:14px;width:60%;border-radius:3px}.invite-preview-card__desc-skel{height:12px;width:80%;border-radius:3px}.invite-preview-card--error .invite-preview-card__error-text{color:var(--text-muted, #949ba4);font-style:italic;font-size:13px}.video-cell:fullscreen{width:100vw;height:100vh;max-width:none;max-height:none;border-radius:0;background:#000}.video-cell:fullscreen .video-tile-overlay{padding:10px 14px;background:#000000b3}.tile-leave-btn{background:#b41e1ebf;border:none;border-radius:4px;color:#fff;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tile-leave-btn:hover{background:#dc2828f2}.tile-volume-slider{width:80px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff4d;border-radius:2px;cursor:pointer}.tile-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}.tile-volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#fff;border:none;cursor:pointer}.video-grid.focus-mode{display:flex;flex-wrap:nowrap;flex-direction:column;height:100%}.video-focus-main{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.video-focus-main .video-cell{max-width:100%;max-height:100%;width:100%;height:100%}.video-focus-strip{display:flex;gap:4px;padding:4px;overflow-x:auto;flex-shrink:0;height:90px;background:var(--bg-tertiary)}.video-focus-strip .video-cell{width:120px;min-width:120px;height:100%;cursor:pointer;border:2px solid transparent;border-radius:4px}.video-focus-strip .video-cell:hover{border-color:var(--accent)}.invite-manager__list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto}.invite-manager__empty{text-align:center;color:var(--text-muted);padding:32px 0;font-size:14px}.invite-item{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:12px;transition:background .15s}.invite-item:hover{background:var(--bg-hover)}.invite-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.invite-item__code{font-family:Consolas,Courier New,monospace;font-size:14px;color:var(--header-primary);font-weight:600}.invite-item__actions{display:flex;gap:4px}.invite-item__copy,.invite-item__revoke{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;transition:all .15s;background:transparent}.invite-item__copy{color:var(--text-positive)}.invite-item__copy:hover{background:#23a55a26}.invite-item__revoke{color:var(--text-danger)}.invite-item__revoke:hover{background:#f23f4326}.invite-item__meta{font-size:12px;color:var(--text-muted)}.invite-item--skeleton:hover{background:var(--bg-secondary)}.invite-item--skeleton{pointer-events:none}.invite-item__code-skel{width:150px;height:18px}.invite-item__btn-skel{width:70px;height:22px;border-radius:var(--radius-sm)}.invite-item__meta-skel{width:60%;height:14px;margin-top:4px}.reduced-motion,.reduced-motion *{animation-duration:0s!important;transition-duration:0s!important}.high-contrast{--text-normal: #ffffff;--text-muted: #cccccc;--bg-active: rgba(255, 255, 255, .15)}.large-font{--font-size: 18px}.quick-switch-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center}.quick-switch-modal{width:380px;max-width:90vw;background:var(--bg-primary);border:1px solid var(--border-glow, var(--border));border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 16px 48px #0009}.quick-switch-header{padding:20px 20px 12px}.quick-switch-header h2{font-size:16px;font-weight:700;color:var(--header-primary);margin:0 0 4px}.quick-switch-subtitle{font-size:12px;color:var(--text-micro);margin:0}.quick-switch-list{padding:0 12px 8px}.quick-switch-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast)}.quick-switch-item:hover{background:var(--bg-hover);border-color:var(--border-glow, transparent)}.quick-switch-item.current{background:var(--bg-active);border-color:var(--border-glow, var(--border));cursor:default}.quick-switch-item.add-new{border-style:dashed;border-color:var(--border);color:var(--accent-primary, var(--accent))}.quick-switch-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--text-muted);flex-shrink:0}.quick-switch-item.current .quick-switch-icon{background:var(--accent-gradient, var(--accent));color:#fff}.quick-switch-item.add-new .quick-switch-icon{background:transparent;font-size:20px;color:inherit}.quick-switch-info{flex:1;min-width:0}.quick-switch-name{font-size:13px;font-weight:600;color:var(--text-normal)}.quick-switch-host{font-size:10px;color:var(--text-micro)}.quick-switch-connected-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.right-member-panel{width:240px;background:var(--bg-secondary);border-left:1px solid var(--border-glow, var(--border));display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.right-member-panel .member-list{width:100%;background:transparent;padding:0 0 16px;overflow-y:visible}.mp-total-header{padding:12px 16px 8px;font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-glow, var(--border));flex-shrink:0}.mp-section{flex-shrink:0}.mp-section-header{display:flex;align-items:center;gap:6px;padding:12px 16px 4px;font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .1s}.mp-section-header:hover{color:var(--text-normal)}.mp-section-arrow{font-size:9px;flex-shrink:0;color:var(--text-micro)}@media(max-width:1200px){.right-member-panel{display:none}}.quick-switch-footer{padding:12px;text-align:center;font-size:12px;color:var(--text-micro)}.server-browser-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--bg-primary);display:flex;flex-direction:column;overflow:hidden}.sb-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.sb-header-inner{display:flex;align-items:center;gap:12px;width:100%;max-width:1180px;margin:0 auto;padding:14px 22px}.sb-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-normal)}.sb-close{margin-left:auto;display:flex;padding:6px;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.sb-close:hover{background:var(--bg-hover);color:var(--text-normal)}.sb-body{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:22px;width:100%;max-width:1180px;margin:0 auto}.sb-invite{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px}.sb-invite h3{margin:0 0 6px;font-size:.95rem;font-weight:700;color:var(--text-normal)}.sb-invite p{margin:0 0 10px;font-size:.82rem;color:var(--text-muted)}.sb-invite-row{display:flex;gap:8px}.sb-invite-row .form-input{flex:1}.sb-invite-error{margin-top:6px;font-size:.8rem;color:var(--red);display:none}.sb-status{font-size:.85rem;color:var(--text-muted)}.sb-section-title{margin:0 0 8px;font-size:.95rem;font-weight:700;color:var(--header-secondary)}.sb-section-subtitle{margin:-4px 0 10px;font-size:.78rem;color:var(--text-muted)}.sb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.sb-empty{padding:16px;text-align:center;font-size:.9rem;color:var(--text-muted);grid-column:1 / -1}.sb-card{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.sb-card:hover{border-color:var(--border-strong)}.sb-card.active{border-color:var(--accent-primary, var(--accent))}.sb-card-head{display:flex;align-items:center;gap:12px}.sb-card-avatar{width:44px;height:44px;flex-shrink:0;border-radius:50%;overflow:hidden;background:var(--accent-gradient, var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px}.sb-card-avatar img{width:100%;height:100%;object-fit:cover}.sb-card-headtext{flex:1;min-width:0}.sb-card-name{font-weight:600;color:var(--text-normal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-card-meta{margin-top:2px;display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-muted)}.sb-card-tag{padding:1px 6px;border-radius:6px;background:var(--bg-active);color:var(--text-muted);font-size:.7rem}.sb-card-desc{font-size:.85rem;line-height:1.4;color:var(--text-muted);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden;min-height:calc(.85rem * 1.4 * 3)}.sb-card-cta{margin-top:auto;width:100%}.sb-card-skeleton{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md)}.sb-skel-head{display:flex;align-items:center;gap:12px}.sb-skel-lines{flex:1;min-width:0}.sb-card-skeleton .skeleton-line:last-child{margin-bottom:0}.sb-skel-cta{height:32px;border-radius:var(--radius-sm)}body.theme-neon-glow{--bg-tertiary: #0d0e10;--bg-secondary: #111214;--bg-primary: #1a1b1e;--bg-input: #252629;--bg-hover: #1f2023;--bg-active: #2a2b2e;--accent: #00c8ff;--accent-hover: #7b2fff;--accent-active: #6620e0;--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-gradient: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));--border: rgba(0, 200, 255, .08);--border-strong: rgba(0, 200, 255, .15);--border-glow: rgba(0, 200, 255, .08);--text-link: var(--accent);--color-success: #23a55a;--color-warning: #f0b232;--color-danger: #f23f43;--aurora-bg: radial-gradient(ellipse 62% 56% at 95% 2%, rgba(123, 47, 255, .15), transparent 72%), radial-gradient(ellipse 66% 60% at 5% 98%, rgba(0, 200, 255, .12), transparent 72%);--aurora-bg-soft: radial-gradient(ellipse 78% 72% at 100% 0%, rgba(123, 47, 255, .09), transparent 80%), radial-gradient(ellipse 82% 74% at 0% 100%, rgba(0, 200, 255, .07), transparent 80%)}body.theme-neon-glow,body.theme-neon-glow .server-strip,body.theme-neon-glow .unified-sidebar,body.theme-neon-glow .channel-sidebar,body.theme-neon-glow .chat-area,body.theme-neon-glow .right-member-panel,body.theme-neon-glow .voice-widget,body.theme-neon-glow .vw-stats,body.theme-neon-glow .user-bar{background-image:var(--aurora-bg);background-attachment:fixed;background-repeat:no-repeat}body.theme-neon-glow .settings-panel{background-image:var(--aurora-bg-soft);background-repeat:no-repeat}body.theme-neon-glow .settings-sidebar{background-color:transparent}body.theme-neon-glow .server-browser-page{background-image:var(--aurora-bg-soft);background-repeat:no-repeat}body.theme-light{--bg-input: #f4f4f5;--bg-hover: #eef0f3;--bg-active: #e1e7ee;--bg-overlay: rgba(15, 20, 25, .45);--bg-modifier-hover: rgba(15, 20, 25, .04);--bg-modifier-active: rgba(15, 20, 25, .07);--bg-modifier-selected: rgba(0, 149, 196, .1);--accent: #0095c4;--accent-hover: #5b18d1;--accent-active: #4912a8;--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-gradient: linear-gradient(135deg, #00c8ff 0%, #7b2fff 100%);--text-muted: #5b6b7d;--text-faint: #8b97a3;--text-micro: #a4adb6;--text-link: var(--accent);--header-primary: #060607;--header-secondary: #232a30;--interactive-normal: #5b6b7d;--interactive-hover: #232a30;--interactive-active: #060607;--interactive-muted: #a4adb6;--channel-icon: #707b85;--border: #e4e9ef;--border-strong: #d0d8e0;--border-glow: transparent;--green: #1b8a4a;--yellow: #d49826;--red: #d83a3e;--color-success: var(--green);--color-warning: var(--yellow);--color-danger: var(--red);--text-positive: var(--green);--text-warning: var(--yellow);--text-danger: var(--red);--role-owner: #c0392b;--role-admin: #d68910;--role-mod: #229954;--elevation-low: 0 1px 0 rgba(15, 20, 25, .06), 0 1.5px 0 rgba(15, 20, 25, .03);--elevation-high: 0 8px 24px rgba(15, 20, 25, .1), 0 1px 3px rgba(15, 20, 25, .06);--scrollbar-thin-thumb: #c5cdd5;--scrollbar-auto-thumb: #c5cdd5;--scrollbar-auto-track: transparent}body.theme-dark{--bg-input: #242f3d;--bg-hover: #202b38;--bg-active: #2c3a4a;--bg-overlay: rgba(10, 15, 20, .65);--bg-modifier-hover: rgba(255, 255, 255, .04);--bg-modifier-active: rgba(255, 255, 255, .07);--bg-modifier-selected: rgba(84, 169, 235, .14);--accent: #54a9eb;--accent-hover: #4a9add;--accent-active: #3f8bca;--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-gradient: linear-gradient(135deg, #54a9eb 0%, #4087c7 100%);--border-glow: transparent;--text-muted: #8096a8;--text-faint: #65788a;--text-micro: #55636f;--text-link: #62b0ee;--header-primary: #ffffff;--header-secondary: #aebfcc;--interactive-normal: #8a99a8;--interactive-hover: #c8d4de;--interactive-active: #ffffff;--interactive-muted: #41505d;--channel-icon: #6d7d8c;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .11);--green: #4dcd5e;--yellow: #e3a23c;--red: #e9596d;--color-success: var(--green);--color-warning: var(--yellow);--color-danger: var(--red);--text-positive: var(--green);--text-warning: var(--yellow);--text-danger: var(--red);--scrollbar-thin-thumb: #2a3744;--scrollbar-auto-thumb: #2a3744;--scrollbar-auto-track: transparent;--elevation-low: 0 1px 0 rgba(0, 0, 0, .22), 0 1.5px 0 rgba(0, 0, 0, .1);--elevation-high: 0 8px 24px rgba(0, 0, 0, .45)}body.theme-midnight{--bg-input: #1e2336;--bg-hover: #1a1f30;--bg-active: #262c42;--bg-overlay: rgba(6, 8, 14, .7);--bg-modifier-hover: rgba(255, 255, 255, .04);--bg-modifier-active: rgba(255, 255, 255, .07);--bg-modifier-selected: rgba(91, 155, 245, .15);--accent: #5b9bf5;--accent-hover: #4d8ae6;--accent-active: #427bd0;--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-gradient: linear-gradient(135deg, #5b9bf5 0%, #6f7bf0 100%);--border-glow: transparent;--text-muted: #8088a0;--text-faint: #656d85;--text-micro: #555c72;--text-link: #6ba8ff;--header-primary: #ffffff;--header-secondary: #b4bcd4;--interactive-normal: #8a90a8;--interactive-hover: #c8cce0;--interactive-active: #ffffff;--interactive-muted: #3e4459;--channel-icon: #6b7290;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .11);--green: #45c97a;--yellow: #e3b341;--red: #ec5f6b;--color-success: var(--green);--color-warning: var(--yellow);--color-danger: var(--red);--text-positive: var(--green);--text-warning: var(--yellow);--text-danger: var(--red);--scrollbar-thin-thumb: #2a3146;--scrollbar-auto-thumb: #2a3146;--scrollbar-auto-track: transparent;--elevation-low: 0 1px 0 rgba(0, 0, 0, .28), 0 1.5px 0 rgba(0, 0, 0, .12);--elevation-high: 0 8px 24px rgba(0, 0, 0, .5)}
