*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1b1d21;--bg-secondary: #15171a;--bg-tertiary: #0f1114;--bg-accent: #2cb7a0;--bg-accent-hover: #239885;--bg-modifier-hover: rgba(255, 255, 255, .06);--bg-modifier-active: rgba(255, 255, 255, .12);--text-primary: #e7e3dc;--text-secondary: #b5b0a6;--text-muted: #8a8479;--text-link: #4fc3f7;--header-primary: #f4f1ea;--channel-text-area: #23272d;--scrollbar-thin-thumb: #0f1114;--scrollbar-thin-track: #15171a;--brand-color: #2cb7a0;--brand: #2cb7a0;--brand-hover: #239885;--brand-primary: #2cb7a0;--danger: #d1605a;--success: #6bbf59}body{font-family:IBM Plex Sans,Manrope,Noto Sans,Helvetica Neue,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}#root{height:100vh}a{color:var(--text-link);text-decoration:none}button{cursor:pointer;border:none;font-family:inherit}input{font-family:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thin-thumb);border-radius:4px}::-webkit-scrollbar-track{background:var(--scrollbar-thin-track)}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;background-color:var(--bg-tertiary)}.app-loading{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 20%,#2d2f34,var(--bg-tertiary) 60%)}.app-loading-card{display:flex;align-items:center;gap:12px;padding:18px 22px;border-radius:10px;background:var(--bg-primary);border:1px solid #1f2124;box-shadow:0 6px 24px #00000040}.app-loading-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.15);border-top-color:var(--brand-color);animation:app-loading-spin .9s linear infinite}.app-loading-text{color:var(--text-primary);font-weight:600;letter-spacing:.02em}@keyframes app-loading-spin{to{transform:rotate(360deg)}}.auth-form{background:var(--bg-primary);padding:32px;border-radius:8px;width:100%;max-width:480px;box-shadow:0 2px 10px #0003}.auth-form h1{color:var(--header-primary);font-size:24px;font-weight:600;margin-bottom:8px;text-align:center}.auth-subtitle{color:var(--text-secondary);font-size:16px;text-align:center;margin-bottom:20px}.auth-form label{display:block;color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;margin-bottom:20px;letter-spacing:.02em}.auth-form input{display:block;width:100%;margin-top:8px;padding:10px;background:var(--bg-tertiary);border:1px solid #040405;border-radius:4px;color:var(--text-primary);font-size:16px;outline:none;transition:border-color .2s}.auth-form input:focus{border-color:var(--brand-color)}.auth-form button[type=submit]{width:100%;padding:12px;background:var(--bg-accent);color:#fff;font-size:16px;font-weight:500;border:none;border-radius:4px;cursor:pointer;margin-top:4px;transition:background .2s}.auth-form button[type=submit]:hover{background:var(--bg-accent-hover)}.auth-error{background:#ed42451a;border:1px solid var(--danger);color:var(--danger);padding:10px;border-radius:4px;margin-bottom:16px;font-size:14px}.auth-link{margin-top:8px;font-size:14px;color:var(--text-secondary)}.auth-link a{color:var(--text-link)}.main-layout{display:flex;height:100vh;overflow:hidden}.server-sidebar{width:72px;min-width:72px;background:var(--bg-tertiary);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:8px;overflow-y:auto}.server-list{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.server-actions{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:8px;border-top:2px solid var(--bg-secondary);margin-top:auto}.server-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:18px;font-weight:600;cursor:pointer;transition:border-radius .2s,background .2s;overflow:hidden;border:none}.server-icon:hover,.server-icon.active{border-radius:16px;background:var(--bg-accent);color:#fff}.server-icon img{width:100%;height:100%;object-fit:cover}.server-icon.add-server{background:var(--bg-primary);color:var(--success);font-size:24px}.server-icon.add-server:hover{background:var(--success);color:#fff}.server-icon.join-server{background:var(--bg-primary);color:var(--success);font-size:20px}.server-icon.join-server:hover{background:var(--success);color:#fff}.channel-sidebar{width:240px;min-width:240px;background:var(--bg-secondary);display:flex;flex-direction:column;overflow:hidden}.channel-sidebar-header{height:48px;padding:0 16px;display:flex;align-items:center;border-bottom:1px solid rgba(0,0,0,.24);font-weight:600;color:var(--header-primary);box-shadow:0 1px #0003}.server-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-sidebar-actions{display:flex;gap:4px;padding:8px}.sidebar-action-btn{flex:1;padding:4px 8px;background:var(--bg-modifier-hover);color:var(--text-secondary);border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.sidebar-action-btn:hover{background:var(--bg-modifier-active);color:var(--text-primary)}.channel-list{flex:1;overflow-y:auto;padding:0 8px}.channel-category{margin-top:16px}.category-label{display:block;padding:0 8px;margin-bottom:4px;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.02em}.channel-item{display:flex;align-items:center;padding:6px 8px;margin:1px 0;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:15px;background:none;border:none;width:100%;text-align:left;transition:background .1s,color .1s}.channel-item:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.channel-item.active{background:var(--bg-modifier-active);color:var(--header-primary)}.channel-item.voice{flex-wrap:wrap;position:relative}.channel-item-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:inherit;font:inherit;cursor:pointer;flex:1;text-align:left;padding:0}.voice-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:4px;font-size:14px}.voice-action-btn:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.voice-action-btn.leave{color:var(--danger)}.voice-action-lock{color:var(--text-muted);padding:2px 6px;border-radius:4px;font-size:13px;line-height:1;cursor:default}.voice-participants{width:100%;padding-left:24px;margin-top:4px}.voice-participant{display:flex;align-items:center;gap:8px;padding:2px 0;font-size:13px;color:var(--text-secondary)}.voice-participant-right{margin-left:auto;display:inline-flex;align-items:center;gap:6px}.voice-participant-actions{display:inline-flex;align-items:center;gap:4px;opacity:0;transition:opacity .15s ease}.voice-participant:hover .voice-participant-actions{opacity:1}.voice-participant-action-btn{background:var(--bg-modifier-hover);border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:4px;font-size:12px;line-height:1}.voice-participant-action-btn.active,.voice-participant-action-btn:hover{color:var(--text-primary)}.voice-status-icons{display:inline-flex;align-items:center;gap:4px;color:var(--text-muted);font-size:12px}.voice-status-icon{line-height:1}.voice-status-icon.locked{color:var(--danger)}.participant-avatar{width:20px;height:20px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;transition:box-shadow .15s ease}.participant-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.participant-avatar.speaking{box-shadow:0 0 0 2px #3ba55d}.live-badge{background:#d1605a;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;line-height:1;letter-spacing:.5px}.channel-hash{margin-right:6px;color:var(--text-muted);font-weight:500;font-size:18px}.channel-voice-icon{margin-right:6px;font-size:16px}.member-list{width:240px;min-width:240px;background:var(--bg-secondary);overflow-y:auto;padding:16px 8px}.member-list .category-label{display:block;padding:16px 8px 4px;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.02em}.member-list>:first-child>.category-label,.member-list>.category-label:first-child{padding-top:0}.member-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;font-size:14px;cursor:default}.member-item:hover{background:var(--bg-modifier-hover)}.member-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;overflow:visible;position:relative;flex-shrink:0}.member-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.member-name{color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-text{display:flex;flex:1;flex-direction:column;min-width:0}.member-status{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-badge{font-size:10px;padding:1px 4px;border-radius:3px;font-weight:600;flex-shrink:0}.profile-card-roles{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.role-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;background:var(--bg-tertiary);font-size:12px;color:var(--text-secondary);font-weight:500}.role-pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.role-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.role-create-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;margin-bottom:12px;background:var(--brand-color);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.role-create-btn:hover{background:#239885}.role-create-btn:active{transform:scale(.98)}.role-create-icon{font-size:18px;font-weight:700;line-height:1}.role-list{display:flex;flex-direction:column;gap:2px;max-height:350px;overflow-y:auto}.role-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .15s;position:relative;overflow:hidden}.role-item:hover{background:var(--bg-modifier-hover)}.role-item-color-bar{width:4px;height:28px;border-radius:2px;flex-shrink:0}.role-item-content{flex:1;min-width:0}.role-item-header{display:flex;align-items:center;gap:8px}.role-item-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-item-meta{font-size:12px;color:var(--text-muted);white-space:nowrap}.role-item-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .15s}.role-item:hover .role-item-actions{opacity:1}.role-move-btn,.role-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:4px 6px;border-radius:4px;transition:color .1s,background .1s}.role-move-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-modifier-active)}.role-move-btn:disabled{opacity:.25;cursor:default}.role-delete-btn:hover{color:var(--danger);background:#ed42451f}.role-list-empty{display:flex;flex-direction:column;align-items:center;padding:32px 16px;color:var(--text-muted);text-align:center;gap:4px}.role-list-empty-icon{font-size:32px;margin-bottom:4px}.role-list-empty p{font-size:15px;font-weight:600;color:var(--text-secondary);margin:0}.role-list-empty span{font-size:13px}.role-editor{display:flex;flex-direction:column}.role-editor-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.role-editor-header h3{color:var(--header-primary);font-size:16px;font-weight:700;margin:0}.role-editor-back{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1;transition:color .15s,background .15s}.role-editor-back:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.role-editor-preview{display:flex;justify-content:center;padding:12px;margin-bottom:16px;background:var(--bg-secondary);border-radius:8px}.role-editor-preview .role-pill{font-size:14px;padding:4px 12px;border:1px solid;background:transparent}.role-editor-section{margin-bottom:16px}.role-editor-label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-secondary);margin-bottom:8px}.role-editor-input{display:block;width:100%;padding:10px 12px;background:var(--bg-tertiary);border:1px solid transparent;border-radius:6px;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .15s;box-sizing:border-box}.role-editor-input:focus{border-color:var(--brand-color)}.role-color-presets{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.role-color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s,box-shadow .1s;padding:0}.role-color-swatch:hover{transform:scale(1.15)}.role-color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--brand-color)}.role-color-custom{width:28px;height:28px;border-radius:50%;background:conic-gradient(red,#ff0,#0f0,#0ff,#00f,#f0f,red);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;margin-bottom:0}.role-color-custom input[type=color]{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer;margin:0;padding:0}.role-color-custom-icon{font-size:13px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);pointer-events:none}.toggle-switch{width:40px;height:22px;border-radius:11px;background:var(--bg-tertiary);border:2px solid var(--text-muted);position:relative;cursor:pointer;transition:background .2s,border-color .2s;flex-shrink:0}.toggle-switch.on{background:var(--brand-color);border-color:var(--brand-color)}.toggle-knob{width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:1px;left:1px;transition:left .2s}.toggle-switch.on .toggle-knob{left:19px}.role-editor-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--text-secondary);font-weight:400;text-transform:none;margin-bottom:0}.permission-section{margin-bottom:12px}.permission-section:last-child{margin-bottom:0}.permission-section-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 0 4px;border-bottom:1px solid var(--bg-modifier-accent);margin-bottom:4px}.permission-row{display:flex;align-items:center;justify-content:space-between;padding:8px 4px;border-radius:4px;cursor:pointer;transition:background .1s}.permission-row:hover{background:var(--bg-modifier-hover)}.permission-info{display:flex;flex-direction:column;gap:1px;min-width:0}.permission-name{font-size:14px;color:var(--text-primary);font-weight:500}.permission-desc{font-size:12px;color:var(--text-muted)}.ban-list{max-height:400px;overflow-y:auto}.ban-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--bg-modifier-accent)}.ban-item:last-child{border-bottom:none}.ban-info{flex:1;display:flex;flex-direction:column;gap:2px}.ban-user{font-weight:600;color:var(--header-primary);font-size:14px}.ban-username{color:var(--text-muted);font-size:12px}.ban-reason{color:var(--text-secondary);font-size:13px;font-style:italic}.ban-meta{color:var(--text-muted);font-size:11px}.role-assign-modal{max-width:380px}.role-assign-target{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-secondary);border-radius:8px;margin-bottom:12px}.role-assign-target-name{font-size:15px;font-weight:600;color:var(--header-primary)}.role-assign-list{display:flex;flex-direction:column;gap:2px;max-height:300px;overflow-y:auto;margin-bottom:12px}.role-assign-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .15s;text-transform:none;font-weight:400;margin-bottom:0}.role-assign-item:hover{background:var(--bg-modifier-hover)}.role-assign-color{width:14px;height:14px;border-radius:50%;flex-shrink:0}.role-assign-name{flex:1;font-size:14px;font-weight:500;color:var(--text-primary)}.role-assign-empty{color:var(--text-muted);text-align:center;padding:24px 0;font-size:14px}.toggle-switch.small{width:32px;height:18px;border-radius:9px}.toggle-switch.small .toggle-knob{width:12px;height:12px;top:1px;left:1px}.toggle-switch.small.on .toggle-knob{left:15px}.member-item.offline{opacity:.4}.presence-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-secondary)}.presence-dot.online{background:var(--success)}.presence-dot.offline{background:var(--text-muted)}.content-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.signalr-status-banner{position:sticky;top:0;z-index:3;display:flex;justify-content:center;padding:6px 12px;font-size:12px;letter-spacing:.2px;color:var(--text-primary);background:#d9a4411f;border-bottom:1px solid rgba(217,164,65,.35);box-shadow:0 1px #0003}.signalr-status-banner.reconnecting{background:#d9a44129}.signalr-status-banner.disconnected{background:#e74c3c2e;border-bottom:1px solid rgba(231,76,60,.45)}.signalr-status-banner.connecting{background:#3498db2e;border-bottom:1px solid rgba(52,152,219,.45)}.channel-header{height:48px;padding:0 16px;display:flex;align-items:center;border-bottom:1px solid rgba(0,0,0,.24);font-weight:600;color:var(--header-primary);box-shadow:0 1px #0003;gap:4px}.channel-header .channel-hash{font-size:22px}.channel-header .channel-name{font-size:16px}.channel-header-actions{margin-left:auto;display:flex;align-items:center;gap:6px}.no-channel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted)}.no-channel h2{color:var(--text-primary);margin-bottom:8px}.voice-channel-view{flex:1;display:flex;flex-direction:column}.voice-channel-content{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:18px}.message-list{flex:1;overflow-y:auto;position:relative}.message-list-inner{padding:16px 0}.scroll-to-bottom-banner{position:sticky;top:0;z-index:2;display:flex;justify-content:center;padding:6px 12px;background:var(--bg-primary);border-bottom:1px solid rgba(0,0,0,.24);box-shadow:0 1px #0003;pointer-events:none}.scroll-to-bottom-banner button{pointer-events:auto;border:1px solid rgba(255,255,255,.14);background:#121621e0;color:var(--text-primary);padding:6px 12px;border-radius:999px;font-size:12px;letter-spacing:.2px;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease}.scroll-to-bottom-banner button:hover{background:#161c29f2;border-color:#ffffff38;transform:translateY(-1px)}.empty-channel-message{display:flex;justify-content:center;align-items:center}.empty-channel-message p{font-weight:400;color:var(--text-secondary)}.message-item{display:flex;padding:2px 16px;margin-top:16px;position:relative}.message-item.system-message{margin-top:8px;padding:6px 16px;color:var(--text-muted)}.message-item.system-message:hover{background:transparent}.system-message-content{display:flex;align-items:center;gap:8px;width:100%;font-size:12px}.system-message-icon{font-size:10px;opacity:.6}.system-message-text strong{color:var(--header-primary);font-weight:600}.system-message-time{margin-left:auto;color:var(--text-muted);font-size:11px}.message-item.message-grouped{margin-top:0}.message-item:hover{background:#0000000f}.message-item.message-mentioned{background:#d9a44114;border-left:3px solid #d9a441;padding-left:13px}.message-item.message-mentioned:hover{background:#d9a44121}.message-item.message-has-reply{margin-top:16px;flex-wrap:wrap}.reply-reference{display:flex;align-items:center;gap:4px;width:100%;padding-left:36px;margin-bottom:4px;font-size:13px;color:var(--text-muted);cursor:pointer}.reply-reference:hover .reply-reference-content{color:var(--text-normal)}.reply-reference-line{width:32px;min-width:32px;height:14px;margin-right:4px;border-left:2px solid var(--text-muted);border-top:2px solid var(--text-muted);border-top-left-radius:6px;align-self:flex-end;margin-bottom:4px}.reply-reference-avatar{width:16px;height:16px;min-width:16px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-modifier-accent);font-size:10px;color:var(--text-normal)}.reply-reference-avatar img{width:100%;height:100%;object-fit:cover}.reply-reference-author{font-weight:600;font-size:12px;color:var(--text-normal);white-space:nowrap;margin-right:4px}.reply-reference-content{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.reply-reference-content.reply-deleted{font-style:italic;color:var(--text-muted)}@keyframes message-highlight-flash{0%{background:#2cb7a04d}to{background:transparent}}.message-highlight>.message-item{animation:message-highlight-flash 1.5s ease-out}.message-avatar-gutter{width:40px;min-width:40px;margin-right:16px;display:flex;align-items:center;justify-content:center}.message-time-inline{font-size:10px;color:var(--text-muted);opacity:0;white-space:nowrap}.message-item:hover .message-time-inline{opacity:1}.message-actions{display:none;position:absolute;top:-8px;right:16px;background:var(--bg-primary);border:1px solid var(--bg-modifier-accent);border-radius:4px;overflow:hidden}.message-item:hover .message-actions{display:flex}.message-actions button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;font-size:16px}.message-actions button:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.message-edited-label{font-size:11px;color:var(--text-muted)}.message-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-button{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;border:1px solid var(--bg-modifier-accent);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-size:18px;line-height:1.4}.reaction-button:hover{background:var(--bg-modifier-hover);border-color:var(--text-muted)}.reaction-button.reacted{border-color:var(--brand-primary);background:#2cb7a026}.reaction-button.reaction-add{color:var(--text-muted);font-size:16px;padding:2px 8px}.reaction-button.reaction-add:hover{color:var(--text-primary)}.reaction-count{font-size:12px;color:var(--text-muted)}.reaction-button.reacted .reaction-count{color:var(--brand-primary)}.emoji-picker-container{position:fixed;z-index:100}.message-deleted{opacity:.5}.message-deleted-text{font-style:italic;color:var(--text-muted)!important}.message-edit-input{width:100%;padding:8px;border:1px solid var(--bg-modifier-accent);border-radius:4px;background:var(--bg-tertiary);color:var(--text-primary);font-size:15px;font-family:inherit;outline:none}.message-edit-input:focus{border-color:var(--text-link)}.message-edit-wrapper{display:flex;flex-direction:column;gap:6px}.message-edit-error{font-size:12px;color:var(--red)}.message-avatar{width:40px;height:40px;min-width:40px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;margin-right:16px;margin-top:2px;overflow:hidden}.message-avatar img{width:100%;height:100%;object-fit:cover}.message-body{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;gap:8px}.message-author{font-weight:600;color:var(--header-primary);font-size:16px}.message-time{font-size:12px;color:var(--text-muted)}.message-content{color:var(--text-primary);font-size:15px;line-height:1.375;word-wrap:break-word;white-space:pre-wrap}.message-content.message-markdown{white-space:normal}.message-content.message-markdown p{margin:0 0 6px}.message-content.message-markdown p:last-child{margin-bottom:0}.message-content.message-markdown h1,.message-content.message-markdown h2,.message-content.message-markdown h3,.message-content.message-markdown h4,.message-content.message-markdown h5,.message-content.message-markdown h6{margin:10px 0 6px;font-weight:600;color:var(--header-primary)}.message-content.message-markdown h1{font-size:20px}.message-content.message-markdown h2{font-size:18px}.message-content.message-markdown h3{font-size:16px}.message-content.message-markdown h4,.message-content.message-markdown h5,.message-content.message-markdown h6{font-size:15px}.message-content.message-markdown ul,.message-content.message-markdown ol{margin:6px 0 6px 18px;padding:0}.message-content.message-markdown li{margin:2px 0}.message-content.message-markdown blockquote{margin:6px 0;padding:4px 10px;border-left:3px solid var(--bg-accent);color:var(--text-muted);background:#ffffff08}.message-content.message-markdown pre{margin:6px 0;padding:8px 10px;background:var(--bg-secondary);border-radius:6px;overflow-x:auto}.message-content.message-markdown code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;background:var(--bg-secondary);padding:2px 4px;border-radius:4px}.message-content.message-markdown pre code{background:transparent;padding:0}.message-content.message-markdown a{color:var(--text-link);text-decoration:underline}.message-attachments{margin-top:4px}.attachment{margin-top:6px}.attachment-image{max-width:400px;max-height:300px;border-radius:8px;cursor:pointer}.attachment-media{display:flex;flex-direction:column;gap:6px;max-width:520px}.attachment-video{width:100%;max-height:320px;border-radius:8px;background:#0b0b0e;box-shadow:0 12px 28px #00000059}.attachment-video-shell{position:relative;width:100%}.attachment-video-shell:fullscreen,.attachment-video-shell:-webkit-full-screen{width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:#0b0b0e;display:flex;align-items:center;justify-content:center}.attachment-video-shell:-moz-full-screen{width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:#0b0b0e;display:flex;align-items:center;justify-content:center}.attachment-video-shell:-moz-full-screen .attachment-video{position:absolute;inset:0;width:100%;height:100%;max-height:none;object-fit:contain;border-radius:0;box-shadow:none;display:block}.attachment-video-shell:fullscreen .attachment-video,.attachment-video-shell:-webkit-full-screen .attachment-video{position:absolute;inset:0;width:100%;height:100%;max-height:none;object-fit:contain;border-radius:0;box-shadow:none;display:block}.attachment-play-overlay{position:absolute;inset:0;margin:auto;width:84px;height:84px;border-radius:999px;background:#0a0b10bf;color:var(--text-normal);border:1px solid rgba(255,255,255,.18);font-size:14px;letter-spacing:.5px;display:flex;align-items:center;justify-content:center}.attachment-play-overlay:hover{background:#14161ed9}.attachment-video-topbar,.attachment-video-bottombar{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#0c0d12d9;border:1px solid rgba(255,255,255,.06);border-radius:10px;flex-wrap:wrap;max-width:100%;position:absolute;left:10px;right:10px;opacity:0;pointer-events:none;transition:opacity .16s ease}.attachment-video-topbar{top:10px;justify-content:flex-end}.attachment-video-bottombar{bottom:10px}.attachment-video-shell:hover .attachment-video-topbar,.attachment-video-shell:hover .attachment-video-bottombar,.attachment-video-shell:focus-within .attachment-video-topbar,.attachment-video-shell:focus-within .attachment-video-bottombar{opacity:1;pointer-events:auto}.attachment-video-shell:fullscreen .attachment-video-topbar,.attachment-video-shell:fullscreen .attachment-video-bottombar,.attachment-video-shell:-webkit-full-screen .attachment-video-topbar,.attachment-video-shell:-webkit-full-screen .attachment-video-bottombar{opacity:1;pointer-events:auto}.attachment-control-btn{padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:var(--bg-secondary);color:var(--text-normal);font-size:12px}.attachment-control-btn:hover{background:var(--bg-tertiary)}.attachment-control-btn:active{transform:translateY(1px)}.attachment-time{font-size:12px;color:var(--text-muted);min-width:88px;text-align:center;flex:0 0 auto}.attachment-seek{flex:1 1 160px;min-width:140px;accent-color:var(--text-link)}.attachment-volume{width:90px;flex:0 0 90px;accent-color:var(--text-link)}.attachment-audio{width:100%}.attachment-audio-shell{display:flex;flex-direction:column;gap:8px}.attachment-audio-controls{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#0c0d12d9;border:1px solid rgba(255,255,255,.06);border-radius:10px;flex-wrap:wrap;max-width:100%}.attachment-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:var(--text-muted)}.attachment-meta-left{display:flex;align-items:center;gap:8px;min-width:0}.attachment-name{color:var(--text-primary);font-weight:500;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{color:var(--text-muted)}.attachment-download{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--bg-secondary);color:var(--text-normal);text-decoration:none;border:1px solid rgba(255,255,255,.08)}.attachment-download:hover{background:var(--bg-tertiary)}.attachment-download:active{transform:translateY(1px)}.attachment-file{display:inline-flex;align-items:center;gap:6px;color:var(--text-link);text-decoration:underline}.image-preview-overlay{z-index:1100}.image-preview-modal{background:var(--bg-primary);border-radius:12px;padding:16px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 32px #0006}.image-preview-img{max-width:80vw;max-height:70vh;width:auto;height:auto;object-fit:contain;border-radius:8px;background:#0b0b0b}.image-preview-actions{display:flex;justify-content:flex-end;gap:8px}.image-download-btn{background:var(--bg-accent);color:#fff;padding:8px 14px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none}.image-download-btn:hover{background:var(--bg-accent-hover)}.message-input-container{padding:0 16px 24px;position:relative}.reply-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-secondary);border-radius:8px 8px 0 0;font-size:14px;color:var(--text-muted)}.reply-bar-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-bar-text strong{color:var(--text-normal)}.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-normal)}.file-previews{display:flex;gap:8px;padding:8px;background:var(--channel-text-area);border-radius:8px 8px 0 0;border-bottom:1px solid rgba(0,0,0,.24)}.file-preview{position:relative;width:80px;height:80px;border-radius:4px;overflow:hidden}.file-preview img{width:100%;height:100%;object-fit:cover}.file-preview-generic{width:100%;height:100%;padding:6px;background:var(--bg-secondary);color:var(--text-primary);display:flex;flex-direction:column;justify-content:center;gap:4px;font-size:11px}.file-preview-name{font-weight:600;line-height:1.2;max-height:2.4em;overflow:hidden;text-overflow:ellipsis}.file-preview-size{color:var(--text-muted)}.remove-file{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:var(--danger);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;padding:0}.message-input-form{display:flex;align-items:center;background:var(--channel-text-area);border-radius:8px;padding:2px 4px}.file-previews+.message-input-form{border-radius:0 0 8px 8px}.attach-btn{width:40px;height:40px;background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}.attach-btn:hover{color:var(--text-primary)}.message-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:16px;padding:10px 8px;min-height:20px;max-height:200px;overflow-y:auto;word-break:break-word;white-space:pre-wrap}.message-input.empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none}.input-mention{background:#2cb7a04d;color:#dee0fc;border-radius:3px;padding:0 2px;font-weight:500;-webkit-user-select:all;user-select:all}.input-custom-emoji{display:inline;width:22px;height:22px;vertical-align:middle;object-fit:contain}.send-btn{padding:8px 16px;background:var(--bg-accent);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.send-btn:hover:not(:disabled){background:var(--bg-accent-hover)}.send-btn:disabled{opacity:.5;cursor:default}.emoji-picker-wrapper{position:relative}.emoji-btn{width:40px;height:40px;background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}.emoji-btn:hover{color:var(--text-primary)}.emoji-picker-input-container{position:fixed;z-index:100}.message-input-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:12px}.message-input-count{color:var(--text-muted)}.message-input-count.over{color:var(--red)}.message-input-error{color:var(--red);font-size:12px}.voice-controls{background:var(--bg-tertiary);padding:8px;border-top:1px solid rgba(0,0,0,.48);display:flex;flex-direction:column;gap:8px}.voice-controls-info{display:flex;flex-direction:column;gap:2px}.voice-connected-label{color:var(--success);font-size:13px;font-weight:600}.voice-channel-name{color:var(--text-secondary);font-size:12px}.voice-controls-buttons{display:flex;gap:4px}.voice-ctrl-btn{flex:1;padding:6px;background:var(--bg-secondary);border:none;border-radius:4px;cursor:pointer;font-size:16px;transition:background .2s}.voice-ctrl-btn:hover{background:var(--bg-modifier-active)}.voice-ctrl-btn.active{background:var(--danger)}.voice-ctrl-btn.ptt-active{background:var(--success);box-shadow:0 0 8px var(--success)}.voice-ctrl-btn.audio-unlock{background:var(--bg-accent);color:#fff;font-size:12px;font-weight:700}.voice-ctrl-btn.audio-unlock:hover{background:var(--bg-accent-hover)}.voice-mode-toggle{font-size:11px;font-weight:700;color:var(--text-secondary);letter-spacing:.02em}.voice-ctrl-btn.disconnect{background:var(--danger);color:#fff}.ptt-hint{display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-muted);padding:0 4px;white-space:nowrap}.typing-indicator{padding:0 16px;height:24px;display:flex;align-items:center;font-size:12px;color:var(--text-secondary)}.loading{text-align:center;padding:16px;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-primary);border-radius:8px;padding:24px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal h2{color:var(--header-primary);font-size:20px;margin-bottom:16px;text-align:center}.modal label{display:block;color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;margin-bottom:16px;letter-spacing:.02em}.modal input{display:block;width:100%;margin-top:8px;padding:10px;background:var(--bg-tertiary);border:1px solid #040405;border-radius:4px;color:var(--text-primary);font-size:16px;outline:none}.modal input:focus{border-color:var(--brand-color)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.modal-actions button{padding:8px 16px;border-radius:4px;font-size:14px;font-weight:500}.modal-actions button[type=submit],.modal-actions button:not(.btn-secondary){background:var(--bg-accent);color:#fff}.modal-actions button[type=submit]:hover,.modal-actions button:not(.btn-secondary):hover{background:var(--bg-accent-hover)}.btn-secondary{background:transparent;color:var(--text-primary)}.btn-secondary:hover{text-decoration:underline}.permissions-modal{max-width:680px;display:flex;flex-direction:column}.permissions-channel-name{text-align:center;font-size:14px;color:var(--text-muted);margin-top:-10px;margin-bottom:16px}.permissions-layout{display:flex;gap:16px;min-height:0;max-height:420px}.permissions-role-sidebar{width:160px;min-width:160px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;background:var(--bg-secondary);border-radius:8px;padding:8px}.permissions-role-sidebar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 8px 6px}.permissions-role-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border:none;background:none;border-radius:4px;cursor:pointer;transition:background .1s;width:100%;text-align:left}.permissions-role-item:hover{background:var(--bg-modifier-hover)}.permissions-role-item.active{background:var(--bg-modifier-active)}.permissions-role-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.permissions-role-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.permissions-role-badge{width:6px;height:6px;border-radius:50%;background:var(--brand-color);flex-shrink:0}.permissions-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.permissions-content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.permissions-editing-role{font-size:15px;font-weight:700}.permissions-reset-btn{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .1s,background .1s}.permissions-reset-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.permissions-loading{padding:32px 16px;color:var(--text-muted);text-align:center}.permissions-perm-list{display:flex;flex-direction:column;gap:8px}.permissions-perm-section{display:flex;flex-direction:column}.permissions-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 0;border-bottom:1px solid var(--bg-modifier-accent);margin-bottom:2px}.permissions-perm-row{display:flex;align-items:center;justify-content:space-between;padding:8px 4px;border-radius:4px;transition:background .1s}.permissions-perm-row:hover{background:var(--bg-modifier-hover)}.permissions-perm-info{display:flex;flex-direction:column;gap:1px;min-width:0}.permissions-perm-name{font-size:14px;color:var(--text-primary);font-weight:500}.permissions-perm-desc{font-size:12px;color:var(--text-muted)}.permissions-tri-toggle{display:flex;background:var(--bg-tertiary);border-radius:6px;overflow:hidden;flex-shrink:0}.tri-btn{width:32px;height:28px;border:none;background:none;color:var(--text-muted);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;font-weight:700;line-height:1}.tri-btn:hover{background:var(--bg-modifier-hover)}.tri-btn.tri-allow.active{background:#6bbf59;color:#fff}.tri-btn.tri-deny.active{background:var(--danger);color:#fff}.tri-btn.tri-inherit.active{background:var(--bg-modifier-active);color:var(--text-secondary)}.channel-type-select{display:flex;gap:8px;margin-top:8px}.type-option{flex:1;padding:10px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:4px;color:var(--text-secondary);font-size:14px;cursor:pointer;text-align:center;transition:border-color .2s,color .2s}.type-option.active{border-color:var(--brand-color);color:var(--header-primary)}.type-option:hover{border-color:var(--text-muted)}.invite-code-display{text-align:center}.invite-code-display p{color:var(--text-secondary);margin-bottom:8px}.invite-code-row{display:flex;gap:8px;align-items:center}.invite-code{flex:1;padding:10px;background:var(--bg-tertiary);border-radius:4px;color:var(--header-primary);font-size:16px;font-family:Consolas,monospace;text-align:center}.invite-code-row button{padding:10px 16px;background:var(--bg-accent);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.invite-code-row button:hover{background:var(--bg-accent-hover)}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:8px;color:var(--text-primary);font-size:13px;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 4px 16px #00000059;animation:toastSlideIn .25s ease-out;max-width:360px;min-width:240px;pointer-events:auto}.toast.clickable{cursor:pointer}.toast.clickable:hover{background:var(--bg-tertiary)}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:13px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-message{color:var(--text-secondary);font-size:13px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:18px;line-height:1;cursor:pointer;padding:0 2px;border-radius:4px}.toast-close:hover{color:var(--text-primary)}.toast.error{border-left:3px solid var(--danger)}.toast.success{border-left:3px solid var(--success)}.toast.info{border-left:3px solid var(--brand-color)}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.screen-share-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:16px}.screen-share-header{display:flex;align-items:center;justify-content:space-between;width:100%;color:var(--text-secondary);font-size:14px;font-weight:600;margin-bottom:12px}.screen-share-video-wrapper{flex:1;width:100%;display:flex;align-items:center;justify-content:center;background:#000;border-radius:8px;overflow:hidden;min-height:0}.screen-share-video{max-width:100%;max-height:100%;object-fit:contain}.screen-share-picker{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center;width:100%}.sharer-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;background:var(--bg-secondary);border-radius:8px;min-width:180px}.sharer-card-icon{font-size:32px}.sharer-card-name{color:var(--text-primary);font-weight:600;font-size:15px}.sharer-card-subtitle{color:var(--text-secondary);font-size:12px}.watch-stream-btn{margin-top:4px;padding:6px 16px;background:var(--brand);color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer}.watch-stream-btn:hover{background:var(--brand-hover, #239885)}.stop-watching-btn{padding:4px 12px;background:var(--bg-tertiary);color:var(--text-primary);border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.stop-watching-btn:hover{background:var(--bg-secondary)}.other-sharers-bar{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap;justify-content:center}.file-preview-progress{position:absolute;left:0;right:0;bottom:0;height:6px;background:#0006}.file-preview-progress-bar{height:100%;background:var(--text-link);transition:width .12s ease}.other-sharer-chip{padding:4px 12px;background:var(--bg-secondary);color:var(--text-primary);border:none;border-radius:12px;font-size:12px;cursor:pointer}.other-sharer-chip:hover{background:var(--bg-tertiary)}.user-bar{display:flex;align-items:center;gap:8px;padding:8px;background:var(--bg-tertiary);border-top:1px solid rgba(0,0,0,.24);margin-top:auto}.user-bar-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;overflow:hidden;flex-shrink:0}.user-bar-avatar img{width:100%;height:100%;object-fit:cover}.user-bar-info{flex:1;min-width:0;display:flex;flex-direction:column}.user-bar-name{font-size:13px;font-weight:600;color:var(--header-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-bar-username{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-bar-btn{width:32px;height:32px;background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;position:relative}.user-bar-btn:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.user-bar-btn:disabled{opacity:.6;cursor:not-allowed}.user-bar-btn:disabled:hover{background:none;color:var(--text-muted)}.user-bar-btn.active{color:#d1605a}.user-bar-settings{width:32px;height:32px;background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-bar-settings:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.user-bar-settings.admin-shield{color:#e0b35b}.user-bar-settings.admin-shield:hover{color:#d9a441}.user-settings-modal{max-width:480px}.settings-avatar-section{display:flex;justify-content:center;margin-bottom:16px}.settings-avatar{width:80px;height:80px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;overflow:hidden;cursor:pointer;position:relative}.settings-avatar img{width:100%;height:100%;object-fit:cover}.settings-avatar-letter{font-size:32px}.settings-avatar-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;opacity:0;transition:opacity .2s}.settings-avatar:hover .settings-avatar-overlay{opacity:1}.settings-textarea{display:block;width:100%;margin-top:8px;padding:10px;background:var(--bg-tertiary);border:1px solid #040405;border-radius:4px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;resize:vertical}.settings-textarea:focus{border-color:var(--brand-color)}.settings-section{margin-top:8px}.settings-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:6px}.settings-toggle{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary);margin-top:6px}.settings-toggle input{accent-color:var(--brand-color)}.settings-mic-test{display:flex;align-items:center;gap:12px;margin-top:6px}.mic-level{flex:1;height:8px;border-radius:999px;background:var(--bg-tertiary);overflow:hidden}.mic-level-fill{height:100%;background:linear-gradient(90deg,#6bbf59,#d9a441 70%,#d1605a);width:0;transition:width .08s linear}.mic-playback{width:100%;margin-top:8px}.settings-range{width:100%;margin-top:6px;accent-color:var(--brand-color)}.settings-range-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-top:4px}.settings-select{display:block;width:100%;margin-top:8px;padding:10px;background:var(--bg-tertiary);border:1px solid #040405;border-radius:4px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none}.settings-select:focus{border-color:var(--brand-color)}.settings-help{margin-top:6px;font-size:12px;color:var(--text-muted)}.ptt-key-capture{display:block;width:100%;margin-top:8px;padding:10px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:4px;color:var(--text-primary);font-size:16px;font-family:Consolas,monospace;text-align:center;cursor:pointer;transition:border-color .2s}.ptt-key-capture:hover{border-color:var(--text-muted)}.ptt-key-capture.recording{border-color:var(--brand-color);color:var(--brand-color);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.user-profile-card{position:fixed;width:280px;background:var(--bg-primary);border-radius:8px;box-shadow:0 4px 20px #0006;z-index:1001;overflow:hidden}.profile-card-banner{height:60px;background:var(--bg-accent)}.profile-card-avatar{width:80px;height:80px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;overflow:hidden;margin:-40px 0 0 16px;border:4px solid var(--bg-primary)}.profile-card-avatar img{width:100%;height:100%;object-fit:cover}.profile-card-body{padding:12px 16px 16px}.profile-card-name{font-size:18px;font-weight:700;color:var(--header-primary)}.profile-card-status{font-size:13px;color:var(--text-secondary);margin-top:2px}.profile-card-username{font-size:13px;color:var(--text-muted);margin-bottom:8px}.profile-card-bio{font-size:13px;color:var(--text-secondary);padding-top:8px;border-top:1px solid var(--bg-modifier-hover);line-height:1.4;white-space:pre-wrap;word-wrap:break-word}.clickable{cursor:pointer}.message-avatar.clickable:hover{opacity:.8}.message-author.clickable:hover{text-decoration:underline;cursor:pointer}.member-item{cursor:pointer}.context-menu{position:fixed;background:var(--bg-primary);border:1px solid var(--bg-modifier-accent);border-radius:4px;padding:4px;z-index:1002;min-width:160px;box-shadow:0 4px 12px #0006}.context-menu-item{display:block;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:14px;text-align:left;cursor:pointer;border-radius:3px}.context-menu-item:hover{background:var(--bg-accent);color:#fff}.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:var(--danger);color:#fff}.context-menu-separator{border-top:1px solid var(--bg-modifier-accent);margin:4px 0}.channel-item-wrapper{position:relative;display:flex;align-items:center}.channel-item-wrapper .channel-item{flex:1}.channel-item-wrapper[draggable=true] .channel-item,.channel-item-wrapper[draggable=true] .channel-item-btn{cursor:grab}.channel-item-wrapper.dragging .channel-item,.channel-item-wrapper.dragging .channel-item-btn{cursor:grabbing}.channel-edit-btn,.channel-delete-btn{display:none;position:absolute;right:4px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:3px;line-height:1}.channel-edit-btn{right:28px;font-size:12px;padding:3px 6px;letter-spacing:.02em;text-transform:uppercase}.channel-item-wrapper:hover .channel-delete-btn,.channel-item-wrapper:hover .channel-edit-btn{display:block}.channel-edit-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.channel-delete-btn:hover{color:var(--danger);background:#ed42451a}.channel-item-wrapper.drag-over{outline:1px dashed var(--bg-accent);border-radius:4px}.channel-item-wrapper.dragging{opacity:.6}.channel-item.voice .channel-edit-btn,.channel-item.voice .channel-delete-btn{position:static;display:inline-flex;align-items:center;justify-content:center;margin-left:4px}.channel-item.voice .channel-edit-btn{font-size:11px;padding:2px 6px}.channel-item.voice .channel-delete-btn{font-size:14px;padding:2px 6px}.channel-item.voice .channel-delete-btn:hover{color:var(--danger);background:#ed42451a}.modal-actions .btn-danger{background:var(--danger);color:#fff}.modal-actions .btn-danger:hover{filter:brightness(.95)}.server-settings-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;flex-shrink:0}.server-settings-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.server-settings-modal{max-width:560px;max-height:80vh;display:flex;flex-direction:column}.settings-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--bg-modifier-accent);padding-bottom:8px;overflow:hidden}.settings-tabs-scroll{display:flex;gap:4px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.settings-tabs-scroll::-webkit-scrollbar{display:none}.settings-tab{padding:8px 16px;background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;border-radius:4px;transition:background .2s,color .2s}.settings-tab:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.settings-tab.active{background:var(--bg-modifier-active);color:var(--header-primary)}.server-tab{display:flex;flex-direction:column;gap:12px}.server-settings-card{background:var(--bg-secondary, #15171a);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px}.server-icon-row{display:flex;align-items:center;gap:16px}.server-icon-preview{width:72px;height:72px;border-radius:36px;background:var(--bg-tertiary, #0f1114);border:1px solid var(--border-color, #42454a);color:var(--text-primary, #fff);font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.server-icon-preview img{width:100%;height:100%;object-fit:cover}.server-icon-actions{display:flex;flex-direction:column;gap:6px}.server-icon-upload-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:4px;background:var(--accent, #2cb7a0);color:#fff;font-size:13px;font-weight:600;cursor:pointer;width:fit-content}.server-icon-upload-btn input{display:none}.server-icon-hint{color:var(--text-muted, #b5b0a6);font-size:12px}.server-name-label{color:var(--text-secondary, #b5b0a6);font-size:12px;font-weight:600}.server-name-input{padding:8px 10px;background:var(--bg-tertiary, #0f1114);border:1px solid var(--border-color, #42454a);border-radius:4px;color:var(--text-primary, #fff);font-size:14px}.server-settings-section{display:flex;flex-direction:column;gap:10px;padding:8px 0 4px;border-top:1px solid var(--bg-modifier-accent)}.server-setting-row{display:flex;align-items:center;gap:10px;color:var(--text-secondary, #b5b0a6);font-size:13px}.server-setting-row input[type=checkbox]{width:16px;height:16px}.server-setting-label{min-width:64px;color:var(--text-secondary, #b5b0a6)}.server-setting-select{flex:1;min-width:180px;padding:6px 8px;background:var(--bg-tertiary, #0f1114);border:1px solid var(--border-color, #42454a);border-radius:4px;color:var(--text-primary, #fff);font-size:13px}.server-setting-select:disabled{opacity:.6;cursor:not-allowed}.server-setting-hint{color:var(--text-muted, #b5b0a6);font-size:12px}.server-error{color:#d1605a;font-size:13px}.audit-log-list{flex:1;overflow-y:auto;max-height:400px}.audit-empty{color:var(--text-muted);text-align:center;padding:24px 0;font-size:14px}.audit-log-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--bg-modifier-accent);font-size:13px}.audit-log-item:last-child{border-bottom:none}.audit-icon{font-size:16px;flex-shrink:0;margin-top:1px}.audit-details{flex:1;line-height:1.4}.audit-actor{font-weight:600;color:var(--header-primary)}.audit-action{color:var(--text-secondary)}.audit-target{color:var(--header-primary);font-weight:600}.audit-extra{color:var(--text-muted)}.audit-time{display:block;color:var(--text-muted);font-size:11px;margin-top:2px}.members-tab{display:flex;flex-direction:column;gap:8px;overflow:hidden}.members-search{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--bg-modifier-accent);border-radius:4px;color:var(--text-primary);font-size:14px;outline:none;box-sizing:border-box}.members-search:focus{border-color:var(--brand)}.members-manage-list{max-height:400px;overflow-y:auto}.member-manage-row{display:flex;align-items:center;justify-content:space-between;padding:8px;border-radius:4px;transition:background .15s}.member-manage-row:hover{background:var(--bg-modifier-hover)}.member-manage-info{display:flex;align-items:center;gap:8px;min-width:0}.member-manage-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-weight:600;color:var(--text-primary)}.member-manage-avatar img{width:100%;height:100%;object-fit:cover}.member-manage-details{display:flex;flex-direction:column;min-width:0}.member-manage-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-manage-username{font-size:12px;color:var(--text-muted)}.member-manage-actions{display:flex;gap:6px;flex-shrink:0}.btn-danger-sm{padding:4px 10px;background:var(--danger);color:#fff;border:none;border-radius:3px;font-size:12px;cursor:pointer;transition:opacity .15s}.btn-danger-sm:hover{opacity:.85}.danger-zone{border:1px solid var(--danger);border-radius:8px;padding:16px;margin-top:8px}.danger-zone p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.danger-zone label{font-size:13px}.btn-danger{width:100%;padding:10px;background:var(--danger);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px;transition:opacity .2s}.btn-danger:hover:not(:disabled){opacity:.9}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.channel-unread-dot{position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:8px;background:var(--text-primary, #fff);border-radius:0 4px 4px 0}.channel-item.unread{color:var(--text-primary, #fff);font-weight:600}.mention-badge{margin-left:auto;background:var(--danger, #d1605a);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.server-icon-wrapper{position:relative}.server-unread-dot{position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:8px;background:var(--text-primary, #fff);border-radius:0 4px 4px 0;z-index:1}.server-mention-badge{position:absolute;bottom:-2px;right:-2px;background:var(--danger, #d1605a);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;z-index:1}.mention{background:#2cb7a04d;color:#dee0fc;border-radius:3px;padding:0 2px;font-weight:500;cursor:pointer}.mention:hover{background:#2cb7a080;color:#fff}.mention-everyone,.mention-here{background:#d9a44133;color:#d9a441}.mention-everyone:hover,.mention-here:hover{background:#d9a44159;color:#fcc747}.mention-autocomplete{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-secondary, #15171a);border-radius:8px;margin-bottom:4px;padding:4px 0;max-height:240px;overflow-y:auto;z-index:100;box-shadow:0 8px 16px #0000003d;border:1px solid rgba(255,255,255,.06)}.mention-autocomplete-item{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary, #b5b0a6)}.mention-autocomplete-item.selected{background:#2cb7a033;color:var(--text-primary, #fff)}.mention-autocomplete-item:hover{background:#2cb7a026}.mention-autocomplete-name{font-weight:500}.custom-emoji{display:inline;width:28px;height:28px;vertical-align:middle;object-fit:contain}.custom-emoji-reaction{width:22px;height:22px;vertical-align:middle;object-fit:contain}.emoji-autocomplete-img{width:22px;height:22px;object-fit:contain;margin-right:8px;vertical-align:middle}.roles-tab{display:flex;flex-direction:column;overflow-y:auto;flex:1;min-height:0}.emojis-tab{display:flex;flex-direction:column;gap:16px}.emoji-upload-form{background:var(--bg-secondary, #15171a);border-radius:8px;padding:16px}.emoji-upload-form h3{margin:0 0 12px;font-size:14px;color:var(--text-secondary, #b5b0a6)}.emoji-upload-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.emoji-upload-row input[type=text]{flex:1;padding:8px 10px;background:var(--bg-tertiary, #0f1114);border:1px solid var(--border-color, #42454a);border-radius:4px;color:var(--text-primary, #fff);font-size:14px}.emoji-upload-row input[type=file]{font-size:13px;color:var(--text-secondary, #b5b0a6)}.emoji-upload-row button{padding:8px 16px;background:var(--accent, #2cb7a0);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap}.emoji-upload-row button:disabled{opacity:.5;cursor:not-allowed}.emoji-upload-preview{width:32px;height:32px;object-fit:contain;border-radius:4px}.emoji-error{color:#d1605a;font-size:13px;margin:4px 0 0}.emoji-list{display:flex;flex-direction:column;gap:2px}.emoji-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:4px;background:var(--bg-secondary, #15171a)}.emoji-item:hover{background:var(--bg-modifier-hover, #1b1d21)}.emoji-item-img{width:32px;height:32px;object-fit:contain}.emoji-item-name{flex:1;color:var(--text-secondary, #b5b0a6);font-size:14px}.emoji-item .role-delete-btn{margin-left:auto}.dm-icon svg{fill:var(--text-secondary)}.dm-icon.active svg{fill:var(--text-primary)}.server-sidebar-separator{width:32px;height:2px;background:var(--bg-tertiary);margin:4px auto;border-radius:1px}.dm-channel-item{display:flex;align-items:center;gap:8px;padding:6px 8px;width:100%}.dm-avatar{position:relative;width:32px;height:32px;min-width:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:visible;font-size:14px;font-weight:600;color:var(--text-primary)}.dm-avatar img{width:32px;height:32px;border-radius:50%;object-fit:cover}.dm-avatar .presence-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border:2px solid var(--bg-secondary)}.dm-channel-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.channel-dm-icon{font-weight:700;font-size:20px;color:var(--text-muted);margin-right:4px}.new-dm-btn{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.new-dm-btn:hover{color:var(--text-primary)}.dm-search-container{padding:0 8px 8px}.dm-search-input{width:100%;padding:8px;background:var(--bg-primary);border:none;border-radius:4px;color:var(--text-primary);font-size:13px;outline:none;box-sizing:border-box}.dm-search-input::placeholder{color:var(--text-muted)}.dm-search-results{margin-top:4px;max-height:200px;overflow-y:auto}.dm-search-empty{padding:8px;color:var(--text-muted);font-size:13px}.dm-search-result-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:none;border:none;color:var(--text-primary);cursor:pointer;border-radius:4px;text-align:left}.dm-search-result-item:hover{background:var(--bg-hover)}.dm-search-result-info{display:flex;flex-direction:column;min-width:0}.dm-search-result-name{font-size:14px;font-weight:500}.dm-search-result-username{font-size:12px;color:var(--text-muted)}.search-header-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:16px;line-height:1}.search-header-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.search-header-btn.active{color:var(--text-primary)}.pin-header-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:16px;line-height:1}.pin-header-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.pin-header-btn.active{color:var(--text-primary)}.search-panel{width:360px;min-width:360px;background:var(--bg-secondary);display:flex;flex-direction:column;overflow:hidden}.search-panel-header{height:48px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.24);font-weight:600;color:var(--header-primary);font-size:16px;flex-shrink:0}.search-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;padding:4px;line-height:1}.search-close-btn:hover{color:var(--text-primary)}.search-input-wrapper{padding:12px 12px 0;flex-shrink:0}.search-input{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid transparent;border-radius:4px;color:var(--text-primary);font-size:14px;outline:none;box-sizing:border-box}.search-input:focus{border-color:var(--brand-color)}.search-input::placeholder{color:var(--text-muted)}.search-filter-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px 12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;flex-shrink:0}.search-filter-toggle:hover{color:var(--text-primary)}.search-filter-active-dot{width:6px;height:6px;border-radius:50%;background:var(--brand-color)}.search-filters{padding:0 12px 8px;display:flex;flex-direction:column;gap:8px;flex-shrink:0}.search-filters label{display:flex;flex-direction:column;gap:4px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.02em;margin-bottom:0}.search-filters select,.search-filters input[type=date]{padding:6px 8px;background:var(--bg-tertiary);border:1px solid transparent;border-radius:4px;color:var(--text-primary);font-size:13px;outline:none}.search-filters select:focus,.search-filters input[type=date]:focus{border-color:var(--brand-color)}.search-filter-checkbox{flex-direction:row!important;align-items:center!important;gap:8px!important;cursor:pointer;text-transform:none!important;font-weight:400!important;font-size:13px!important}.search-filter-checkbox input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer}.search-clear-filters{background:none;border:none;color:var(--text-link);cursor:pointer;font-size:12px;padding:0;text-align:left}.search-clear-filters:hover{text-decoration:underline}.search-results-header{padding:4px 12px;font-size:12px;color:var(--text-muted);flex-shrink:0}.search-results{flex:1;overflow-y:auto;padding:0 8px 8px}.search-result-card{display:flex;flex-direction:column;gap:4px;padding:10px;margin-bottom:4px;background:var(--bg-primary);border:1px solid transparent;border-radius:4px;cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.search-result-card:hover{border-color:var(--bg-modifier-accent)}.search-result-channel{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.search-result-meta{display:flex;align-items:center;gap:6px}.search-result-avatar{width:20px;height:20px;border-radius:50%;background:var(--bg-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;overflow:hidden;flex-shrink:0}.search-result-avatar img{width:100%;height:100%;object-fit:cover}.search-result-author{font-size:13px;font-weight:600;color:var(--header-primary)}.search-result-time{font-size:11px;color:var(--text-muted);margin-left:auto}.search-result-content{font-size:14px;color:var(--text-secondary);line-height:1.375;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.search-highlight{background:#d9a4414d;color:#d9a441;border-radius:2px;padding:0 1px}.search-result-attachment-badge{font-size:11px;color:var(--text-muted);font-style:italic}.search-no-results{text-align:center;padding:24px 0;color:var(--text-muted);font-size:14px}.pinned-messages-modal{width:420px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.pinned-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--bg-tertiary)}.pinned-header-title{font-size:16px;font-weight:600;color:var(--header-primary)}.pinned-close-btn{background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s,color .15s}.pinned-close-btn:hover{color:var(--text-primary);background:var(--bg-modifier-hover)}.pinned-list{display:flex;flex-direction:column;overflow-y:auto;padding:8px;gap:4px}.pinned-empty{text-align:center;padding:40px 24px}.pinned-empty-icon{font-size:32px;margin-bottom:12px;opacity:.4}.pinned-empty-text{color:var(--header-primary);font-size:15px;font-weight:600;margin-bottom:4px}.pinned-empty-hint{color:var(--text-muted);font-size:13px}.pinned-card{display:flex;align-items:flex-start;border-radius:6px;position:relative;transition:background .1s}.pinned-card:hover{background:var(--bg-modifier-hover)}.pinned-card-body{display:flex;gap:12px;padding:10px 12px;cursor:pointer;flex:1;min-width:0;align-items:flex-start}.pinned-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;font-weight:600;font-size:14px;color:var(--text-primary);flex-shrink:0}.pinned-avatar img{width:100%;height:100%;object-fit:cover}.pinned-info{flex:1;min-width:0}.pinned-author{display:flex;gap:6px;align-items:baseline;margin-bottom:2px}.pinned-author-name{font-size:14px;font-weight:600;color:var(--header-primary)}.pinned-time{font-size:11px;color:var(--text-muted)}.pinned-excerpt{color:var(--text-secondary);font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pinned-unpin-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;opacity:0;transition:opacity .15s,background .15s,color .15s;margin:8px 8px 0 0;flex-shrink:0}.pinned-card:hover .pinned-unpin-btn{opacity:1}.pinned-unpin-btn:hover{color:var(--danger);background:var(--bg-modifier-hover)}.admin-panel-modal{max-width:920px}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.admin-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:4px}.admin-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.admin-tab{padding:8px 12px;border-radius:6px;border:1px solid transparent;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer}.admin-tab.active{border-color:var(--brand-color);color:var(--header-primary);background:var(--bg-secondary)}.admin-error{background:#ed42451a;border:1px solid var(--danger);color:var(--danger);padding:10px;border-radius:6px;margin-bottom:12px;font-size:14px}.admin-loading,.admin-empty{text-align:center;padding:24px 0;color:var(--text-muted)}.admin-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.admin-metric{background:var(--bg-tertiary);border-radius:8px;padding:12px;border:1px solid rgba(255,255,255,.04)}.admin-metric-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.admin-metric-value{font-size:22px;font-weight:600;color:var(--header-primary);margin-top:6px}.admin-section{display:flex;flex-direction:column;gap:12px}.admin-search{display:flex;gap:10px;align-items:center}.admin-search input{flex:1;padding:10px;border-radius:6px;border:1px solid #040405;background:var(--bg-tertiary);color:var(--text-primary)}.admin-count{color:var(--text-muted);font-size:12px}.admin-table{display:flex;flex-direction:column;gap:6px}.admin-table-header,.admin-table-row{display:grid;grid-template-columns:2fr 2fr 1fr 1fr;gap:10px;align-items:center}.admin-table-header{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 10px}.admin-table-row{background:var(--bg-tertiary);border-radius:6px;padding:10px;font-size:13px}.admin-table-users{grid-template-columns:1.5fr 1.2fr 1.6fr 1fr}.admin-table-codes{grid-template-columns:1.4fr .8fr 1fr 1fr}.admin-strong{color:var(--header-primary);font-weight:600}.admin-mono{font-family:Consolas,monospace;font-size:12px;color:var(--text-secondary)}.admin-setting-card{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--bg-tertiary);border-radius:8px;padding:12px 14px}.admin-setting-title{color:var(--header-primary);font-weight:600;margin-bottom:4px}.admin-setting-desc{color:var(--text-muted);font-size:12px}.admin-code-card{flex-direction:column;align-items:stretch}.admin-code-actions{display:grid;grid-template-columns:1fr 1.2fr auto;gap:8px;margin-top:8px}.admin-code-actions input{padding:8px 10px;border-radius:6px;border:1px solid #040405;background:var(--bg-secondary);color:var(--text-primary);font-size:13px}.admin-new-code{background:var(--bg-secondary);border-radius:6px;padding:10px 12px;font-size:13px;color:var(--text-secondary)}@media(max-width:720px){.admin-table-header,.admin-table-row,.admin-table-users,.admin-table-codes{grid-template-columns:1fr 1fr}.admin-code-actions{grid-template-columns:1fr}}.vcv-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.vcv-scroll-area{flex:1;overflow-y:auto;padding:24px}.vcv-screen-share-fullscreen{flex:1;display:flex;align-items:center;justify-content:center}.vcv-screen-share-section{margin-bottom:24px}.vcv-not-connected{text-align:center;color:var(--text-muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:8px 0 16px}.vcv-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;padding-bottom:24px}.vcv-card{display:flex;flex-direction:column;align-items:center;width:96px;gap:6px;position:relative}.vcv-avatar-ring{border-radius:50%;border:3px solid transparent;padding:2px;transition:border-color .15s ease}.vcv-avatar-ring.speaking{border-color:var(--success)}.vcv-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:600;overflow:hidden}.vcv-avatar img{width:100%;height:100%;object-fit:cover;display:block}.vcv-mute-overlay{position:absolute;top:50px;right:8px;background:var(--bg-tertiary);border-radius:10px;padding:2px 4px;display:flex;gap:2px;align-items:center;justify-content:center;font-size:10px}.vcv-live-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:800;padding:2px 6px;border-radius:4px;letter-spacing:.6px}.vcv-name{color:var(--text-primary);font-size:13px;font-weight:500;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:96px}.vcv-empty{color:var(--text-muted);font-size:16px;text-align:center;padding:48px 0}.vcv-connect-bar{padding:12px 16px;border-top:1px solid var(--bg-tertiary);background:var(--bg-secondary)}.vcv-connect-btn{width:100%;padding:10px;background:var(--bg-accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s}.vcv-connect-btn:hover{background:var(--bg-accent-hover)}.update-banner{position:sticky;top:0;z-index:3;display:flex;justify-content:center;padding:6px 12px;font-size:12px;letter-spacing:.2px;color:var(--text-primary);background:#3498db24;border-bottom:1px solid rgba(52,152,219,.35);box-shadow:0 1px #0003}.update-banner.available,.update-banner.downloaded{background:#2ecc7124;border-bottom:1px solid rgba(46,204,113,.35)}.update-banner.downloading{background:#3498db24;border-bottom:1px solid rgba(52,152,219,.35)}.update-banner.error{background:#e74c3c2e;border-bottom:1px solid rgba(231,76,60,.45)}.update-banner.not-available{background:#95a5a61f;border-bottom:1px solid rgba(149,165,166,.3)}.update-banner-content{display:flex;align-items:center;gap:8px;width:100%;justify-content:center}.update-spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--text-primary);border-radius:50%;animation:update-spin .8s linear infinite}@keyframes update-spin{to{transform:rotate(360deg)}}.update-action-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:var(--text-primary);padding:2px 10px;border-radius:3px;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}.update-action-btn:hover{background:#fff3}.update-dismiss-btn{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:0 2px;line-height:1;margin-left:4px}.update-dismiss-btn:hover{color:var(--text-primary)}.update-progress-bar{width:120px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.update-progress-fill{height:100%;background:#3498dbcc;border-radius:2px;transition:width .3s ease}
