:root{--bg-primary: #1e1e2e;--bg-secondary: #181825;--bg-tertiary: #11111b;--bg-surface: #252536;--bg-surface-hover: #2a2a3d;--bg-message-hover: #22223a;--bg-accent: #5b6abf;--bg-accent-hover: #4f5dae;--bg-accent-subtle: rgba(91, 106, 191, .12);--text-primary: #cdd6f4;--text-secondary: #a6adc8;--text-muted: #9ca0b8;--text-link: #89b4fa;--text-header: #f5f5f7;--border-color: rgba(255, 255, 255, .06);--border-subtle: rgba(255, 255, 255, .03);--input-bg: #313244;--input-border: rgba(255, 255, 255, .08);--scrollbar-thumb: #45475a;--scrollbar-track: transparent;--online: #a6e3a1;--idle: #f9e2af;--danger: #f38ba8;--offline: #8b8fa5;--voice: #a6e3a1;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--elevation-1: 0 1px 2px rgba(0, 0, 0, .15);--elevation-2: 0 2px 8px rgba(0, 0, 0, .2);--elevation-3: 0 4px 16px rgba(0, 0, 0, .25);--transition-fast: .12s ease-out;--transition-normal: .2s ease-out;--transition-spring: .3s cubic-bezier(.16, 1, .3, 1);--glow-accent: 0 0 20px rgba(91, 106, 191, .3), 0 0 60px rgba(91, 106, 191, .08);--glow-accent-hover: 0 0 40px rgba(91, 106, 191, .5), 0 0 100px rgba(91, 106, 191, .15)}.skip-to-content{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden;z-index:10000;padding:8px 16px;background:var(--bg-accent);color:#fff;text-decoration:none;border-radius:var(--radius-sm);font-weight:600}.skip-to-content:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;overflow:visible}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font);font-size:14px;color:var(--text-primary);background:var(--bg-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#585b70}input,button,textarea{font-family:var(--font);font-size:14px}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}.login-backdrop{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg-tertiary)}.login-modal{background:var(--bg-primary);border-radius:var(--radius-lg);padding:36px;width:420px;max-width:90vw;box-shadow:var(--elevation-3);border:1px solid var(--border-color)}.login-modal h1{text-align:center;color:var(--text-header);margin-bottom:4px;font-size:24px;font-weight:700;letter-spacing:-.5px}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:24px;font-size:14px}.login-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px}.login-tabs button{flex:1;padding:8px 12px;border:none;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.login-tabs button.active{background:var(--bg-accent);color:#fff;box-shadow:var(--elevation-1)}.login-tabs button:hover:not(.active){color:var(--text-primary);background:var(--bg-surface)}.login-modal label{display:block;color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;margin-top:16px}.login-modal input{width:100%;padding:10px 14px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.login-modal input:focus{border-color:var(--bg-accent)}.login-error{color:var(--danger);font-size:13px;margin-top:8px}.login-submit{width:100%;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;margin-top:24px;transition:all var(--transition-spring);letter-spacing:.3px;box-shadow:var(--glow-accent)}.login-submit:hover:not(:disabled){background:var(--bg-accent-hover);transform:translateY(-1px);box-shadow:var(--glow-accent-hover)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:backdrop-fade-in .2s ease-out}.modal{background:var(--bg-primary);border-radius:var(--radius-lg);padding:28px;width:440px;max-width:90vw;box-shadow:var(--elevation-3);border:1px solid var(--border-color);animation:modal-scale-in .3s cubic-bezier(.16,1,.3,1)}.modal h2{color:var(--text-header);margin-bottom:20px;font-size:20px;font-weight:700;letter-spacing:-.3px}.modal label{display:block;color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;margin-top:16px}.modal input{width:100%;padding:10px 14px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.modal input:focus{border-color:var(--bg-accent)}.modal-error{color:var(--danger);font-size:13px;margin-top:8px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.modal-cancel{padding:10px 18px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}.modal-cancel:hover{color:var(--text-primary)}.modal-submit{padding:10px 22px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-spring);box-shadow:var(--glow-accent)}.modal-submit:hover{background:var(--bg-accent-hover);box-shadow:var(--glow-accent-hover);transform:translateY(-1px)}.chat-header-modes{color:var(--text-muted);font-size:11px;margin-left:8px;font-family:SF Mono,Fira Code,monospace;background:var(--bg-surface);padding:2px 8px;border-radius:var(--radius-sm)}.chat-header-lock{font-size:13px;margin-right:4px}.chat-header-e2ee{font-size:11px;font-weight:600;color:var(--online);background:#a6e3a11f;padding:2px 8px;border-radius:var(--radius-xl);margin-left:8px;letter-spacing:.04em}.mode-badge{display:inline-block;font-size:10px;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);margin-left:6px;vertical-align:middle;letter-spacing:.3px}.mode-badge-moderated{background:#f9e2af26;color:var(--idle)}.member-mode-prefix{color:var(--bg-accent);font-weight:700;margin-right:2px}.channel-lock{font-size:12px;margin-right:6px;flex-shrink:0}.message-encrypted{font-size:10px;font-weight:600;color:var(--online);background:#a6e3a11f;padding:1px 6px;border-radius:var(--radius-xl);margin-left:4px;letter-spacing:.03em}.decrypt-failed{color:var(--danger);font-style:italic}.mode-toggles{display:flex;flex-direction:column;gap:8px;margin-top:6px}.mode-toggle{display:flex!important;align-items:center;gap:10px;color:var(--text-primary)!important;font-size:13px!important;font-weight:400!important;text-transform:none!important;margin:0!important;cursor:pointer}.mode-toggle input[type=checkbox]{width:auto;accent-color:var(--bg-accent)}.mode-input{margin-top:2px;margin-left:26px;width:calc(100% - 26px)!important}.voice-panel{background:var(--bg-surface);border-top:1px solid var(--border-color);padding:12px}.voice-panel-header{margin-bottom:8px}.voice-panel-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--online)}.voice-panel-dot{width:8px;height:8px;border-radius:50%;background:var(--online);animation:voice-pulse 2s ease-in-out infinite}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.5}}.voice-panel-channel{font-size:11px;color:var(--text-muted);margin-top:2px}.voice-panel-users{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.voice-user{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.voice-user.speaking{background:#a6e3a11a}.voice-user-avatar{width:24px;height:24px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0;transition:box-shadow var(--transition-fast)}.voice-user.speaking .voice-user-avatar{box-shadow:0 0 0 2px var(--online)}.voice-user-name{font-size:13px;color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-user-icon{font-size:12px;opacity:.6}.voice-controls{border-top:1px solid var(--border-color);padding-top:10px}.voice-controls-row{display:flex;gap:4px}.voice-btn{flex:1;padding:6px;border:none;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;font-size:14px;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.voice-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.voice-btn.active{color:var(--danger)}.voice-btn-disconnect{background:#f38ba826;color:var(--danger)}.voice-btn-disconnect:hover{background:#f38ba840}.voice-ptt-bar{margin-top:6px;padding:4px 10px;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-muted);font-size:11px;text-align:center;transition:all var(--transition-fast)}.voice-ptt-bar.active{background:#a6e3a126;color:var(--online)}.channel-voice-btn{margin-left:auto;background:none;border:none;cursor:pointer;font-size:12px;opacity:0;transition:opacity var(--transition-fast);padding:2px 4px;border-radius:var(--radius-sm);flex-shrink:0}.channel-item:hover .channel-voice-btn,.channel-voice-btn.active{opacity:1}.channel-voice-btn.active{color:var(--online)}.channel-voice-btn:hover{background:var(--bg-surface)}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-primary);text-align:center;padding:40px}.error-boundary h2{color:var(--danger)}.error-boundary p{color:var(--text-muted);max-width:400px}.error-boundary button{padding:10px 20px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.error-boundary button:hover{background:var(--bg-accent-hover)}.toast-container{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius-md);box-shadow:var(--elevation-3);font-size:13px;max-width:360px;animation:toast-in .3s ease-out}.toast-warning{background:#f9e2aff2;color:#1e1e2e;border:1px solid var(--idle)}.toast-info{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.video-grid{display:grid;gap:4px;padding:8px 0;max-height:300px;overflow-y:auto}.video-tile{position:relative;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:16 / 9}.video-tile video{width:100%;height:100%;object-fit:cover;display:block}.video-tile.self video{transform:scaleX(-1)}.video-tile-label{position:absolute;bottom:4px;left:6px;font-size:11px;color:#fff;background:#00000080;padding:2px 6px;border-radius:var(--radius-sm)}.voice-btn.active-video{color:var(--online);background:#a6e3a126}.call-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:150}.call-modal{background:var(--bg-primary);border-radius:var(--radius-lg);padding:36px;width:320px;text-align:center;box-shadow:var(--elevation-3);border:1px solid var(--border-color)}.call-modal-avatar{width:64px;height:64px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin:0 auto 16px}.call-modal-name{color:var(--text-header);font-size:18px;font-weight:600;margin-bottom:4px}.call-modal-status{color:var(--text-muted);font-size:13px;margin-bottom:24px}.call-modal-actions{display:flex;gap:12px;justify-content:center}.call-btn{padding:12px 24px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.call-btn-accept{background:#43b581;color:#fff}.call-btn-accept:hover{background:#3ca374}.call-btn-reject{background:#f04747;color:#fff}.call-btn-reject:hover{background:#d84040}.dm-header-actions{display:flex;gap:6px;margin-left:auto}.dm-call-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.dm-call-btn:hover{background:var(--bg-surface);color:var(--text-primary)}@media(max-width:1024px){.member-list{display:none}.sidebar{width:220px;min-width:220px}}@media(max-width:768px){.app-layout{flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0)}.app-layout.sidebar-visible .sidebar{display:flex}.app-layout.sidebar-visible .chat-view,.app-layout.sidebar-visible .member-list{display:none}.sidebar{width:100%;min-width:100%;max-height:100%;border-bottom:1px solid var(--border-color);overflow-y:auto;transition:transform .3s ease}.member-list{display:none}.chat-view{flex:1;min-height:0}.chat-header{flex-wrap:wrap}.chat-header-topic{display:none}.message-input input{font-size:16px}.msg-image{max-width:100%}.app-layout.has-mobile-nav{padding-bottom:56px}}@media(max-width:480px){.sidebar{max-height:100%}.message{padding:3px 12px}.message-avatar{width:32px;height:32px;font-size:12px;margin-right:10px}.message-input{padding:0 12px 12px;gap:6px}.message-input button{padding:12px 16px}.pinned-panel,.search-panel{width:100%;right:0;left:0}.channel-item{padding:10px 12px;min-height:44px}.member-item{padding:8px 12px;min-height:44px}.sidebar-add-btn,.chat-header-btn{min-width:44px;min-height:44px}}@media(max-height:500px)and (orientation:landscape){.sidebar{display:none}.app-layout.sidebar-visible .sidebar{display:flex;position:fixed;top:0;left:0;bottom:0;width:280px;z-index:1000;box-shadow:var(--elevation-3)}}.mobile-nav{display:none}@media(max-width:768px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:9000;background:var(--bg-tertiary);border-top:1px solid var(--border-color);padding-bottom:env(safe-area-inset-bottom,0)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;background:none;border:none;color:var(--text-muted);font-size:10px;cursor:pointer;gap:2px;min-height:56px;transition:color var(--transition-fast)}.mobile-nav-item:hover,.mobile-nav-item.active{color:var(--bg-accent)}.mobile-nav-icon{font-size:20px;line-height:1}.mobile-nav-label{font-size:10px;font-weight:500}}.markdown-content{line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}.inline-code{background:var(--bg-surface);padding:1px 6px;border-radius:var(--radius-sm);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.9em;color:var(--text-primary)}.code-block{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:12px 16px;overflow-x:auto;margin:8px 0;border:1px solid var(--border-color)}.code-block code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;color:var(--text-primary);line-height:1.5}.md-blockquote{border-left:3px solid var(--bg-accent);padding:4px 12px;margin:6px 0;background:var(--bg-surface);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary)}.md-header{color:var(--text-header);font-weight:700;margin:8px 0 4px}h3.md-header{font-size:1.15em}h4.md-header{font-size:1.05em}h5.md-header{font-size:1em;color:var(--text-secondary)}.md-list{padding-left:20px;margin:4px 0}.md-list li{margin:2px 0;color:var(--text-primary)}.spoiler{background:var(--bg-tertiary);color:transparent;border-radius:var(--radius-sm);padding:0 4px;cursor:pointer;transition:all var(--transition-normal);-webkit-user-select:none;user-select:none}.spoiler:hover{background:var(--bg-surface-hover)}.spoiler.revealed{color:var(--text-primary);background:var(--bg-surface);cursor:default}.thread-panel{position:absolute;top:0;right:0;width:320px;height:100%;background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;z-index:30;box-shadow:var(--elevation-3);animation:thread-slide-in .2s ease-out}@keyframes thread-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.thread-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.thread-panel-header h3{color:var(--text-header);font-size:15px;font-weight:700}.thread-panel-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.thread-panel-header button:hover{color:var(--text-primary);background:var(--bg-surface)}.thread-panel-parent{padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-surface);flex-shrink:0}.thread-panel-messages{flex:1;overflow-y:auto;padding:8px 0;min-height:0}.thread-panel-input{padding:12px 16px;border-top:1px solid var(--border-color);flex-shrink:0}.thread-panel-input input{width:100%;padding:10px 14px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.thread-panel-input input:focus{border-color:var(--bg-accent)}.thread-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-sm);background:var(--bg-accent-subtle);color:var(--bg-accent);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-top:4px}.thread-badge:hover{background:#6c7bda33}.poll{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;margin-top:8px;max-width:400px}.poll.poll-closed{opacity:.8}.poll-question{font-weight:700;color:var(--text-header);font-size:15px;margin-bottom:12px}.poll-multi-label{font-size:12px;color:var(--text-muted);margin-bottom:8px}.poll-options{display:flex;flex-direction:column;gap:0}.poll-option{position:relative;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:6px;cursor:pointer;border:1px solid var(--border-color);background:var(--bg-primary);transition:all var(--transition-fast);overflow:hidden;display:flex;align-items:center;justify-content:space-between;text-align:left;width:100%;color:var(--text-primary);font-size:14px}.poll-option:hover:not(:disabled){border-color:var(--bg-accent)}.poll-option:disabled{cursor:default;opacity:.7}.poll-option-voted{border-color:var(--bg-accent);background:var(--bg-accent-subtle)}.poll-option-bar{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#5b6abf33,#89b4fa1f);border-radius:var(--radius-sm);transition:width var(--transition-normal);pointer-events:none}.poll-option-voted .poll-option-bar{background:linear-gradient(90deg,#5b6abf4d,#89b4fa2e)}.poll-option-text{position:relative;z-index:1}.poll-option-pct{position:relative;z-index:1;font-size:12px;color:var(--text-muted);margin-left:8px;flex-shrink:0}.poll-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-muted)}.poll-total{color:var(--text-muted)}.poll-footer button{background:none;border:none;color:var(--text-link);cursor:pointer;font-size:12px;padding:0;transition:color var(--transition-fast)}.poll-footer button:hover{color:var(--bg-accent)}.poll-closed-label{color:var(--text-danger, #f04747);font-weight:600}.global-search-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:200}.global-search-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:600px;max-width:90vw;max-height:70vh;box-shadow:var(--elevation-3);display:flex;flex-direction:column;overflow:hidden}.global-search-input{padding:16px 20px;border-bottom:1px solid var(--border-color)}.global-search-input input{width:100%;padding:12px 16px;border:1px solid var(--input-border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--text-primary);font-size:16px;outline:none;transition:border-color var(--transition-fast)}.global-search-input input:focus{border-color:var(--bg-accent)}.global-search-filters{display:flex;gap:6px;padding:10px 20px;border-bottom:1px solid var(--border-color);flex-wrap:wrap}.global-search-filters button{padding:4px 12px;border-radius:var(--radius-xl);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.global-search-filters button:hover{border-color:var(--bg-accent);color:var(--text-primary)}.global-search-filters button.active{background:var(--bg-accent);border-color:var(--bg-accent);color:#fff}.global-search-results{flex:1;overflow-y:auto;padding:8px 0}.search-result-item{display:flex;flex-direction:column;gap:4px;padding:10px 20px;cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover{background:var(--bg-message-hover)}.search-result-item .result-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted)}.search-result-item .result-meta .result-channel{color:var(--text-link);font-weight:600}.search-result-item .result-content{color:var(--text-primary);font-size:13px;line-height:1.4}.search-result-item .result-content mark{background:#f9e2af4d;color:inherit;border-radius:2px;padding:0 2px}.settings-modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:600px;max-width:90vw;max-height:80vh;box-shadow:var(--elevation-3);border:1px solid var(--border-color);display:flex;overflow:hidden}.settings-tabs{width:160px;background:var(--bg-secondary);padding:16px 8px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border-color);flex-shrink:0}.settings-tab{padding:8px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:all var(--transition-fast)}.settings-tab:hover{background:var(--bg-surface);color:var(--text-primary)}.settings-tab.active{background:var(--bg-accent-subtle);color:var(--bg-accent);font-weight:600}.settings-content{flex:1;padding:24px;overflow-y:auto;min-width:0}.settings-section{margin-bottom:28px}.settings-section h3{color:var(--text-header);font-size:15px;font-weight:700;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.settings-section label{display:flex;align-items:center;justify-content:space-between;padding:8px 0;color:var(--text-primary);font-size:13px;cursor:pointer}.theme-preview{display:flex;gap:10px;margin-top:8px}.theme-preview .theme-swatch{width:48px;height:48px;border-radius:var(--radius-md);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.theme-preview .theme-swatch:hover{transform:scale(1.1)}.theme-preview .theme-swatch.active{border-color:var(--bg-accent);box-shadow:0 0 0 2px var(--bg-accent-subtle)}.profile-banner{width:100%;height:200px;background:linear-gradient(135deg,var(--bg-accent),var(--bg-accent-hover));border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:relative;overflow:hidden}.profile-banner img{width:100%;height:100%;object-fit:cover}.profile-avatar-large{width:80px;height:80px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:28px;border:4px solid var(--bg-primary);position:relative;margin-top:-40px;flex-shrink:0}.profile-avatar-large img{width:100%;height:100%;border-radius:50%;object-fit:cover}.profile-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.profile-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-xl);background:var(--bg-surface);color:var(--text-secondary);font-size:11px;font-weight:600;border:1px solid var(--border-color)}.profile-custom-status{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:13px;margin-top:6px}.profile-custom-status .status-emoji{font-size:16px}.friends-section{padding:8px 0;border-top:1px solid var(--border-color)}.friends-section h4{padding:6px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.friend-item{display:flex;align-items:center;gap:10px;padding:6px 14px;cursor:pointer;transition:background var(--transition-fast)}.friend-item:hover{background:var(--bg-surface-hover)}.friend-item .friend-name{flex:1;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.friend-item:hover .friend-actions{opacity:1}.friend-actions button{background:var(--bg-surface);border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:4px 6px;font-size:12px;transition:all var(--transition-fast)}.friend-actions button:hover{background:var(--bg-accent);color:#fff}.friend-request-item{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-surface);border-radius:var(--radius-sm);margin:4px 8px}.friend-request-item .request-name{flex:1;font-size:13px;color:var(--text-primary)}.friend-request-item button{padding:4px 10px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.friend-request-item .accept-btn{background:var(--online);color:var(--bg-tertiary)}.friend-request-item .reject-btn{background:transparent;color:var(--danger)}.friend-request-item .reject-btn:hover{background:#f38ba826}.bookmarks-section{padding:8px 0;border-top:1px solid var(--border-color)}.bookmarks-section h4{padding:6px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.bookmark-item{display:flex;flex-direction:column;gap:2px;padding:8px 14px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle)}.bookmark-item:hover{background:var(--bg-surface-hover)}.bookmark-item .bookmark-content{font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bookmark-item .bookmark-meta{font-size:11px;color:var(--text-muted)}.bookmark-note{font-size:11px;color:var(--text-muted);font-style:italic;margin-top:2px}.server-strip{width:60px;background:var(--bg-tertiary);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:6px;overflow-y:auto;flex-shrink:0;border-right:1px solid var(--border-color)}.server-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-surface);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;flex-shrink:0}.server-icon:hover{border-radius:var(--radius-md);background:var(--bg-accent);color:#fff}.server-icon img{width:100%;height:100%;object-fit:cover}.server-icon.active{border-radius:var(--radius-md);background:var(--bg-accent);color:#fff}.server-icon.active:before{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:4px;height:36px;background:var(--text-primary);border-radius:0 4px 4px 0}.server-sidebar{width:200px;background:var(--bg-secondary);display:flex;flex-direction:column;overflow-y:auto;border-right:1px solid var(--border-color);flex-shrink:0}.category-header{display:flex;align-items:center;gap:4px;padding:16px 12px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.category-header:hover{color:var(--text-primary)}.category-header .category-arrow{font-size:10px;transition:transform var(--transition-fast)}.category-header.collapsed .category-arrow{transform:rotate(-90deg)}.server-channel-item{display:flex;align-items:center;gap:6px;padding:5px 12px 5px 24px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-sm);margin:1px 8px}.server-channel-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.server-channel-item.active{background:var(--bg-surface);color:var(--text-primary);font-weight:600}.link-preview{display:flex;gap:12px;background:var(--bg-surface);border:1px solid var(--border-color);border-left:3px solid var(--bg-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:10px 14px;margin-top:6px;max-width:400px;cursor:pointer;transition:background var(--transition-fast)}.link-preview:hover{background:var(--bg-surface-hover)}.link-preview .link-preview-info{flex:1;min-width:0}.link-preview .link-preview-site{font-size:11px;color:var(--text-muted);margin-bottom:2px}.link-preview .link-preview-title{font-size:14px;font-weight:600;color:var(--text-link);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-preview .link-preview-desc{font-size:12px;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.link-preview-image{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.media-picker{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:360px;max-width:90vw;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--elevation-3);max-height:400px;display:flex;flex-direction:column;overflow:hidden;z-index:1100}.media-picker-tabs{display:flex;gap:2px;padding:8px 8px 0;border-bottom:1px solid var(--border-color)}.media-picker-tabs button{padding:8px 16px;border:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border-bottom:2px solid transparent}.media-picker-tabs button:hover{color:var(--text-primary)}.media-picker-tabs button.active{color:var(--bg-accent);border-bottom-color:var(--bg-accent)}.media-picker-search{padding:8px 12px;border-bottom:1px solid var(--border-color)}.media-picker-search input{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);font-size:13px;outline:none;transition:border-color var(--transition-fast)}.media-picker-search input:focus{border-color:var(--bg-accent)}.media-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px;padding:8px;overflow-y:auto;flex:1}.media-picker-grid .media-item{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:transform var(--transition-fast)}.media-picker-grid .media-item:hover{transform:scale(1.05)}.media-picker-grid .media-item img{width:100%;height:100%;object-fit:cover}.voice-message{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-surface);border-radius:var(--radius-lg);max-width:340px;margin-top:4px;border:1px solid var(--border-color);position:relative}.voice-message-error{color:var(--text-muted);font-style:italic;font-size:13px;padding:4px 0}.voice-message-play{width:36px;height:36px;border-radius:50%;background:var(--bg-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition-fast),transform var(--transition-fast)}.voice-message-play:hover{background:var(--bg-accent-hover);transform:scale(1.05)}.voice-message-play:active{transform:scale(.95)}.voice-message-waveform-track{flex:1;cursor:pointer;padding:2px 0;min-width:100px;height:32px}.voice-message-bars{display:flex;align-items:center;gap:2px;height:100%}.voice-message-bar-item{flex:1;min-width:2px;background:var(--bg-tertiary);border-radius:1.5px;transition:background .15s ease}.voice-message-bar-item.played{background:var(--bg-accent)}.voice-message-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.voice-message-time{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:32px;text-align:right}.voice-message-speed{background:var(--bg-tertiary);border:none;color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast);font-variant-numeric:tabular-nums;line-height:1.4}.voice-message-speed:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.voice-message-encrypted{font-size:11px;position:absolute;top:4px;right:6px;opacity:.6}.video-message{border-radius:var(--radius-md);overflow:hidden;max-width:320px;margin-top:4px;background:var(--bg-tertiary)}.video-message video{width:100%;display:block;border-radius:var(--radius-md)}.location-message{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;max-width:300px;margin-top:4px;cursor:pointer;transition:border-color var(--transition-fast)}.location-message:hover{border-color:var(--bg-accent)}.location-message .map-preview{width:100%;height:150px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:24px}.location-message .location-info{padding:8px 12px}.location-coords{font-size:12px;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace}.live-location-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-xl);background:#a6e3a126;color:var(--online);font-size:11px;font-weight:600;margin-top:4px}.live-location-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--online);animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.audit-log-table{width:100%;border-collapse:collapse;font-size:13px}.audit-log-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.audit-log-table td{padding:8px 12px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.audit-log-table tr:hover td{background:var(--bg-message-hover)}.audit-action{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.audit-action.action-create{background:#a6e3a126;color:var(--online)}.audit-action.action-delete{background:#f38ba826;color:var(--danger)}.audit-action.action-update{background:#f9e2af26;color:var(--idle)}.invite-link-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.invite-link-item .invite-code{font-family:SF Mono,Fira Code,monospace;font-size:13px;color:var(--text-link);font-weight:600}.invite-link-item .invite-meta{flex:1;font-size:12px;color:var(--text-muted)}.invite-copy-btn{padding:6px 12px;border:none;border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.invite-copy-btn:hover{background:var(--bg-accent);color:#fff}.automod-rule{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:12px;transition:border-color var(--transition-fast)}.automod-rule:hover{border-color:var(--bg-accent)}.automod-rule .rule-info{flex:1;min-width:0}.automod-rule .rule-name{font-size:14px;font-weight:600;color:var(--text-primary)}.automod-rule .rule-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.automod-rule-type{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);background:var(--bg-accent-subtle);color:var(--bg-accent);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.notify-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);width:240px;padding:8px;z-index:60}.notify-dropdown h4{padding:6px 8px;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.notify-option{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);font-size:13px;color:var(--text-primary)}.notify-option:hover{background:var(--bg-surface-hover)}.notify-option input[type=radio]{accent-color:var(--bg-accent)}.notify-option.selected{background:var(--bg-accent-subtle);color:var(--bg-accent);font-weight:600}.webhook-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.webhook-item .webhook-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.webhook-item .webhook-info{flex:1;min-width:0}.webhook-item .webhook-name{font-size:14px;font-weight:600;color:var(--text-primary)}.webhook-item .webhook-url{font-size:11px;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bot-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.bot-item .bot-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-accent-subtle);color:var(--bg-accent);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.bot-item .bot-info{flex:1;min-width:0}.bot-item .bot-name{font-size:14px;font-weight:600;color:var(--text-primary)}.bot-item .bot-desc{font-size:12px;color:var(--text-muted)}.bot-embed{background:var(--bg-surface);border-left:3px solid var(--bg-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:10px 14px;margin-top:4px;max-width:400px}.bot-embed .embed-title{font-size:14px;font-weight:600;color:var(--text-header);margin-bottom:4px}.bot-embed .embed-desc{font-size:13px;color:var(--text-secondary);line-height:1.4}.bot-embed .embed-field{margin-top:8px}.bot-embed .embed-field-name{font-size:12px;font-weight:700;color:var(--text-primary)}.bot-embed .embed-field-value{font-size:12px;color:var(--text-secondary)}.skip-link{position:absolute;top:-100%;left:8px;padding:8px 16px;background:var(--bg-accent);color:#fff;font-weight:600;font-size:13px;border-radius:0 0 var(--radius-sm) var(--radius-sm);z-index:999;transition:top var(--transition-fast);text-decoration:none}.skip-link:focus{top:0}.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}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}[data-contrast=high]{--text-primary: #f0f0f5;--text-secondary: #d0d0e0;--text-muted: #a0a0b8;--border-color: rgba(255, 255, 255, .15)}[data-density=compact] .message{padding-top:1px;padding-bottom:1px}[data-density=compact] .message-avatar{width:24px;height:24px;font-size:10px}.account-switcher{position:absolute;bottom:100%;left:0;right:0;margin-bottom:4px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);padding:6px;z-index:60}.account-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.account-item.active{background:var(--bg-accent-subtle)}.account-item .account-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.account-item .account-name{font-size:13px;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-item .account-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.account-item .account-status.online{background:var(--online)}.account-item .account-status.offline{background:var(--offline)}.scheduled-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;max-height:400px;overflow-y:auto}.scheduled-panel h3{color:var(--text-header);font-size:14px;font-weight:700;margin-bottom:10px}.scheduled-item{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-surface);margin-bottom:6px;transition:background var(--transition-fast)}.scheduled-item:hover{background:var(--bg-surface-hover)}.scheduled-item .scheduled-time{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.scheduled-item .scheduled-channel{font-size:11px;color:var(--text-link);font-weight:600}.scheduled-item .scheduled-content{flex:1;font-size:13px;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scheduled-item .scheduled-actions{display:flex;gap:4px;flex-shrink:0}.scheduled-item .scheduled-actions button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);font-size:12px;transition:all var(--transition-fast)}.scheduled-item .scheduled-actions button:hover{color:var(--text-primary);background:var(--bg-tertiary)}.contact-card{display:flex;align-items:center;gap:12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px 16px;max-width:280px;margin-top:4px;cursor:pointer;transition:all var(--transition-fast)}.contact-card:hover{border-color:var(--bg-accent);background:var(--bg-surface-hover)}.contact-card .contact-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.contact-card .contact-info{flex:1;min-width:0}.contact-card .contact-name{font-size:14px;font-weight:600;color:var(--text-primary)}.contact-card .contact-handle{font-size:12px;color:var(--text-muted)}.sticker-message{width:128px;height:128px;margin-top:4px;cursor:pointer;transition:transform var(--transition-fast)}.sticker-message:hover{transform:scale(1.05)}.sticker-message img{width:100%;height:100%;object-fit:contain}.message-forward-header{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);margin-bottom:4px;padding-left:2px}.message-forward-header .forward-icon{font-size:12px}.message-forward-header .forward-source{color:var(--text-link);font-weight:600;cursor:pointer}.message-forward-header .forward-source:hover{text-decoration:underline}.message-reply-preview{display:flex;align-items:center;gap:8px;padding:4px 8px;margin-bottom:4px;border-left:2px solid var(--bg-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--bg-surface);cursor:pointer;transition:background var(--transition-fast);max-width:400px}.message-reply-preview:hover{background:var(--bg-surface-hover)}.message-reply-preview .reply-nick{font-size:12px;font-weight:600;color:var(--bg-accent);flex-shrink:0}.message-reply-preview .reply-text{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.media-picker-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.media-picker-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-surface-hover)}.media-picker-btn:disabled{opacity:.4;cursor:not-allowed}.media-picker{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:360px;max-width:90vw;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:1100;overflow:hidden;max-height:400px}.media-picker-tabs{display:flex;border-bottom:1px solid var(--border-color)}.media-picker-tab{flex:1;padding:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;transition:color var(--transition-fast),background var(--transition-fast)}.media-picker-tab.active{color:var(--text-primary);background:var(--bg-surface);border-bottom:2px solid var(--bg-accent)}.media-picker-tab:hover{background:var(--bg-surface-hover)}.media-picker-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px 10px;font-size:14px}.media-picker-content{max-height:260px;overflow-y:auto;padding:8px}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px}.emoji-grid-item{background:none;border:none;font-size:22px;cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.emoji-grid-item:hover{background:var(--bg-surface-hover)}.gif-search-form{display:flex;gap:4px;margin-bottom:8px}.gif-search-form input{flex:1;padding:6px 10px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary)}.gif-search-form button{padding:6px 12px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}.gif-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.gif-grid-item{background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden}.gif-grid-item img{width:100%;height:80px;object-fit:cover;display:block}.gif-loading,.gif-empty,.sticker-loading,.sticker-empty{text-align:center;color:var(--text-muted);padding:16px;font-size:13px}.sticker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.sticker-grid-item{background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;padding:4px}.sticker-grid-item:hover{background:var(--bg-surface-hover)}.sticker-grid-item img{width:100%;height:72px;object-fit:contain;display:block}.voice-record-trigger-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:4px 6px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.voice-record-trigger-btn:hover:not(:disabled){color:#ed4245;background:var(--bg-surface-hover)}.voice-record-trigger-btn:disabled{opacity:.4;cursor:not-allowed}.voice-recorder{display:flex;align-items:center;gap:8px;padding:4px 8px;background:var(--bg-surface);border-radius:var(--radius-sm);user-select:none;-webkit-user-select:none;transition:background .2s}.voice-recorder.voice-recorder-cancelling{background:#ed42451f}.voice-recorder-loading{opacity:.6}.voice-recorder-indicator{width:10px;height:10px;border-radius:50%;background:#ed4245;flex-shrink:0;animation:voice-rec-pulse 1.2s ease-in-out infinite}@keyframes voice-rec-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.voice-recorder-time{font-size:13px;color:#ed4245;font-weight:600;font-variant-numeric:tabular-nums;min-width:36px;flex-shrink:0}.voice-recorder-waveform{border-radius:4px;flex-shrink:0}.voice-recorder-slide-hint{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0;transition:opacity .15s}.voice-recorder-cancel-hint{font-size:12px;color:#ed4245;font-weight:600;white-space:nowrap;flex-shrink:0}.voice-recorder-cancel{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border-color);color:var(--text-muted);border-radius:50%;cursor:pointer;flex-shrink:0;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.voice-recorder-cancel:hover{color:#ed4245;border-color:#ed4245;background:#ed42451a}.voice-recorder-send{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-accent);border:none;color:#fff;border-radius:50%;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast)}.voice-recorder-send:hover{background:var(--bg-accent-hover)}.account-switcher{position:relative;flex-shrink:0}.account-switcher-trigger{width:28px;height:28px;border-radius:50%;background:var(--bg-accent);color:#fff;border:none;cursor:pointer;font-size:12px;font-weight:600;transition:background var(--transition-fast)}.account-switcher-trigger:hover{background:var(--bg-accent-hover)}.account-switcher-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:6px;width:220px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:200;overflow:hidden}.account-switcher-header{padding:8px 12px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border-color)}.account-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;transition:background var(--transition-fast)}.account-item:hover{background:var(--bg-surface-hover)}.account-item.current{background:var(--bg-accent-subtle)}.account-item-info{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1;min-width:0}.account-avatar{width:24px;height:24px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-primary);flex-shrink:0;overflow:hidden}.account-avatar img{width:100%;height:100%;object-fit:cover}.account-nickname{font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-current-badge{font-size:10px;color:var(--bg-accent);flex-shrink:0}.account-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;padding:2px 4px;border-radius:var(--radius-sm);flex-shrink:0}.account-remove:hover{color:var(--danger)}.account-add-btn{display:block;width:100%;padding:8px 12px;background:none;border:none;border-top:1px solid var(--border-color);color:var(--bg-accent);cursor:pointer;font-size:13px;text-align:left;transition:background var(--transition-fast)}.account-add-btn:hover{background:var(--bg-surface-hover)}.message-link-previews{margin-top:6px;display:flex;flex-direction:column;gap:6px}.link-preview{max-width:400px}.link-preview-loading{font-size:12px;color:var(--text-muted);padding:4px 0}.link-preview-card{display:flex;gap:10px;padding:10px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:background var(--transition-fast);border-left:3px solid var(--bg-accent)}.link-preview-card:hover{background:var(--bg-surface-hover)}.link-preview-image{width:80px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.link-preview-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.link-preview-site{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.link-preview-title{font-size:13px;font-weight:600;color:var(--text-link);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-preview-desc{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.location-message{max-width:320px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);background:var(--bg-surface)}.location-message-link{display:block}.location-message-thumb{width:100%;height:150px;object-fit:cover;display:block}.location-message-info{padding:8px 10px;display:flex;flex-direction:column;gap:2px}.location-message-coords{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.location-live-badge{font-size:11px;color:var(--danger);font-weight:700;text-transform:uppercase}.location-live-time{font-weight:400;color:var(--text-muted);text-transform:none}.location-message-label{font-size:12px;color:var(--text-link)}.contact-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);max-width:280px}.contact-card-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;flex-shrink:0}.contact-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.contact-card-name{font-size:14px;font-weight:600;color:var(--text-primary)}.contact-card-id{font-size:12px;color:var(--text-muted)}.contact-card-view{padding:4px 10px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;flex-shrink:0;transition:background var(--transition-fast)}.contact-card-view:hover{background:var(--bg-accent-hover)}.sticker-message{display:inline-block}.sticker-message-img{max-width:160px;max-height:160px;border-radius:var(--radius-sm)}.sticker-message-pack{font-size:11px;color:var(--text-muted);margin-top:2px}.mention-suggestions{position:absolute;bottom:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:11;margin-bottom:4px}.mention-suggestion{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer}.mention-suggestion:hover,.mention-suggestion.selected{background:var(--bg-surface-hover)}.mention-suggestion-avatar{width:24px;height:24px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.mention-suggestion-name{font-size:13px;color:var(--text-primary)}.message-mentioned{background:#faa61a14;border-left:3px solid #faa61a;padding-left:13px}.message-components{margin-top:6px}.msg-comp-action-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}.msg-comp-btn{padding:6px 14px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:background var(--transition-fast);text-decoration:none;display:inline-block}.msg-comp-btn:disabled{opacity:.5;cursor:not-allowed}.msg-comp-btn-primary{background:#5865f2;color:#fff}.msg-comp-btn-primary:hover:not(:disabled){background:#4752c4}.msg-comp-btn-secondary{background:#4f545c;color:#fff}.msg-comp-btn-secondary:hover:not(:disabled){background:#686d73}.msg-comp-btn-danger{background:#ed4245;color:#fff}.msg-comp-btn-danger:hover:not(:disabled){background:#c03537}.msg-comp-btn-link{background:transparent;color:var(--bg-accent)}.msg-comp-btn-link:hover{text-decoration:underline}.msg-comp-select{padding:6px 10px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;min-width:150px}.message-embeds{margin-top:4px}.rich-embed{background:var(--bg-secondary, #2f3136);border-left:4px solid #4f545c;border-radius:var(--radius-sm);padding:8px 12px;max-width:520px;margin-top:4px;position:relative}.rich-embed-author{display:flex;align-items:center;gap:6px;margin-bottom:4px}.rich-embed-author-icon{width:20px;height:20px;border-radius:50%}.rich-embed-author-name{font-size:12px;font-weight:600;color:var(--text-primary)}.rich-embed-author-name a{color:var(--text-primary);text-decoration:none}.rich-embed-author-name a:hover{text-decoration:underline}.rich-embed-title{font-size:14px;font-weight:600;margin-bottom:4px}.rich-embed-title a{color:var(--bg-accent);text-decoration:none}.rich-embed-title a:hover{text-decoration:underline}.rich-embed-description{font-size:13px;color:var(--text-secondary, #dcddde);margin-bottom:6px;white-space:pre-wrap}.rich-embed-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:6px}.rich-embed-field{grid-column:span 3}.rich-embed-field.inline{grid-column:span 1}.rich-embed-field-name{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.rich-embed-field-value{font-size:13px;color:var(--text-secondary, #dcddde);white-space:pre-wrap}.rich-embed-image{margin-top:8px}.rich-embed-image img{max-width:100%;max-height:300px;border-radius:var(--radius-sm)}.rich-embed-thumbnail{position:absolute;top:8px;right:12px;width:80px;height:80px;object-fit:cover;border-radius:var(--radius-sm)}.rich-embed-footer{display:flex;align-items:center;gap:4px;margin-top:6px;font-size:11px;color:var(--text-muted)}.rich-embed-footer-icon{width:16px;height:16px;border-radius:50%}.schedule-send-container{display:inline-block}.schedule-send-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm)}.schedule-send-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-surface-hover)}.schedule-send-btn:disabled{opacity:.4;cursor:not-allowed}.schedule-send-menu{position:absolute;bottom:100%;right:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;min-width:200px;z-index:10;box-shadow:var(--shadow-lg)}.schedule-send-menu-header{font-size:11px;font-weight:600;color:var(--text-muted);padding:2px 4px 6px;text-transform:uppercase}.schedule-send-datetime{width:100%;padding:6px 8px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);font-size:13px;margin-bottom:6px}.schedule-send-confirm{width:100%;padding:6px 8px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.schedule-send-confirm:disabled{opacity:.5;cursor:not-allowed}.sticker-pack{margin-bottom:8px}.sticker-pack-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:4px 0;margin-bottom:4px;border-bottom:1px solid var(--border-color)}.self-destruct-container{display:inline-block}.self-destruct-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm)}.self-destruct-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-surface-hover)}.self-destruct-btn.active{color:#f04747}.self-destruct-btn:disabled{opacity:.4;cursor:not-allowed}.self-destruct-menu{position:absolute;bottom:100%;right:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px;min-width:140px;z-index:10;box-shadow:var(--shadow-lg)}.self-destruct-menu-header{font-size:11px;font-weight:600;color:var(--text-muted);padding:4px 8px;text-transform:uppercase}.self-destruct-option{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-primary);padding:6px 8px;cursor:pointer;border-radius:var(--radius-sm);font-size:13px}.self-destruct-option:hover{background:var(--bg-surface-hover)}.self-destruct-option.selected{color:#f04747;font-weight:600}.self-destruct-clear{color:var(--text-muted);border-top:1px solid var(--border-color);margin-top:2px;padding-top:6px}.message-self-destruct{font-size:11px;color:#f04747;margin-left:6px}.message-self-destruct-expired{opacity:.3;transition:opacity 2s ease-out;pointer-events:none}.scheduled-messages-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.scheduled-messages-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px}.scheduled-messages-header h3{font-size:14px;font-weight:600;color:var(--text-header)}.scheduled-messages-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px}.scheduled-messages-list{flex:1;overflow-y:auto;padding:0 12px 12px}.scheduled-messages-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.scheduled-message-item{padding:8px 10px;background:var(--bg-surface);border-radius:var(--radius-sm);margin-bottom:6px}.scheduled-message-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.scheduled-message-channel{font-size:12px;font-weight:600;color:var(--bg-accent)}.scheduled-message-time{font-size:11px;color:var(--text-muted)}.scheduled-message-content{font-size:13px;color:var(--text-primary);margin-bottom:6px;word-break:break-word}.scheduled-message-cancel{padding:3px 8px;background:none;border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;font-size:11px;transition:background var(--transition-fast)}.scheduled-message-cancel:hover{background:#f38ba81a}.scheduled-message-actions{display:flex;gap:6px;margin-top:4px}.scheduled-message-edit-btn{padding:3px 8px;background:none;border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;font-size:11px}.scheduled-message-edit-btn:hover{background:var(--bg-surface-hover)}.scheduled-message-edit{display:flex;flex-direction:column;gap:6px}.scheduled-message-edit-textarea{width:100%;padding:6px 8px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;resize:vertical}.scheduled-message-edit-time{padding:4px 8px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px}.scheduled-message-edit-actions{display:flex;gap:6px}.scheduled-message-edit-actions button{padding:4px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px}.scheduled-message-edit-actions button:first-child{background:var(--bg-accent);color:#fff}.scheduled-message-edit-actions button:last-child{background:var(--bg-surface-hover);color:var(--text-primary)}.folders-create{display:flex;gap:6px;margin-bottom:12px}.folder-icon-input{width:48px;flex-shrink:0;text-align:center}.folders-list{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto}.folder-item{background:var(--bg-surface);border-radius:var(--radius-sm);padding:8px 10px}.folder-row{display:flex;align-items:center;gap:8px}.folder-row .folder-icon{font-size:16px}.folder-row .folder-name{flex:1;font-size:13px;color:var(--text-primary)}.folder-row .folder-count{font-size:12px;color:var(--text-muted)}.folder-row button{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px}.folder-edit{display:flex;flex-direction:column;gap:6px}.folder-channel-list{max-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.folder-edit-actions{display:flex;gap:6px;justify-content:flex-end}.profile-banner-area{margin-bottom:12px;position:relative}.profile-banner-preview{width:100%;height:100px;object-fit:cover;border-radius:var(--radius-sm)}.profile-upload-label{font-size:12px;color:var(--bg-accent);cursor:pointer;display:inline-block;margin-top:4px}.profile-upload-label:hover{text-decoration:underline}.profile-avatar-area{display:flex;align-items:center;gap:12px;margin-bottom:12px}.profile-avatar-preview{width:56px;height:56px;border-radius:50%;background:var(--bg-accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:600;overflow:hidden;flex-shrink:0}.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}.profile-custom-status{display:flex;gap:6px}.profile-emoji-input{width:52px;flex-shrink:0;text-align:center}.sidebar-tabs{display:flex;flex-wrap:wrap;gap:2px;padding:6px 10px;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.sidebar-tabs button{flex:0 1 auto;padding:6px 8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.sidebar-tabs button:hover{color:var(--text-primary);background:var(--bg-surface)}.sidebar-tabs button.active{color:#fff;background:var(--bg-accent)}.chat-folder-tabs{display:flex;gap:4px;padding:8px 10px 4px}.chat-folder-tab{position:relative;padding:4px 10px;border:1px solid var(--border-color);border-radius:var(--radius-xl);background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.chat-folder-tab:hover{color:var(--text-primary);background:var(--bg-surface);border-color:var(--bg-accent)}.chat-folder-tab.active{color:#fff;background:var(--bg-accent);border-color:var(--bg-accent)}.chat-folder-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;margin-left:4px;border-radius:8px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:1}.chat-folder-tab.active .chat-folder-badge{background:#ffffff4d}.member-info{display:flex;flex-direction:column;min-width:0;gap:1px}.member-last-seen{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-last-seen{font-size:13px;color:var(--text-muted);margin-top:4px}.sidebar-dm-inline{border-top:1px solid var(--border-color);padding-top:4px;margin-top:4px}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200}.verify-identity-modal{width:480px;max-width:92vw;max-height:85vh;overflow-y:auto}.verify-identity-modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.verify-identity-modal .modal-header h3{color:var(--text-header);font-size:18px;font-weight:700;margin:0}.verify-identity-modal .modal-close{background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.verify-identity-modal .modal-close:hover{color:var(--text-primary);background:var(--bg-secondary)}.verify-loading{color:var(--text-muted);font-size:14px;text-align:center;padding:24px 0}.verify-error{color:var(--danger);font-size:14px;text-align:center;padding:16px;background:#f047471a;border-radius:var(--radius-sm)}.verify-warning{background:#faa61a1f;border:1px solid rgba(250,166,26,.3);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px;color:#faa61a;font-size:13px;line-height:1.5}.verify-instructions{color:var(--text-secondary);font-size:13px;line-height:1.5;margin-bottom:16px}.safety-number-display{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px;text-align:center}.safety-number-group{font-family:SF Mono,Consolas,Liberation Mono,monospace;font-size:16px;font-weight:600;color:var(--text-primary);letter-spacing:1px;padding:4px}.visual-hash-section{display:flex;justify-content:center;margin-bottom:16px}.visual-hash-canvas{border-radius:var(--radius-sm);border:1px solid var(--border-color);image-rendering:pixelated}.verify-actions{display:flex;align-items:center;gap:10px;margin-bottom:16px}.verify-actions .btn-secondary{padding:8px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.verify-actions .btn-secondary:hover{background:var(--bg-tertiary)}.verify-actions .btn-primary{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;font-size:13px;transition:all var(--transition-spring);box-shadow:var(--glow-accent)}.verify-actions .btn-primary:hover{background:var(--bg-accent-hover);box-shadow:var(--glow-accent-hover);transform:translateY(-1px)}.verify-actions .btn-danger{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:var(--danger);color:#fff;font-weight:600;cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.verify-actions .btn-danger:hover{opacity:.85}.verify-badge{display:inline-flex;align-items:center;padding:4px 10px;background:#43b58126;color:#43b581;border-radius:12px;font-size:12px;font-weight:600}.qr-section{margin-bottom:16px}.qr-section p{color:var(--text-secondary);font-size:13px;margin-bottom:8px}.qr-data{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text-muted);font-size:11px;font-family:SF Mono,Consolas,Liberation Mono,monospace;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.manual-verify{border-top:1px solid var(--border-color);padding-top:16px}.manual-verify p{color:var(--text-secondary);font-size:13px;margin-bottom:8px}.manual-verify input{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);font-size:13px;outline:none;margin-bottom:8px;transition:border-color var(--transition-fast)}.manual-verify input:focus{border-color:var(--bg-accent)}.manual-verify button{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.manual-verify button:hover:not(:disabled){background:var(--bg-accent-hover)}.manual-verify button:disabled{opacity:.5;cursor:not-allowed}.server-browser-modal{max-width:700px;width:90vw;max-height:85vh;display:flex;flex-direction:column}.server-browser-search{display:flex;gap:8px;margin-bottom:12px}.server-browser-search input{flex:1}.server-browser-search .modal-submit{flex-shrink:0;padding:8px 16px}.server-browser-filters{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.server-browser-categories{display:flex;gap:6px;flex-wrap:wrap;flex:1}.server-browser-category-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:4px 12px;border-radius:14px;font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.server-browser-category-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.server-browser-category-btn.active{background:var(--bg-accent);color:#fff;border-color:var(--bg-accent)}.server-browser-sort{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer}.server-browser-list{flex:1;overflow-y:auto;min-height:0;margin-bottom:12px}.server-browser-card{display:flex;align-items:center;gap:14px;padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);margin-bottom:8px;background:var(--bg-secondary);transition:background .15s}.server-browser-card:hover{background:var(--bg-hover)}.server-browser-card-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary, #2f3136);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:20px;font-weight:700;color:var(--text-primary)}.server-browser-card-icon img{width:100%;height:100%;object-fit:cover}.server-browser-card-info{flex:1;min-width:0}.server-browser-card-name{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.server-browser-card-desc{font-size:13px;color:var(--text-secondary);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.server-browser-card-meta{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:12px;color:var(--text-muted)}.server-browser-card-category{background:var(--bg-primary);padding:1px 8px;border-radius:10px;font-size:11px}.server-browser-members:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent-green, #3ba55d);margin-right:4px;vertical-align:middle}.server-browser-card-action{flex-shrink:0}.server-browser-join-btn{padding:6px 20px!important;font-size:13px!important}.server-browser-joined-btn{background:var(--bg-tertiary, #2f3136);border:1px solid var(--border-color);color:var(--text-muted);padding:6px 16px;border-radius:var(--radius-sm);font-size:13px;cursor:default}.server-browser-empty,.server-browser-loading{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}.server-browser-load-more{display:block;width:100%;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:13px;cursor:pointer;transition:all .15s;margin-top:4px}.server-browser-load-more:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.server-browser-load-more:disabled{opacity:.5;cursor:not-allowed}.contact-import-body{display:flex;flex-direction:column;gap:12px}.contact-import-privacy{font-size:12px;color:var(--text-muted);background:#43b5811a;border-radius:var(--radius-sm);padding:8px 12px;line-height:1.4}.contact-import-picker-btn{padding:10px 16px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:600;transition:background var(--transition-fast)}.contact-import-picker-btn:hover:not(:disabled){background:var(--bg-accent-hover)}.contact-import-picker-btn:disabled{opacity:.5;cursor:not-allowed}.contact-import-divider{text-align:center;color:var(--text-muted);font-size:12px;position:relative}.contact-import-divider:before,.contact-import-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--border-color)}.contact-import-divider:before{left:0}.contact-import-divider:after{right:0}.contact-import-textarea{width:100%;padding:8px 12px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;resize:vertical;font-family:inherit}.contact-import-textarea:focus{border-color:var(--bg-accent);outline:none}.contact-import-lookup-btn{padding:8px 16px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600}.contact-import-lookup-btn:disabled{opacity:.5;cursor:not-allowed}.contact-import-results{border-top:1px solid var(--border-color);padding-top:10px}.contact-import-results h4{font-size:13px;color:var(--text-header);margin-bottom:8px}.contact-import-result{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.contact-import-result:hover{background:var(--bg-surface-hover)}.contact-import-nick{font-size:14px;font-weight:500;color:var(--text-primary)}.contact-import-result button{padding:4px 12px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px}.contact-import-result button:hover{background:var(--bg-accent-hover)}.contact-import-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:12px 0}.forum-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.forum-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border-color)}.forum-count{font-size:13px;color:var(--text-muted)}.forum-new-btn{padding:6px 14px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600}.forum-new-btn:hover{background:var(--bg-accent-hover)}.forum-loading,.forum-empty{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:14px}.forum-list{flex:1;overflow-y:auto;padding:8px 12px}.forum-list-item{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);margin-bottom:6px;cursor:pointer;transition:background var(--transition-fast)}.forum-list-item:hover{background:var(--bg-surface-hover)}.forum-list-item-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.forum-list-item-title{font-size:15px;font-weight:600;color:var(--text-primary)}.forum-list-item-meta{display:flex;gap:12px;font-size:12px;color:var(--text-muted)}.forum-list-item-tags{display:flex;gap:4px;margin-top:4px}.forum-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:1px 8px;border-radius:10px;font-size:11px}.forum-pin-badge{background:var(--bg-accent);color:#fff;padding:1px 6px;border-radius:8px;font-size:10px;font-weight:700}.forum-lock-badge{background:var(--text-muted);color:var(--bg-primary);padding:1px 6px;border-radius:8px;font-size:10px;font-weight:700}.forum-post-view{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:12px 16px}.forum-post-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.forum-back-btn{background:none;border:none;color:var(--bg-accent);cursor:pointer;font-size:13px;padding:4px 0}.forum-back-btn:hover{text-decoration:underline}.forum-post-actions{display:flex;gap:6px}.forum-action-btn{padding:4px 10px;background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;font-size:12px}.forum-action-btn:hover{background:var(--bg-surface-hover)}.forum-delete-btn{color:var(--danger);border-color:var(--danger)}.forum-post-title{font-size:20px;font-weight:700;color:var(--text-header);margin-bottom:6px;display:flex;align-items:center;gap:8px}.forum-post-meta{display:flex;gap:12px;font-size:13px;color:var(--text-muted);margin-bottom:8px}.forum-post-tags{display:flex;gap:4px;margin-bottom:10px}.forum-post-body{font-size:14px;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.forum-post-edit{display:flex;flex-direction:column;gap:8px}.forum-post-edit-title{padding:8px 12px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:16px;font-weight:600}.forum-post-edit-body{padding:8px 12px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;resize:vertical}.forum-save-btn{align-self:flex-start;padding:6px 16px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.forum-new-content{resize:vertical;min-height:100px}.stage-view{padding:12px 16px;border-bottom:1px solid var(--border-color)}.stage-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px}.stage-speaker-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.stage-speaker-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px;background:var(--bg-surface);border-radius:var(--radius-md);min-width:80px;position:relative}.stage-speaker-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.stage-speaker-nick{font-size:12px;color:var(--text-primary);font-weight:500}.stage-demote-btn{position:absolute;top:2px;right:2px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:10px;padding:2px 4px}.stage-demote-btn:hover{color:var(--danger)}.stage-hand-queue{margin-bottom:10px}.stage-hand-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;font-size:13px;color:var(--text-primary)}.stage-promote-btn{padding:3px 10px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:11px}.stage-listener-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.stage-listener-chip{background:var(--bg-surface);color:var(--text-secondary);padding:2px 8px;border-radius:10px;font-size:12px}.stage-empty{color:var(--text-muted);font-size:13px;padding:8px 0}.stage-controls{display:flex;gap:8px;margin-top:6px}.stage-join-btn{padding:6px 14px;background:var(--bg-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600}.stage-join-btn.speaker{background:var(--bg-accent-hover)}.stage-hand-btn{padding:6px 14px;background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.stage-hand-btn.active{background:#faa61a26;border-color:#faa61a;color:#faa61a}.stage-leave-btn{padding:6px 14px;background:none;border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.message-delivery-status{color:var(--text-muted, #72767d);font-size:11px;margin-left:4px;letter-spacing:-2px;font-weight:600}.message-delivery-status.delivered{color:var(--text-muted, #72767d)}.message-delivery-status.read{color:#3b82f6}.toast-container{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column-reverse;gap:8px;max-width:380px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--elevation-3);border-left:4px solid var(--bg-accent);font-size:14px;pointer-events:auto;animation:toast-slide-in .25s ease-out}.toast-error{border-left-color:var(--danger)}.toast-success{border-left-color:var(--online)}.toast-warning{border-left-color:var(--idle)}.toast-info{border-left-color:var(--bg-accent)}.toast-message{flex:1;word-break:break-word}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 4px;line-height:1;flex-shrink:0}.toast-close:hover{color:var(--text-primary)}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.skeleton-container{padding:16px}.skeleton-message{display:flex;gap:12px;padding:8px 0}.skeleton-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);flex-shrink:0}.skeleton-body{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-name{width:100px;height:14px;border-radius:4px;background:var(--bg-surface)}.skeleton-text{width:80%;height:12px;border-radius:4px;background:var(--bg-surface)}.skeleton-text-short{width:50%}.skeleton-shimmer{background:linear-gradient(90deg,var(--bg-surface) 25%,var(--bg-surface-hover) 50%,var(--bg-surface) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(prefers-reduced-motion:reduce){.skeleton-shimmer{animation:none;background:var(--bg-surface)}.spinner{animation-duration:2s}}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.spinner{border:3px solid var(--border-color);border-top-color:var(--bg-accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.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}.connection-banner{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#b45309;color:#fff;font-size:14px;font-weight:500;animation:banner-slide-down .3s ease-out}.connection-banner-icon{font-size:16px}@keyframes banner-slide-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes backdrop-fade-in{0%{opacity:0}to{opacity:1}}@keyframes message-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes panel-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes reaction-pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes glow-pulse{0%,to{box-shadow:var(--glow-accent)}50%{box-shadow:var(--glow-accent-hover)}}@keyframes empty-fade-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.message-pending{opacity:.6}.message-failed{opacity:.8;border-left:3px solid var(--danger)}.message-failed-indicator{display:inline-flex;align-items:center;gap:4px;color:var(--danger);font-size:12px;margin-top:4px;cursor:pointer}.message-failed-indicator:hover{text-decoration:underline}.global-search-syntax-help{padding:4px 0 8px;font-size:12px;color:var(--text-muted)}.call-history-modal .modal-body{max-height:400px;overflow-y:auto}.call-history-empty{color:var(--text-muted);text-align:center;padding:32px 0}.call-history-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-color)}.call-history-item:last-child{border-bottom:none}.call-history-icon{font-size:18px;flex-shrink:0}.call-history-info{flex:1;display:flex;flex-direction:column;gap:2px}.call-history-nick{font-weight:600;font-size:14px;color:var(--text-primary)}.call-history-meta{font-size:12px;color:var(--text-muted)}.call-history-time{font-size:12px;color:var(--text-muted);flex-shrink:0}.global-search-syntax-help code{background:var(--bg-surface);padding:1px 4px;border-radius:3px;font-size:11px;color:var(--text-secondary)}.gradient-text{background:linear-gradient(135deg,var(--bg-accent) 0%,var(--text-link) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-layout{display:flex;height:100%;width:100%}.sidebar{width:260px;min-width:260px;background:var(--bg-secondary);display:flex;flex-direction:column}.sidebar-header{padding:16px 18px;border-bottom:1px solid var(--border-color)}.sidebar-header h2{font-size:17px;color:var(--text-header);font-weight:700;letter-spacing:-.3px}.sidebar-section{flex:1;overflow-y:auto;padding:10px 0}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:6px 18px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.sidebar-add-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:2px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.sidebar-add-btn:hover{color:var(--text-primary);background:var(--bg-surface)}.sidebar-join-form{padding:4px 10px}.sidebar-join-form input{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;font-size:13px;transition:border-color var(--transition-fast)}.sidebar-join-form input:focus{border-color:var(--bg-accent)}.sidebar-list{padding:0 10px}.sidebar-empty{padding:10px 18px;color:var(--text-muted);font-size:13px}.channel-item{display:flex;align-items:center;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-spring);margin-bottom:1px}.channel-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.channel-item.active{background:var(--bg-accent-subtle);color:var(--text-header)}.channel-hash{font-size:16px;font-weight:600;margin-right:8px;opacity:.4}.channel-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-panel{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.user-panel-info{display:flex;align-items:center;gap:10px;min-width:0}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.user-details{min-width:0}.user-nickname{font-size:13px;font-weight:600;color:var(--text-header);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-status{font-size:11px}.user-status.online{color:var(--online)}.user-status.offline{color:var(--offline)}.user-logout-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:6px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.user-logout-btn:hover{color:var(--text-primary);background:var(--bg-surface)}.chat-view{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);animation:empty-fade-in .4s cubic-bezier(.16,1,.3,1) both}.chat-empty h2{margin-bottom:8px;background:linear-gradient(135deg,var(--bg-accent) 0%,var(--text-link) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chat-header{display:flex;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);min-height:52px;position:relative}.chat-header-left{display:flex;align-items:center;gap:6px;min-width:0}.chat-header-hash{font-size:18px;color:var(--text-muted);font-weight:600;opacity:.5}.chat-header-name{font-size:16px;font-weight:700;color:var(--text-header);letter-spacing:-.2px}.chat-header-topic{margin-left:14px;padding-left:14px;border-left:1px solid var(--border-color);color:var(--text-muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-list{flex:1;overflow-y:auto;padding:16px 0}.message-list-load-more{text-align:center;padding:10px}.message-list-load-more button{background:var(--bg-surface);border:none;color:var(--text-link);cursor:pointer;font-size:13px;padding:6px 16px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.message-list-load-more button:hover{background:var(--bg-surface-hover)}.message{display:flex;padding:3px 20px;margin-top:4px;position:relative;transition:background var(--transition-fast);animation:message-fade-in .25s cubic-bezier(.16,1,.3,1) both}.message:hover{background:var(--bg-message-hover)}.message-avatar{width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0;margin-right:14px;margin-top:2px}.message-body{min-width:0;flex:1}.message-header{display:flex;align-items:baseline;gap:8px}.message-nick{font-weight:600;color:var(--text-header);font-size:14px}.message-time{font-size:11px;color:var(--text-muted)}.message-content{color:var(--text-primary);word-break:break-word;white-space:pre-wrap;line-height:1.45}.message-action{padding-left:54px}.message-action-text{color:var(--text-secondary);font-style:italic}.typing-indicator{min-height:22px;padding:0 20px;font-size:12px;color:var(--text-muted)}.message-input{display:flex;padding:0 20px 20px;gap:10px}.message-input input{flex:1;padding:12px 16px;border:1px solid var(--input-border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--text-primary);outline:none;font-size:14px;transition:border-color var(--transition-fast)}.message-input input::placeholder{color:var(--text-muted)}.message-input input:focus{border-color:var(--bg-accent)}.message-input button{padding:12px 24px;border:none;border-radius:var(--radius-md);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast);letter-spacing:.2px}.message-input button:hover:not(:disabled){background:var(--bg-accent-hover);transform:translateY(-1px)}.message-input button:active:not(:disabled){transform:translateY(0)}.message-input button:disabled{opacity:.35;cursor:not-allowed}.member-list{width:240px;min-width:240px;background:var(--bg-secondary);border-left:1px solid var(--border-color);overflow-y:auto;padding:16px 10px}.member-group{margin-bottom:18px}.member-group-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:0 10px 6px}.member-item{display:flex;align-items:center;gap:10px;padding:5px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);animation:slide-in-right .2s cubic-bezier(.16,1,.3,1) both}.member-item:hover{background:var(--bg-surface-hover)}.member-avatar{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;position:relative}.member-presence{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-secondary)}.member-name{font-size:14px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-domain{color:var(--text-muted, #72767d);font-size:11px}.message-toolbar{position:absolute;top:-10px;right:20px;display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:3px;box-shadow:var(--elevation-2)}.message-toolbar button{background:none;border:none;cursor:pointer;padding:4px 7px;border-radius:calc(var(--radius-sm) - 2px);font-size:14px;line-height:1;transition:background var(--transition-fast)}.message-toolbar button:hover{background:var(--bg-surface-hover)}.message-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.reaction-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-xl);border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-primary);font-size:13px;cursor:pointer;transition:all var(--transition-fast);animation:reaction-pop .3s cubic-bezier(.16,1,.3,1) both}.reaction-badge:hover{background:var(--bg-surface-hover)}.reaction-badge.own{border-color:var(--bg-accent);background:var(--bg-accent-subtle)}.emoji-picker{position:absolute;top:-10px;right:140px;display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px;box-shadow:var(--elevation-2)}.emoji-picker button{background:none;border:none;cursor:pointer;padding:4px;border-radius:calc(var(--radius-sm) - 2px);font-size:18px;line-height:1;transition:background var(--transition-fast)}.emoji-picker button:hover{background:var(--bg-surface-hover)}.message-edited{font-size:11px;color:var(--text-muted)}.deleted-text{color:var(--text-muted);font-style:italic}.message-edit-form input{width:100%;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;font-size:14px;transition:border-color var(--transition-fast)}.message-edit-form input:focus{border-color:var(--bg-accent)}.message-edit-actions{display:flex;gap:10px;margin-top:6px}.message-edit-actions button{background:none;border:none;color:var(--text-link);cursor:pointer;font-size:12px;transition:opacity var(--transition-fast)}.message-edit-actions button:hover{opacity:.8}.message-reply-preview{display:flex;align-items:center;gap:6px;padding:4px 0 4px 10px;margin-bottom:4px;border-left:2px solid var(--bg-accent);font-size:12px;color:var(--text-muted);cursor:pointer}.reply-line{display:none}.reply-nick{font-weight:600;color:var(--text-secondary)}.reply-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-forward-header{font-size:12px;color:var(--text-muted);margin-bottom:2px;font-style:italic}.message-pinned-badge{font-size:10px;margin-left:4px;opacity:.6}.message-input-container{padding:0}.reply-bar{display:flex;align-items:center;gap:8px;padding:8px 20px;background:var(--bg-surface);border-top:1px solid var(--border-color);font-size:13px;color:var(--text-secondary)}.reply-bar-label{flex-shrink:0}.reply-bar-preview{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.reply-bar-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:0 4px;line-height:1}.reply-bar-close:hover{color:var(--text-primary)}.format-toolbar{display:flex;gap:2px;padding:4px 20px 0;border-top:1px solid var(--border-color)}.format-btn{background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:2px 8px;font-size:12px;line-height:1.4;transition:all var(--transition-fast);min-width:28px;text-align:center}.format-btn:hover:not(:disabled){background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-color)}.format-btn:active:not(:disabled){background:var(--bg-surface-hover)}.format-btn:disabled{opacity:.3;cursor:not-allowed}.format-btn code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:11px}.chat-header{justify-content:space-between}.chat-header-right{display:flex;gap:4px;flex-shrink:0}.chat-header-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:6px 8px;border-radius:var(--radius-sm);transition:background var(--transition-fast);opacity:.6}.chat-header-btn:hover{background:var(--bg-surface);opacity:1}.chat-header-admin{position:relative}.admin-dropdown{position:absolute;top:100%;right:0;min-width:160px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:100;padding:4px 0}.admin-dropdown-item{display:block;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.admin-dropdown-item:hover{background:var(--bg-surface)}.pinned-panel{position:absolute;top:52px;right:0;width:340px;max-height:400px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:50;display:flex;flex-direction:column;animation:panel-slide-in .25s cubic-bezier(.16,1,.3,1)}.pinned-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:14px;color:var(--text-header)}.pinned-panel-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}.pinned-panel-list{overflow-y:auto;flex:1}.pinned-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.pinned-message{padding:10px 16px;border-bottom:1px solid var(--border-subtle)}.pinned-msg-nick{font-weight:600;color:var(--text-header);font-size:13px;margin-right:8px}.pinned-msg-content{color:var(--text-primary);font-size:13px;word-break:break-word}.pinned-msg-time{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.media-gallery-panel{position:absolute;top:52px;right:0;width:420px;max-height:520px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:50;display:flex;flex-direction:column;animation:panel-slide-in .25s cubic-bezier(.16,1,.3,1)}.media-gallery-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:14px;color:var(--text-header)}.media-gallery-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}.media-gallery-tabs{display:flex;border-bottom:1px solid var(--border-color);padding:0 8px}.media-gallery-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:13px;padding:8px 12px;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.media-gallery-tab:hover{color:var(--text-primary)}.media-gallery-tab.active{color:var(--text-header);border-bottom-color:var(--bg-accent)}.media-gallery-content{overflow-y:auto;flex:1;padding:8px}.media-gallery-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.media-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.media-gallery-item{border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-tertiary);position:relative}.media-gallery-image{aspect-ratio:1;cursor:pointer}.media-gallery-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .15s ease}.media-gallery-image img:hover{transform:scale(1.05)}.media-gallery-placeholder{width:100%;height:100%;background:var(--bg-tertiary)}.media-gallery-item-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:16px 6px 4px;display:flex;justify-content:space-between;align-items:center;opacity:0;transition:opacity var(--transition-fast)}.media-gallery-item:hover .media-gallery-item-info{opacity:1}.media-gallery-item-nick{font-size:11px;color:#ddd;font-weight:500}.media-gallery-item-time{font-size:10px;color:#aaa}.media-gallery-file{grid-column:1 / -1;display:flex;align-items:center;padding:10px 12px;gap:10px}.media-gallery-file-icon{font-size:24px;flex-shrink:0}.media-gallery-file-info{min-width:0;flex:1}.media-gallery-file-name{color:var(--text-link);font-size:13px;text-decoration:none;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-gallery-file-name:hover{text-decoration:underline}.media-gallery-item-meta{display:flex;gap:8px;font-size:11px;color:var(--text-muted);margin-top:2px}.media-lightbox{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.media-lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 4px 30px #00000080}.media-lightbox-close{position:absolute;top:16px;right:16px;background:#00000080;border:none;color:#fff;font-size:28px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.media-lightbox-close:hover{background:#000000b3}.search-panel{position:absolute;top:52px;right:0;width:380px;max-height:450px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-3);z-index:50;display:flex;flex-direction:column;animation:panel-slide-in .25s cubic-bezier(.16,1,.3,1)}.search-panel-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-color)}.search-form{display:flex;flex:1;gap:6px}.search-form input{flex:1;padding:8px 12px;border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);outline:none;font-size:13px}.search-form input:focus{border-color:var(--bg-accent)}.search-form button{padding:8px 14px;border:none;border-radius:var(--radius-sm);background:var(--bg-accent);color:#fff;cursor:pointer;font-size:13px;font-weight:600}.search-panel-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}.search-results{overflow-y:auto;flex:1}.search-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.search-result{padding:10px 16px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast)}.search-result:hover{background:var(--bg-surface-hover)}.search-result-nick{font-weight:600;color:var(--text-header);font-size:13px;margin-right:8px}.search-result-content{color:var(--text-primary);font-size:13px}.search-result-time{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.forward-preview{padding:10px;background:var(--bg-surface);border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px}.forward-preview-nick{font-weight:600;color:var(--text-header);margin-right:6px}.forward-preview-content{color:var(--text-primary)}.forward-tabs{display:flex;gap:4px;margin-bottom:12px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px}.forward-tabs button{flex:1;padding:6px 10px;border:none;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--text-muted);cursor:pointer;font-size:13px}.forward-tabs button.active{background:var(--bg-accent);color:#fff}.forward-list{max-height:200px;overflow-y:auto}.forward-item{padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;color:var(--text-secondary);transition:background var(--transition-fast)}.forward-item:hover{background:var(--bg-surface-hover)}.forward-item.selected{background:var(--bg-accent-subtle);color:var(--text-header)}.profile-modal{text-align:center}.profile-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:16px}.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:28px}.profile-info h2{margin-bottom:4px}.profile-username{color:var(--text-muted);font-size:14px}.profile-status{color:var(--text-secondary);font-size:13px;margin-top:6px}.profile-bio{color:var(--text-secondary);font-size:13px;margin-top:4px}.profile-loading{padding:40px;color:var(--text-muted);text-align:center}.dm-list{padding:10px 0}.dm-list-header{padding:6px 18px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.dm-item{display:flex;align-items:center;gap:8px;padding:7px 18px;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);font-size:14px}.dm-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.dm-item.active{background:var(--bg-accent-subtle);color:var(--text-header)}.dm-lock{font-size:12px;opacity:.5}.dm-nick{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-view{display:flex;flex-direction:column;height:100%}.dm-view-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.dm-header{display:flex;align-items:center;gap:8px;padding:14px 20px;border-bottom:1px solid var(--border-color)}.dm-header-nick{font-size:16px;font-weight:700;color:var(--text-header)}.dm-e2ee-badge{font-size:11px;background:#a6e3a126;color:var(--online);padding:2px 8px;border-radius:var(--radius-xl);margin-left:auto}.dm-messages{flex:1;overflow-y:auto;padding:16px 20px}.dm-message{margin-bottom:8px}.dm-message.own{text-align:right}.dm-msg-nick{font-weight:600;color:var(--text-header);font-size:13px;margin-right:8px}.dm-msg-content{color:var(--text-primary);font-size:14px}.dm-msg-time{font-size:11px;color:var(--text-muted);margin-left:8px}.dm-input{display:flex;padding:0 20px 20px;gap:10px}.dm-input input{flex:1;padding:12px 16px;border:1px solid var(--input-border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--text-primary);outline:none;font-size:14px}.dm-input input:focus{border-color:var(--bg-accent)}.dm-input button{padding:12px 24px;border:none;border-radius:var(--radius-md);background:var(--bg-accent);color:#fff;font-weight:600;cursor:pointer}.file-upload-btn{width:40px;height:40px;border:1px solid var(--input-border);border-radius:var(--radius-md);background:var(--input-bg);color:var(--text-muted);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.file-upload-btn:hover:not(:disabled){color:var(--text-primary);border-color:var(--bg-accent)}.file-upload-btn:disabled{opacity:.35;cursor:not-allowed}.message-input-container.drag-over{background:var(--bg-accent-subtle);border:2px dashed var(--bg-accent);border-radius:var(--radius-md);margin:0 10px 10px}.msg-image-link{display:block;margin-top:6px}.msg-image{max-width:360px;max-height:280px;border-radius:var(--radius-md);object-fit:cover;cursor:pointer;transition:opacity var(--transition-fast)}.msg-image:hover{opacity:.9}.msg-file-link{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;margin-top:4px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-link);font-size:13px;text-decoration:none;transition:background var(--transition-fast)}.msg-file-link:hover{background:var(--bg-surface-hover);text-decoration:none}.encrypted-attachment{display:inline-flex;align-items:center;gap:4px;position:relative}.encrypted-file-badge{font-size:12px;opacity:.7;cursor:default}.dm-view.drag-over{background:var(--bg-accent-subtle);border:2px dashed var(--bg-accent);border-radius:var(--radius-md)}.emoji-picker-more{font-size:16px!important;color:var(--text-muted);min-width:28px}.emoji-picker-portal{position:absolute;bottom:100%;right:0;z-index:100;margin-bottom:4px}.emoji-picker-full{width:352px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--elevation-2);display:flex;flex-direction:column;overflow:hidden}.emoji-picker-header{display:flex;align-items:center;gap:4px;padding:8px;border-bottom:1px solid var(--border-color)}.emoji-picker-search{flex:1;padding:6px 10px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;outline:none}.emoji-picker-search:focus{border-color:var(--bg-accent)}.emoji-picker-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:4px 6px;border-radius:var(--radius-sm)}.emoji-picker-close-btn:hover{background:var(--bg-surface-hover)}.emoji-skin-tone-container{position:relative}.emoji-skin-tone-btn{background:none;border:none;cursor:pointer;font-size:20px;padding:2px 6px;border-radius:var(--radius-sm);line-height:1}.emoji-skin-tone-btn:hover{background:var(--bg-surface-hover)}.emoji-skin-tone-menu{position:absolute;top:100%;right:0;display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px;box-shadow:var(--elevation-2);z-index:10}.emoji-skin-tone-option{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;border-radius:var(--radius-sm);line-height:1}.emoji-skin-tone-option:hover,.emoji-skin-tone-option.active{background:var(--bg-surface-hover)}.emoji-picker-categories{display:flex;gap:1px;padding:4px 8px;border-bottom:1px solid var(--border-color);overflow-x:auto}.emoji-cat-btn{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 6px;border-radius:var(--radius-sm);line-height:1;opacity:.6;transition:opacity var(--transition-fast),background var(--transition-fast);flex-shrink:0}.emoji-cat-btn:hover{opacity:1;background:var(--bg-surface-hover)}.emoji-cat-btn.active{opacity:1;background:var(--bg-accent-subtle)}.emoji-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:1px;padding:8px;max-height:300px;overflow-y:auto}.emoji-picker-item{background:none;border:none;cursor:pointer;font-size:24px;padding:4px;border-radius:var(--radius-sm);line-height:1;transition:background var(--transition-fast);text-align:center}.emoji-picker-item:hover{background:var(--bg-surface-hover)}.emoji-picker-empty{grid-column:1 / -1;text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.gif-search-input-wrapper{position:relative;flex:1}.gif-search-input-wrapper input{width:100%;padding:6px 30px 6px 10px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary)}.gif-search-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:var(--radius-sm);line-height:1}.gif-search-clear:hover{color:var(--text-primary)}.gif-masonry{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;grid-auto-rows:10px}.gif-masonry .gif-grid-item{grid-row-end:span 8}.gif-masonry .gif-grid-item img{height:100%;width:100%;object-fit:cover}.voice-quality{width:10px;height:10px;border-radius:50%;margin:0 6px;flex-shrink:0;align-self:center}.voice-quality-good{background:#43b581;box-shadow:0 0 4px #43b58180}.voice-quality-fair{background:#faa61a;box-shadow:0 0 4px #faa61a80}.voice-quality-poor{background:#f04747;box-shadow:0 0 4px #f0474780}.voice-quality-unknown{background:var(--text-muted)}.voice-reconnecting{text-align:center;color:#faa61a;font-size:12px;padding:4px 0;animation:voice-reconnect-pulse 1.5s ease-in-out infinite}@keyframes voice-reconnect-pulse{0%,to{opacity:1}50%{opacity:.4}}.voice-panel-stats{font-size:11px;color:var(--text-muted);margin-left:8px}.verified-badge{color:#5b6abf;font-size:.75em;margin-left:2px;font-weight:700}.unverified-badge{color:#faa61a;font-size:.7em;margin-left:2px;opacity:.7}.junk-indicator{background:#faa61a;color:#fff;border-radius:8px;font-size:10px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;margin-left:4px}.junk-banner{background:var(--bg-secondary, #2f3136);border-bottom:1px solid var(--border-color, #202225);padding:8px 16px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-muted, #b9bbbe)}.junk-banner-text{display:flex;align-items:center;gap:6px}.junk-banner-icon{color:#faa61a;font-size:14px}.junk-banner-actions{display:flex;gap:8px}.junk-banner-actions button{background:none;border:1px solid var(--border-color, #40444b);color:var(--text-primary, #dcddde);padding:3px 10px;border-radius:3px;cursor:pointer;font-size:12px}.junk-banner-actions button:hover{background:var(--bg-hover, #40444b)}.junk-banner-actions button.trust-btn{border-color:#5b6abf;color:#5b6abf}.junk-banner-actions button.trust-btn:hover{background:#5b6abf1a}.message-junk{opacity:.6;border-left:2px solid #faa61a;padding-left:12px}
