: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}.connect-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 600px 400px at 15% 80%,rgba(88,101,242,.08) 0%,transparent 70%),radial-gradient(ellipse 500px 350px at 85% 20%,rgba(88,101,242,.06) 0%,transparent 70%),radial-gradient(ellipse 300px 300px at 50% 50%,rgba(35,165,90,.04) 0%,transparent 70%);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:slideInRight .5s ease-out .1s both}.form-container{width:100%;max-width:400px;animation:formSlideIn .5s cubic-bezier(.16,1,.3,1)}.form-logo{text-align:center;margin-bottom:28px}.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 #5865f240}.form-logo-mark svg{width:32px;height:32px}.form-logo h1{font-family:var(--font-display);font-size:28px;font-weight:700;color:#fff;letter-spacing:-.01em}.form-logo p{font-size:14px;color:var(--text-muted);margin-top:4px}.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 #5865f233}.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:linear-gradient(135deg,#5865f2,#4752c4);color:#fff;font-size:15px;font-weight:600;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px #5865f24d}.btn-primary:hover{background:linear-gradient(135deg,#6872f5,#5460d9);box-shadow:0 4px 16px #5865f266}.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{background:linear-gradient(135deg,#4752c4,#3b44b0)}.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 rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.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}.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:#fff;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 #5865f240}.totp-icon svg{width:32px;height:32px;color:#fff}.totp-title{text-align:center;font-size:22px;font-weight:700;color:#fff;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:#fff;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:#fff}.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:#fff}.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:#fff;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:#fff;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:#fff}.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}.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}.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:#fff;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-shrink: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:#fff}.channel-list{flex:1;overflow-y:auto;padding:8px 0}.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:#fff}.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:#5865f226;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:#fff;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;animation:speak-pulse 1.5s ease-in-out infinite}@keyframes speak-pulse{0%,to{box-shadow:0 0 0 2px var(--green),0 0 8px #23a55a4d}50%{box-shadow:0 0 0 2px var(--green),0 0 14px #23a55a80}}.voice-user-item .vu-status,.voice-user-item .vu-muted{margin-left:2px;display:flex;align-items:center;flex-shrink:0}.voice-user-item .vu-status{color:var(--text-muted)}.voice-user-item .vu-muted{color:var(--red)}.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 rgba(0,200,255,.15);box-shadow:0 0 4px #00c8ff14;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 rgba(0,200,255,.08);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-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.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}.vw-signal:hover{background:var(--bg-active)}.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:#11121499;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 rgba(17,18,20,.6)}.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:#fff;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:#fff}.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:#fff}.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-container{flex:1;overflow-y:auto;padding:16px 0;overscroll-behavior:contain;contain:strict;position:relative}.messages-container>*{overflow-anchor:none}.scroll-anchor{overflow-anchor:auto;height:1px}.scroll-to-bottom-btn{position:absolute;bottom:8px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;opacity:0;transform:translateY(10px);transition:opacity .15s ease,transform .15s ease;pointer-events:none;z-index:5;box-shadow:0 2px 8px #0000004d}.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-primary)}.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:#fff;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)}.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)}.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}.mention{background:#5865f24d;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:#5865f226;border:1px solid rgba(88,101,242,.3);font-size:14px;cursor:pointer;transition:all .1s}.reaction-chip:hover{background:#5865f24d}.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}.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-textarea{flex:1;background:transparent;color:var(--text-normal);font-size:14px;resize:none;padding:8px 4px;min-height:36px;max-height:200px;line-height:1.4}.msg-textarea::placeholder{color:var(--text-micro)}.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)}.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:#fff}.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%}.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;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:500;display:none;align-items:center;justify-content:center}.settings-overlay.open{display:flex}.settings-panel{display:flex;width:900px;max-width:calc(100vw - 80px);height:80vh;max-height:720px;background:var(--bg-primary);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000080;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;border-radius:12px 0 0 12px}.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:#fff}.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:#fff;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}.mic-meter-threshold:hover{opacity:1}.mic-meter-threshold:active{cursor:grabbing;opacity:1}.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:#fff}.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:#fff;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:#fff;margin-bottom:16px}.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:#fff}.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}.accent-swatches{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.accent-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:none;outline:none;transition:transform .12s}.accent-swatch:hover{transform:scale(1.1)}.accent-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor}.accent-hex-row{display:flex;align-items:center;gap:4px;margin-top:4px}.accent-hex-prefix{font-size:14px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.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:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.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)}.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}.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}.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}.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:#fff}.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:#fff}.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}.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:#fff;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:#fff}.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:#fff}.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:#fff;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:#fff}.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:#fff}.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__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}.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)}.video-cell video{width:100%;height:100%;object-fit:cover}.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}.vw-controls .active-ctrl{background:var(--brand-primary, #5865f2);color:#fff}.video-tile-overlay{position:absolute;bottom:0;right:0;padding:6px;display:flex;gap:4px;align-items:center;z-index:2;opacity:0;transition:opacity .15s}.video-cell:hover .video-tile-overlay,.video-tile-overlay.muted{opacity:1}.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-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{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:#fff;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)}.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:#fff;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}.quick-switch-footer{padding:12px;text-align:center;font-size:12px;color:var(--text-micro)}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}
