*{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #111111;--bg-primary: #161616;--bg-secondary: #1c1c1c;--bg-tertiary: #232323;--bg-hover: #2a2a2a;--bg-active: #303030;--border: rgba(255,255,255,.06);--border-light: rgba(255,255,255,.04);--text-primary: #f0f0f0;--text-secondary: #999999;--text-muted: #555555;--accent: #ffffff;--danger: #e05050;--success: #3ddc84;--scrollbar: #2a2a2a;--scrollbar-hover: #3a3a3a;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.3);--shadow-lg: 0 4px 16px rgba(0,0,0,.4);--shadow-xl: 0 8px 32px rgba(0,0,0,.5)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-base);color:var(--text-primary);overflow:hidden;height:100vh}#root{height:100vh;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}input,textarea{font-family:inherit;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:12px;padding:10px 14px;font-size:14px;outline:none;transition:border-color .15s,background .15s}input:focus,textarea:focus{border-color:#ffffff1f;background:var(--bg-secondary)}input::placeholder,textarea::placeholder{color:var(--text-muted)}button{font-family:inherit;cursor:pointer;border:none;border-radius:12px;font-size:14px;font-weight:500;padding:10px 20px;transition:all .15s ease}button.primary{background:var(--text-primary);color:var(--bg-base);font-weight:600}button.primary:hover{opacity:.9}button.primary:active{transform:scale(.98)}button.secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}button.secondary:hover{background:var(--bg-hover);border-color:#ffffff1a}button.danger{background:var(--danger);color:#fff}button.danger:hover{opacity:.9}button.icon-btn{background:none;padding:8px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}button.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}button.icon-btn.active{color:var(--text-primary)}button.icon-btn.danger-hover:hover{color:var(--danger)}.auth-page{display:flex;align-items:center;justify-content:center;width:100%;height:100vh}.auth-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:24px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-xl)}.auth-card h1{font-size:26px;font-weight:700;margin-bottom:8px}.auth-card p{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.auth-card .form-group{margin-bottom:16px}.auth-card label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:6px}.auth-card input{width:100%}.auth-card button{width:100%;margin-top:8px}.auth-card .auth-link{text-align:center;margin-top:16px;font-size:13px;color:var(--text-secondary)}.auth-card .auth-link a{color:var(--text-primary);text-decoration:underline}.auth-card .error{color:var(--danger);font-size:13px;margin-bottom:12px}.auth-card .forgot-link{margin-top:8px;margin-bottom:-8px}.auth-card .forgot-link a{color:var(--text-muted);font-size:12px}.auth-card .forgot-link a:hover{color:var(--text-secondary)}.auth-success-icon{text-align:center;margin-bottom:16px;color:var(--text-secondary)}.auth-card strong{color:var(--text-primary)}.app-layout{display:flex;width:100%;height:100vh}.server-sidebar{width:72px;min-width:72px;background:var(--bg-base);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:8px;overflow-y:auto;z-index:2}.server-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-radius .2s,background .15s,transform .1s;font-size:18px;font-weight:600;color:var(--text-secondary);border:none;flex-shrink:0}.server-icon:hover{border-radius:16px;background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.server-icon.active{border-radius:16px;background:var(--text-primary);color:var(--bg-base)}.server-icon.add-server{font-size:24px;color:var(--text-muted)}.server-icon.add-server:hover{color:var(--success)}.server-divider{width:32px;height:2px;background:var(--border);border-radius:1px}.server-icon.friends-icon{background:var(--bg-tertiary);color:var(--text-secondary)}.server-icon.friends-icon:hover,.server-icon.friends-icon.active{background:var(--text-primary);color:var(--bg-base)}.friend-search{display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:6px 10px}.friend-search input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:13px;outline:none}.friend-search input:focus{border:none}.friend-search input::placeholder{color:var(--text-muted)}.friend-avatar-small{position:relative;width:32px;height:32px;min-width:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-secondary)}.status-dot-mini{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-secondary);background:var(--text-muted)}.status-dot-mini.online{background:var(--success)}.friend-info-compact{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dm-preview{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-item-row{display:flex;align-items:center;gap:10px}.friend-actions{display:flex;align-items:center;gap:2px;margin-left:auto}.favorite-btn,.remove-friend-btn{opacity:0;transition:opacity .15s;color:var(--text-muted)}.friend-item-row:hover .favorite-btn,.friend-item-row:hover .remove-friend-btn,.favorite-btn:focus,.remove-friend-btn:focus{opacity:1}.remove-friend-btn:hover{color:var(--danger)}.favorite-btn svg[fill=currentColor]{color:var(--text-primary)}.badge{position:absolute;top:-4px;right:-4px;background:var(--danger);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 4px}.request-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.request-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;background:var(--bg-tertiary);border:1px solid var(--border)}.request-avatar{width:36px;height:36px;min-width:36px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--text-secondary)}.request-info{flex:1;min-width:0}.request-name{font-size:14px;font-weight:500;color:var(--text-primary)}.request-username{font-size:12px;color:var(--text-muted)}.status-dot-inline{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-muted);margin-left:6px;vertical-align:middle}.status-dot-inline.online{background:var(--success)}.channel-sidebar{width:240px;min-width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:1}.channel-sidebar-header{padding:16px;font-size:16px;font-weight:700;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;height:52px}.channel-list{flex:1;overflow-y:auto;padding:8px}.channel-category{padding:16px 8px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:flex;align-items:center;justify-content:space-between}.channel-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;cursor:pointer;color:var(--text-secondary);font-size:14px;transition:all .1s ease}.channel-item:hover{background:var(--bg-hover);color:var(--text-primary)}.channel-item.active{background:var(--bg-active);color:var(--text-primary)}.channel-item .channel-icon{font-size:18px;opacity:.5;width:20px;text-align:center;display:flex;align-items:center;justify-content:center}.channel-item .channel-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-users{padding-left:36px}.voice-user{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:13px;color:var(--text-secondary)}.voice-user .user-avatar-small{width:20px;height:20px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:10px}.user-panel{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;position:relative}.user-panel .user-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-panel .user-info{flex:1;overflow:hidden}.user-panel .user-name{font-size:13px;font-weight:600}.user-panel .user-status{font-size:11px;color:var(--text-muted)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.top-bar{height:52px;min-height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;z-index:1}.top-bar .channel-label{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600}.top-bar .channel-label .hash{color:var(--text-muted)}.top-bar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.top-bar-btn{transition:all .15s}.top-bar-btn.active{color:var(--text-primary);background:var(--bg-active)}.chat-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.message-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:2px}.message{display:flex;gap:12px;padding:6px 8px;border-radius:10px;transition:background .1s}.message:hover{background:var(--bg-secondary)}.message .msg-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.message .msg-body{flex:1;min-width:0}.message .msg-header{display:flex;align-items:baseline;gap:8px}.message .msg-author{font-size:14px;font-weight:600}.message .msg-time{font-size:11px;color:var(--text-muted)}.message .msg-content{font-size:14px;color:var(--text-primary);line-height:1.5;word-break:break-word}.message .msg-edited{font-size:11px;color:var(--text-muted)}.message{position:relative}.msg-actions{position:absolute;top:-8px;right:8px;display:flex;gap:2px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:10px;padding:2px;z-index:10;box-shadow:var(--shadow-lg);animation:fadeIn .1s ease}.msg-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:0;transition:all .1s}.msg-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.msg-action-btn.active{color:var(--text-primary)}.msg-action-btn.danger:hover{color:var(--danger)}.msg-edit-box input{width:100%;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;padding:8px 10px;font-size:14px}.msg-edit-box input:focus{border-color:#ffffff1f}.msg-edit-hint{font-size:11px;color:var(--text-muted);margin-top:4px}.message.compact{padding-left:52px}.message.compact .msg-avatar{display:none}.message-input-container{padding:0 16px 16px}.message-input-wrapper{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:0 14px;transition:border-color .15s}.message-input-wrapper:focus-within{border-color:#ffffff1f}.message-input-wrapper input,.message-input-wrapper textarea{flex:1;background:transparent;border:none;padding:14px 0;font-size:14px;resize:none;max-height:120px;overflow-y:auto;line-height:1.4;font-family:inherit}.message-input-wrapper input:focus,.message-input-wrapper textarea:focus{border:none;box-shadow:none}.reply-preview{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;margin:0 16px;background:var(--bg-secondary);border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0;font-size:12px;color:var(--text-secondary)}.reply-preview-label strong{color:var(--text-primary)}.reply-preview-close{padding:2px!important;opacity:.5}.reply-preview-close:hover{opacity:1}.reply-preview+.message-input-wrapper{border-top-left-radius:0;border-top-right-radius:0;margin:0 16px 0 0}.typing-indicator{padding:4px 16px;font-size:12px;color:var(--text-muted);height:20px}.e2ee-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--success);padding:2px 8px;background:#3ddc841a;border-radius:8px;margin-left:8px}.voice-e2ee-badge{position:absolute;top:12px;right:12px;z-index:10;display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--success);padding:4px 10px;background:#0009;border-radius:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.member-list{width:240px;min-width:240px;background:var(--bg-secondary);border-left:1px solid var(--border);padding:16px;overflow-y:auto;z-index:1}.member-category{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:16px 0 6px}.member-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:10px;cursor:pointer;transition:background .1s}.member-item:hover{background:var(--bg-hover)}.member-item .member-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;position:relative}.member-item .status-dot{width:10px;height:10px;border-radius:50%;position:absolute;bottom:-1px;right:-1px;border:2px solid var(--bg-secondary)}.status-dot.online{background:var(--success)}.status-dot.idle{background:#e6a817}.status-dot.dnd{background:var(--danger)}.status-dot.offline{background:var(--text-muted)}.member-item .member-name{font-size:14px;color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-role-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:1px 5px;border-radius:6px;flex-shrink:0}.member-role-badge.role-owner{background:#ffffff1a;color:var(--text-primary)}.member-role-badge.role-admin{background:#ffffff0d;color:var(--text-secondary)}.video-grid-container{flex:1;display:flex;flex-direction:column;background:var(--bg-base)}.video-grid{flex:1;display:grid;gap:8px;padding:8px}.video-grid.grid-1{grid-template-columns:1fr}.video-grid.grid-2,.video-grid.grid-4{grid-template-columns:1fr 1fr}.video-grid.grid-many{grid-template-columns:repeat(3,1fr)}.video-tile{background:var(--bg-tertiary);border-radius:16px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:200px;border:1px solid var(--border)}.video-tile video{width:100%;height:100%;object-fit:cover;border-radius:16px}.video-tile .video-label{position:absolute;bottom:12px;left:12px;background:#000000b3;color:#fff;padding:4px 10px;border-radius:8px;font-size:13px;font-weight:500}.video-tile .no-video{font-size:48px;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;padding:24px;width:100%;max-width:440px;animation:slideUp .2s ease;box-shadow:var(--shadow-xl)}.modal h2{font-size:20px;font-weight:700;margin-bottom:16px}.modal .form-group{margin-bottom:16px}.modal label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:6px}.modal input,.modal select{width:100%}.modal select{font-family:inherit;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:12px;padding:10px 14px;font-size:14px;outline:none}.modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.server-dropdown{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;margin:0 8px;overflow:hidden;animation:scaleIn .12s ease;box-shadow:var(--shadow-lg)}.server-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .1s}.server-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.server-dropdown-item .invite-code-preview{margin-left:auto;font-family:SF Mono,Consolas,monospace;font-size:11px;color:var(--text-muted);background:var(--bg-primary);padding:2px 6px;border-radius:6px}.user-dropdown{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;overflow:hidden;z-index:200;box-shadow:var(--shadow-lg);animation:slideUp .15s ease}.user-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .1s}.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-dropdown-item.danger:hover{color:var(--danger)}.channel-category button,.channel-category .add-channel-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .15s}.channel-category button:hover,.channel-category .add-channel-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:40px}.empty-state h2{font-size:24px;margin-bottom:8px;color:var(--text-secondary)}.empty-state p{font-size:14px;max-width:400px;line-height:1.5}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .2s ease}.settings-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;display:flex;width:720px;max-width:90vw;height:520px;max-height:85vh;overflow:hidden;box-shadow:var(--shadow-xl);animation:scaleIn .2s ease}.settings-sidebar{width:200px;min-width:200px;background:var(--bg-primary);padding:20px 12px;border-right:1px solid var(--border);display:flex;flex-direction:column}.settings-sidebar h2{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 8px 12px}.settings-nav{display:flex;flex-direction:column;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:all .1s;text-align:left;width:100%}.settings-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-nav-item.active{background:var(--bg-active);color:var(--text-primary)}.settings-content{flex:1;display:flex;flex-direction:column;min-width:0}.settings-content-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px;border-bottom:1px solid var(--border)}.settings-content-header h2{font-size:18px;font-weight:700}.settings-close-btn{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;padding:0}.settings-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-content-body{flex:1;overflow-y:auto;padding:20px 24px 24px}.settings-section h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;margin-top:16px}.settings-section h3:first-child{margin-top:0}.settings-section select{width:100%;font-family:inherit;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:12px;padding:9px 12px;font-size:13px;outline:none;cursor:pointer;transition:border-color .15s}.settings-section select:hover{border-color:#ffffff1a}.settings-divider{height:1px;background:var(--border);margin:20px 0}.setting-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.setting-row label{font-size:13px;color:var(--text-secondary);min-width:80px}.setting-row select{flex:1}.setting-hint{font-size:11px;color:var(--text-muted);margin-top:2px;margin-bottom:8px}.setting-hint-inline{font-size:11px;color:var(--text-muted);margin-left:auto}.checkbox-row label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-primary);min-width:unset}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--text-primary);cursor:pointer}.settings-toggle-group{display:flex;gap:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);margin-bottom:12px}.toggle-option{flex:1;padding:9px 14px;font-size:13px;font-weight:500;background:var(--bg-primary);color:var(--text-muted);border:none;cursor:pointer;transition:all .15s;text-align:center}.toggle-option:not(:last-child){border-right:1px solid var(--border)}.toggle-option:hover{color:var(--text-primary)}.toggle-option.active{background:var(--bg-active);color:var(--text-primary)}.ptt-key-btn{padding:8px 16px;border-radius:12px;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);font-size:13px;font-weight:500;font-family:SF Mono,Consolas,monospace;cursor:pointer;transition:all .15s;min-width:100px;text-align:center}.ptt-key-btn:hover{border-color:#ffffff1a}.ptt-key-btn.capturing{border-color:#fff3;background:var(--bg-active);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.settings-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:4px;border-radius:2px;background:var(--bg-tertiary);outline:none;border:none;padding:0}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--text-primary);cursor:pointer;border:none}.settings-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--text-primary);cursor:pointer;border:none}.slider-label{font-size:12px;color:var(--text-secondary);min-width:42px;text-align:right;font-family:SF Mono,Consolas,monospace}.mic-test{display:flex;align-items:center;gap:12px}.mic-test-bar-container{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;position:relative;overflow:hidden}.mic-test-bar{height:100%;background:var(--text-muted);border-radius:4px;transition:width .05s linear;min-width:0}.mic-test-bar.active{background:var(--success)}.mic-test-threshold{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--danger);border-radius:1px;pointer-events:none}.msg-embeds{display:flex;flex-direction:column;gap:6px;margin-top:6px}.link-embed{display:flex;max-width:520px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:border-color .15s}.link-embed:hover{border-color:#ffffff1a}.link-embed-accent{width:4px;min-height:100%;background:var(--text-muted);flex-shrink:0}.link-embed-body{flex:1;min-width:0;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.link-embed-header{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.link-embed-favicon{width:14px;height:14px;border-radius:2px;flex-shrink:0}.link-embed-site{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-embed-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.link-embed-description{font-size:13px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.link-embed-thumbnail{width:80px;min-width:80px;flex-shrink:0}.link-embed-thumbnail img{width:100%;height:100%;object-fit:cover}.avatar{border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-secondary);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.profile-avatar-section{display:flex;align-items:center;gap:16px;margin-top:8px}.profile-avatar-preview{width:80px;height:80px;min-width:80px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid var(--border)}.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}.profile-avatar-letter{font-size:32px;font-weight:600;color:var(--text-muted)}.profile-avatar-actions{display:flex;flex-direction:column;gap:6px}.profile-avatar-actions .setting-hint{margin-top:2px}.profile-name-row{display:flex;gap:8px;align-items:center;margin-top:8px}.profile-name-row input{flex:1}.profile-info-grid{display:flex;flex-direction:column;gap:10px;margin-top:8px}.profile-info-item{display:flex;flex-direction:column;gap:2px}.profile-info-item label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.profile-info-item span{font-size:14px;color:var(--text-secondary)}.profile-id{font-size:12px!important;font-family:monospace;color:var(--text-muted)!important;word-break:break-all}.account-password-form{display:flex;flex-direction:column;gap:12px;margin-top:8px}.account-password-form .form-group{display:flex;flex-direction:column;gap:4px}.account-password-form .form-group label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.account-password-form .form-group input{padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:14px}.account-password-form .form-group input:focus{outline:none;border-color:#ffffff1f}.danger-btn{color:var(--danger)!important}.danger-btn:hover{background:var(--danger)!important;color:#fff!important}.settings-message{margin-top:12px;padding:8px 12px;border-radius:10px;font-size:13px}.settings-message.success{background:#3ddc841a;color:var(--success)}.settings-message.error{background:#e050501a;color:var(--danger)}.voice-controls{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--bg-primary);border-top:1px solid var(--border)}.voice-controls .voice-info{display:flex;flex-direction:column;gap:1px}.voice-controls .voice-channel-name{font-size:13px;font-weight:600;color:var(--success);display:flex;align-items:center;gap:6px}.voice-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0}.voice-dot.speaking{animation:speaking-pulse .8s ease-in-out infinite}@keyframes speaking-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}.voice-controls .voice-status{font-size:11px;color:var(--text-muted)}.audio-level-bar-container{height:3px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.audio-level-bar{height:100%;background:var(--text-muted);border-radius:2px;transition:width .05s linear}.audio-level-bar.speaking{background:var(--success)}.connection-stats{display:flex;gap:10px;padding:4px 0}.connection-stats .stat{display:flex;flex-direction:column;align-items:center;gap:1px}.connection-stats .stat-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}.connection-stats .stat-value{font-size:11px;font-family:SF Mono,Consolas,monospace;color:var(--text-secondary)}.connection-stats .stat-value.warn{color:#e6a817}.voice-buttons{display:flex;gap:4px;flex-wrap:wrap}.voice-buttons .control-btn{width:34px;height:34px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;color:var(--text-secondary);font-size:16px;transition:all .15s;flex-shrink:0;padding:0}.voice-buttons .control-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.voice-buttons .control-btn.muted{background:var(--danger);color:#fff}.voice-buttons .control-btn.active{background:var(--success);color:var(--bg-base)}.voice-buttons .control-btn.speaking-ring{box-shadow:0 0 0 2px var(--success)}.voice-buttons .control-btn.settings{margin-left:auto}.voice-buttons .control-btn.disconnect{background:transparent;border:1px solid var(--border)}.voice-buttons .control-btn.disconnect:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.screen-share-preview{position:fixed;bottom:80px;right:16px;width:280px;border-radius:16px;overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border);box-shadow:var(--shadow-xl);z-index:50}.screen-share-preview video{width:100%;display:block;object-fit:contain;max-height:180px}.screen-share-preview .preview-label{padding:6px 10px;font-size:11px;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);text-align:center}.file-share-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s;padding:0}.file-share-btn:hover{color:var(--text-primary)}.file-message{display:flex;align-items:center;gap:12px;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:10px 14px;margin-top:4px;transition:border-color .15s}.file-message:hover{border-color:#ffffff1a}.file-message-icon{width:36px;height:36px;background:var(--bg-tertiary);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.file-message-info{flex:1;min-width:0}.file-message-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-message-size{font-size:12px;color:var(--text-muted);margin-top:2px}.file-message-action{flex-shrink:0}.file-download-btn{padding:6px 16px;font-size:13px;font-weight:500;background:var(--text-primary);color:var(--bg-base);border:none;border-radius:10px;cursor:pointer;transition:opacity .15s}.file-download-btn:hover{opacity:.85}.file-download-btn.small{padding:4px 10px;font-size:11px}.file-unavailable{font-size:12px;color:var(--text-muted);font-style:italic}.file-shared-label{font-size:12px;color:var(--text-muted)}.file-complete{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--success)}.file-error-state{display:flex;align-items:center;gap:8px}.file-error-text{font-size:11px;color:var(--danger)}.file-transfer-progress{display:flex;align-items:center;gap:8px;min-width:120px}.file-progress-bar{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.file-progress-fill{height:100%;background:var(--text-primary);border-radius:2px;transition:width .2s ease}.file-progress-text{font-size:11px;color:var(--text-muted);min-width:32px;text-align:right}.file-cancel-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;padding:0}.file-cancel-btn:hover{color:var(--danger)}.invite-page{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base)}.invite-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:24px;padding:40px;text-align:center;min-width:360px;max-width:420px;box-shadow:var(--shadow-xl)}.invite-subtitle{color:var(--text-muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:24px}.invite-server-icon{width:80px;height:80px;border-radius:20px;background:var(--bg-tertiary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:32px;font-weight:600;color:var(--text-primary)}.invite-server-icon img{width:100%;height:100%;border-radius:20px;object-fit:cover}.invite-server-name{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.invite-member-count{display:flex;align-items:center;justify-content:center;gap:6px;color:var(--text-muted);font-size:14px;margin-bottom:24px}.invite-error{color:var(--danger);font-size:14px;margin-bottom:16px}.invite-error-icon{color:var(--text-muted);margin-bottom:16px}.invite-loading{color:var(--text-muted);font-size:14px;padding:40px 0}.invite-btn{display:inline-block;width:100%;padding:12px 24px;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;border:none;text-decoration:none;text-align:center;transition:opacity .15s}.invite-btn:hover{opacity:.9}.invite-btn:active{transform:scale(.98)}.invite-btn:disabled{opacity:.5;cursor:not-allowed}.invite-btn.primary{background:var(--text-primary);color:var(--bg-base)}.invite-btn.secondary{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);margin-top:12px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes skeletonPulse{0%,to{opacity:.06}50%{opacity:.12}}.pinned-drawer{width:240px;min-width:240px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;animation:slideInRight .2s ease}.pinned-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-primary);gap:8px}.pinned-drawer-header span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-drawer-body{flex:1;overflow-y:auto;padding:8px}.pinned-message{padding:10px 12px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);margin-bottom:6px;transition:border-color .15s}.pinned-message:hover{border-color:#ffffff1a}.pinned-message-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.pinned-message-author{font-size:13px;font-weight:600;color:var(--text-primary)}.pinned-message-time{font-size:11px;color:var(--text-muted);margin-left:auto;white-space:nowrap}.pinned-unpin-btn{opacity:0;transition:opacity .15s;flex-shrink:0}.pinned-message:hover .pinned-unpin-btn{opacity:1}.pinned-message-content{font-size:13px;color:var(--text-secondary);line-height:1.4;word-break:break-word}.pinned-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:40px 16px;line-height:1.5}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;background:var(--bg-tertiary);border:1px solid var(--border);box-shadow:var(--shadow-lg);font-size:13px;color:var(--text-primary);pointer-events:auto;cursor:pointer;animation:toastIn .3s ease;max-width:360px}.toast-exit{animation:toastOut .3s ease forwards}.toast-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:#3ddc8426;color:var(--success)}.toast-error .toast-icon{background:#e0505026;color:var(--danger)}.toast-info .toast-icon{background:#ffffff1a;color:var(--text-secondary)}.toast-message{line-height:1.4}.skeleton{background:var(--bg-tertiary);border-radius:8px;animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-message{display:flex;gap:12px;padding:12px 20px}.skeleton-avatar{width:36px;height:36px;min-width:36px;border-radius:50%}.skeleton-text-group{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-line{height:12px;border-radius:6px}.skeleton-line.short{width:30%}.skeleton-line.medium{width:60%}.skeleton-line.long{width:85%}.skeleton-loader{background:var(--bg-tertiary);border-radius:4px;animation:skeletonPulse 1.5s ease-in-out infinite}.context-menu{position:fixed;z-index:500;min-width:180px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;padding:4px;box-shadow:var(--shadow-lg);animation:scaleIn .12s ease}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;font-size:13px;color:var(--text-secondary);background:none;border:none;border-radius:8px;cursor:pointer;transition:all .1s;text-align:left}.context-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:#e050501a;color:var(--danger)}.context-menu-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.context-menu-separator{height:1px;background:var(--border);margin:4px 6px}.edit-channel-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:20px;width:360px;max-width:90vw;animation:scaleIn .15s ease}.edit-channel-modal h3{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-primary)}.error-boundary{display:flex;align-items:center;justify-content:center;width:100%;height:100vh;background:var(--bg-base);color:var(--text-primary)}.error-boundary-content{text-align:center;max-width:400px;padding:40px}.error-boundary-content svg{color:var(--danger);margin-bottom:16px}.error-boundary-content h2{font-size:22px;font-weight:700;margin-bottom:8px}.error-boundary-content p{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:24px}.error-boundary-actions{display:flex;gap:10px;justify-content:center}.channel-item.unread .channel-name{color:var(--text-primary);font-weight:600}.unread-badge{background:var(--text-primary);color:var(--bg-base);font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;margin-left:auto}.server-icon .unread-dot{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background:var(--text-primary);border-radius:50%;border:2px solid var(--bg-base)}.markdown-content{font-size:14px;line-height:1.5;word-break:break-word}.markdown-content p{margin:0}.markdown-content p+p{margin-top:8px}.markdown-content a{color:#5dadec;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content code{background:#ffffff0f;padding:1px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:13px}.markdown-content pre{background:var(--bg-base);border:1px solid var(--border);border-radius:8px;padding:12px;margin:8px 0;overflow-x:auto}.markdown-content pre code{background:none;padding:0;border-radius:0;font-size:13px;line-height:1.4}.markdown-content blockquote{border-left:3px solid var(--text-muted);margin:8px 0;padding:4px 12px;color:var(--text-secondary)}.markdown-content ul,.markdown-content ol{margin:4px 0;padding-left:24px}.markdown-content li{margin:2px 0}.markdown-content strong{font-weight:700;color:var(--text-primary)}.markdown-content em{font-style:italic}.markdown-content hr{border:none;border-top:1px solid var(--border);margin:12px 0}.markdown-content table{border-collapse:collapse;margin:8px 0}.markdown-content th,.markdown-content td{border:1px solid var(--border);padding:6px 12px;font-size:13px}.markdown-content th{background:var(--bg-tertiary);font-weight:600}.reaction-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-pill{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);font-size:13px;cursor:pointer;transition:all .15s}.reaction-pill:hover{background:var(--bg-hover)}.reaction-pill.active{border-color:#ffffff26;background:#ffffff14}.reaction-pill .reaction-emoji{font-size:16px;line-height:1}.reaction-pill .reaction-count{font-size:12px;color:var(--text-secondary)}.reaction-pill.active .reaction-count{color:var(--text-primary)}.reaction-add-btn{display:flex;align-items:center;justify-content:center;width:28px;height:24px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;color:var(--text-muted);font-size:14px;transition:all .15s}.reaction-add-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.emoji-picker-container{position:absolute;bottom:100%;right:0;z-index:200;margin-bottom:8px}.reply-header{display:flex;align-items:center;gap:6px;padding:4px 0;margin-bottom:2px;font-size:12px;color:var(--text-muted);cursor:pointer}.reply-header:hover{color:var(--text-secondary)}.reply-header svg{flex-shrink:0}.reply-author{font-weight:600;color:var(--text-secondary)}.reply-snippet{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.message-highlight{animation:messageHighlight 1.5s ease}@keyframes messageHighlight{0%,30%{background:#ffffff0f}to{background:transparent}}.search-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn .15s ease}.search-modal-content{width:560px;max-height:500px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-xl);overflow:hidden;display:flex;flex-direction:column;animation:slideUp .2s ease}.search-modal-input{padding:16px;border-bottom:1px solid var(--border)}.search-modal-input input{width:100%;font-size:16px}.search-results{flex:1;overflow-y:auto;padding:8px}.search-result{display:flex;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .1s}.search-result:hover{background:var(--bg-hover)}.search-result-meta{font-size:11px;color:var(--text-muted)}.search-result-content{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.mention-autocomplete{position:absolute;bottom:100%;left:14px;right:14px;max-height:200px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);z-index:100;margin-bottom:4px;padding:4px}.mention-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px;transition:background .1s}.mention-item:hover,.mention-item.selected{background:var(--bg-hover)}.mention-item .mention-name{font-weight:500;color:var(--text-primary)}.mention-item .mention-username{color:var(--text-muted);font-size:12px}.mention-highlight{background:#58a6ff1f;color:#5dadec;padding:0 2px;border-radius:3px;font-weight:500}.hamburger-btn{display:none}.member-count-label{font-size:13px;color:var(--text-muted)}.sidebar-overlay{display:none}@media(max-width:768px){.hamburger-btn{display:flex!important;flex-shrink:0}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.server-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .25s ease}.channel-sidebar{position:fixed;top:0;left:72px;bottom:0;z-index:100;transform:translate(calc(-100% - 72px));transition:transform .25s ease}.app-layout.sidebar-open .server-sidebar,.app-layout.sidebar-open .channel-sidebar{transform:translate(0)}.main-content{width:100%}.member-list,.member-count-label{display:none}.pinned-drawer{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:360px;z-index:100;box-shadow:var(--shadow-xl)}.message-row{padding:8px 12px}.message-hover-actions{right:8px;top:-12px}.message-input-wrapper textarea{font-size:16px;min-height:44px}.message-input-wrapper .send-btn,.message-input-wrapper .attach-btn{min-width:44px;min-height:44px}.modal{width:95vw;max-width:95vw;margin:16px}.search-modal .search-modal-content{width:95vw;max-width:95vw;height:80vh;margin:10vh auto}.context-menu{max-width:calc(100vw - 16px)}.emoji-picker-container{right:0;left:0;width:100%;max-width:360px}.auth-card{margin:16px;width:calc(100vw - 32px);max-width:420px}.voice-controls{flex-wrap:wrap;gap:8px}.voice-controls button{min-width:44px;min-height:44px}.reply-preview{font-size:12px;padding:6px 12px}.toast-container{left:16px;right:16px;bottom:16px;max-width:100%}}@media(min-width:769px)and (max-width:1024px){.channel-sidebar,.member-list{width:200px;min-width:200px}.server-sidebar{width:64px;min-width:64px}.server-icon{width:42px;height:42px;font-size:16px}}
