.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#00685c,#376e5d,#218274)}.auth-card{background:#fff;border-radius:var(--radius-md);border:1px solid rgba(0,102,92,.2);padding:40px;width:100%;max-width:480px;box-shadow:0 16px 48px #0000004d}.auth-header{text-align:center;margin-bottom:24px}.auth-title{font-size:24px;font-weight:700;color:#1a2b27;margin-bottom:8px}.auth-subtitle{color:#2e4a43;font-size:var(--font-size-sm)}.auth-submit{width:100%;padding:14px;font-size:var(--font-size-md);margin-top:8px}.auth-footer{text-align:center;margin-top:16px;font-size:var(--font-size-xs);color:var(--text-muted)}.auth-footer a{color:var(--brand)}.auth-footer a:hover{text-decoration:underline}.server-icon-upload{display:flex;justify-content:center;margin-bottom:24px}.icon-upload-area{width:80px;height:80px;border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .15s ease}.icon-upload-area:hover{border-color:var(--brand)}.icon-preview{width:100%;height:100%;object-fit:cover}.icon-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);font-size:var(--font-size-xs)}.copy-invite-area{display:flex;gap:8px;margin-top:16px}.copy-invite-input{flex:1;padding:8px 12px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);font-family:var(--font-mono)}.settings-section{margin-bottom:24px}.settings-section-title{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.avatar-upload-row{display:flex;align-items:center;gap:16px;margin-bottom:16px}.status-picker{display:flex;gap:8px;flex-wrap:wrap}.status-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);font-size:var(--font-size-xs);transition:border-color .15s ease,background-color .15s ease}.status-btn.active{border-color:var(--brand);background:#21827414;color:var(--brand)}.danger-zone{border:1px solid var(--danger);border-radius:var(--radius-sm);padding:16px}.danger-zone-title{color:var(--danger);font-weight:700;margin-bottom:12px}.user-profile-banner{height:40px;background:var(--brand);border-radius:var(--radius-sm) var(--radius-sm) 0 0;margin:calc(var(--space-6) * -1) calc(var(--space-6) * -1) 0}.user-profile-avatar-wrap{position:relative;margin-top:-28px}.user-profile-avatar{width:56px;height:56px;flex-shrink:0;font-size:22px}.user-profile-body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) 0 var(--space-2)}.user-profile-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.user-profile-discriminator{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:400}.user-profile-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);background:var(--bg-accent);color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:600;width:fit-content}.user-profile-description{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color);font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5;word-break:break-word}.server-list{width:100%;height:var(--sidebar-server-width);background:var(--bg-tertiary);background-image:repeating-linear-gradient(135deg,transparent,transparent 10px,rgba(0,0,0,.04) 10px,rgba(0,0,0,.04) 11px);display:flex;flex-direction:row;align-items:center;padding:0 12px;gap:8px;overflow-x:auto;overflow-y:hidden;flex-shrink:0;box-shadow:0 2px 8px #00000040}.server-list-divider{width:2px;height:32px;background:#9af3e233;flex-shrink:0}.server-icon-wrapper{position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;width:48px;height:48px;overflow:hidden;border-radius:var(--radius-sm);transition:box-shadow .15s ease;flex-shrink:0}.server-icon-wrapper:hover{box-shadow:inset 0 -3px #9af3e280}.server-icon-wrapper.active{box-shadow:0 3px 0 var(--brand-light)}.server-icon{width:48px;height:48px;object-fit:cover;transition:transform .15s ease;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;background:#0003;overflow:hidden;flex-shrink:0}.server-icon-wrapper:hover .server-icon:not(.server-icon-add){transform:scale(1.5)}.server-icon-placeholder{font-size:13px;font-weight:600;background:#218274b3;letter-spacing:-.5px}.server-icon-add{background:#9af3e21a;color:var(--brand-light)}.server-icon-wrapper:hover .server-icon-add{background:#9af3e233;color:var(--brand-light)}.server-icon-user{margin-left:4px}.server-icon-user-placeholder{background:var(--brand)}.server-notification-badge{position:absolute;bottom:1px;right:1px;width:14px;height:14px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-tertiary);pointer-events:none}.channel-type-picker{display:flex;flex-direction:column;gap:8px}.channel-type-option{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.channel-type-option input[type=radio]{position:absolute;opacity:0;pointer-events:none}.channel-type-option:hover{background:var(--bg-modifier-hover)}.channel-type-option.active{border-color:var(--brand);background:#21827414}.channel-type-icon{font-size:20px;font-weight:700;color:var(--text-muted);width:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.channel-type-info{display:flex;flex-direction:column}.channel-type-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.channel-type-desc{font-size:var(--font-size-xs);color:var(--text-muted)}.channel-list{width:var(--sidebar-channel-width);background:var(--bg-secondary);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;border-right:1px solid var(--border-sidebar)}.channel-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-sidebar);min-height:48px;flex-shrink:0}.channel-list-server-name{font-weight:600;font-size:var(--font-size-md);color:var(--text-sidebar-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-list-body{flex:1;overflow-y:auto;padding:8px 0}.section-add-btn{font-size:16px;line-height:1;transform:translateY(-1px);margin-left:2px;cursor:pointer;opacity:0;color:var(--text-sidebar-muted);transition:opacity .15s ease,color .15s ease}.section-add-btn:hover{color:var(--text-sidebar-primary)}.section-header:hover .section-add-btn{opacity:1}.channel-list .section-header{color:var(--text-sidebar-muted)}.channel-list .section-header:after{content:"";flex:1;height:1px;background:var(--border-sidebar);margin-left:8px}.channel-list .section-header:hover{color:var(--text-sidebar-secondary)}.channel-icon{flex-shrink:0;color:var(--text-sidebar-muted);font-weight:500;font-size:var(--font-size-md);width:16px;display:flex;align-items:center;justify-content:center}.channel-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-sm)}.channel-delete-btn{opacity:0;font-size:18px;color:var(--text-sidebar-muted);line-height:1;padding:0 2px;transition:opacity .15s ease,color .15s ease}.channel-row:hover .channel-delete-btn{opacity:1}.channel-row.active .channel-icon{color:var(--text-sidebar-primary)}.channel-delete-btn:hover{color:var(--danger)}.voice-channel-row{cursor:pointer}.voice-channel-row.active .channel-icon svg{color:var(--brand-light)}.voice-active-indicator{color:var(--brand-light);font-size:10px;flex-shrink:0}.voice-channel-row.in-voice .channel-name{color:var(--brand-light)}.voice-channel-group{display:flex;flex-direction:column}.voice-participant-row{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 30px;color:var(--text-sidebar-muted);font-size:var(--font-size-sm);cursor:default;border-radius:0;margin:0}.voice-participant-avatar{width:16px;height:16px;flex-shrink:0;object-fit:cover}.voice-participant-avatar-placeholder{background:#0000004d;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--text-sidebar-muted)}.voice-participant-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.voice-participant-disconnect{opacity:0;flex-shrink:0;color:var(--text-sidebar-muted);display:flex;align-items:center;justify-content:center;transition:opacity .15s ease,color .15s ease}.voice-participant-self:hover .voice-participant-disconnect{opacity:1}.voice-participant-disconnect:hover{color:var(--danger)}.member-list{width:var(--sidebar-member-width);background:var(--bg-secondary);padding:16px 8px;overflow-y:auto;flex-shrink:0;border-left:1px solid var(--border-sidebar)}.member-section-header{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-sidebar-muted);padding:16px 8px 4px}.member-item{display:flex;align-items:center;gap:10px;padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .1s ease}.member-item:hover{background:#ffffff0f}.member-avatar-wrapper{position:relative;flex-shrink:0}.member-avatar-wrapper .status-dot{position:absolute;bottom:-5px;right:-5px;border-color:var(--bg-secondary)}.member-info{flex:1;overflow:hidden;min-width:0}.member-name{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-sidebar-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-discriminator{font-size:var(--font-size-xs);color:var(--text-sidebar-muted)}.member-role{font-size:var(--font-size-xs);color:#a6feedb3;background:transparent;border:1px solid rgba(154,243,226,.3);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0;text-transform:capitalize}.emote-picker{position:fixed;z-index:var(--z-dropdown);width:320px;height:340px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-high);display:flex;flex-direction:column;overflow:hidden}.emote-picker-search{padding:var(--space-2) var(--space-3);background:var(--brand-light);border:none;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:var(--font-size-xs);outline:none;width:100%}.emote-picker-search::placeholder{color:var(--text-muted)}.emote-picker-scroll{overflow-y:auto;max-height:280px;padding:var(--space-2)}.emote-picker-empty{text-align:center;padding:var(--space-5);color:var(--text-muted);font-size:var(--font-size-xs)}.emote-section{margin-bottom:var(--space-3)}.emote-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-1) var(--space-1);margin-bottom:var(--space-1)}.emote-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px}.emote-cell{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background-color .1s ease;cursor:pointer}.emote-cell:hover{background:var(--bg-accent)}.emote-cell-unicode{font-size:20px;line-height:1;-webkit-user-select:none;user-select:none}.emote-cell-img{width:22px;height:22px;object-fit:contain}.reaction-area{position:relative}.reaction-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-pill{display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);color:var(--text-secondary);transition:background-color .1s ease,border-color .1s ease;width:45px;justify-content:center}.reaction-pill:hover{background:var(--bg-accent);border-color:var(--brand)}.reaction-pill-active{background:#21827414;border-color:var(--brand);color:var(--brand)}.reaction-pill-emoji{font-size:20px;line-height:1}.reaction-pill-img{width:20px;height:20px;object-fit:contain}.reaction-pill-count{font-size:14px;font-weight:500}.reaction-add-pill{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--bg-accent);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-muted);transition:background-color .1s ease}.reaction-add-pill:hover{background:var(--bg-accent);color:var(--text-primary)}.reaction-bar{position:absolute;bottom:-8px;right:8px;display:flex;align-items:center;gap:2px;background:var(--brand-light);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:2px;box-shadow:var(--shadow-low);z-index:10}.reaction-bar-btn{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background-color .1s ease,color .1s ease;cursor:pointer}.reaction-bar-btn:hover{background:var(--bg-accent);color:var(--text-primary)}.reaction-bar-danger:hover{background:var(--danger);color:#fff}.reaction-bar-emoji{font-size:18px;line-height:1}.reaction-bar-img{width:20px;height:20px;object-fit:contain}.reaction-bar-plus{font-size:var(--font-size-sm)}.reaction-bar-divider{width:1px;height:16px;background:var(--border-color);margin:0 2px}.message-item{display:flex;gap:16px;padding:2px 16px 2px 14px;position:relative;border-radius:var(--radius-sm);transition:background-color .05s ease,border-color .05s ease;border-left:2px solid transparent}.message-item:hover{background:#9af3e233;border-left:2px solid var(--bg-tertiary)}.message-item:not(.message-compact){margin-top:16px;padding-top:2px}.message-avatar-col{width:40px;flex-shrink:0;padding-top:2px}.message-compact-time{display:flex;align-items:center;justify-content:flex-end}.compact-timestamp{font-size:10px;color:var(--text-muted);white-space:nowrap}.message-content-col{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-author{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary)}.message-discriminator{color:var(--text-muted);font-size:var(--font-size-xs);font-weight:400}.message-timestamp{font-size:var(--font-size-xs);color:var(--text-muted)}.message-text{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.5;word-break:break-word;white-space:pre-wrap}.message-edited{font-size:var(--font-size-xs);color:var(--text-muted);margin-left:4px}.message-edit-area{display:flex;flex-direction:column;gap:4px}.message-edit-input{background:#fff;border:1px solid var(--brand);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.5;resize:none;outline:none;width:100%;box-shadow:0 2px 0 0 var(--brand)}.message-edit-hint{font-size:var(--font-size-xs);color:var(--text-muted)}.message-edit-hint button{color:var(--brand);text-decoration:underline}.emote-inline{display:inline;font-size:1.25em;vertical-align:-.15em;line-height:1}img.emote-inline{width:1.25em;height:1.25em;object-fit:contain;vertical-align:-.25em}.message-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.attachment-image-link{display:block;max-width:400px}.attachment-image{max-width:400px;max-height:300px;border-radius:var(--radius-sm);object-fit:contain;background:var(--bg-accent)}.attachment-file{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-primary);max-width:320px;transition:background-color .1s ease}.attachment-file:hover{background:var(--bg-accent);text-decoration:none}.attachment-file-icon{color:var(--brand);flex-shrink:0}.attachment-file-info{display:flex;flex-direction:column;min-width:0}.attachment-filename{font-size:var(--font-size-sm);color:var(--text-link);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-filesize{font-size:var(--font-size-xs);color:var(--text-muted)}.message-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;padding:0 0 8px;box-shadow:inset 0 8px 16px -8px #00665c14}.messages-container{display:flex;flex-direction:column;min-height:min-content;margin-top:auto;padding:0 16px}.message-list-empty{flex:1;display:flex;align-items:flex-end;justify-content:flex-start;padding:16px;color:var(--text-muted)}.load-more-btn{width:100%;text-align:center;padding:12px;color:var(--text-muted);font-size:var(--font-size-xs);background:none;cursor:pointer;transition:color .15s ease}.load-more-btn:hover{color:var(--brand)}.typing-indicator{display:flex;align-items:center;gap:8px;padding:4px 16px;min-height:28px;flex-shrink:0}.typing-dots{display:flex;gap:3px;align-items:center}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:typing-bounce 1.4s ease infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.typing-text{font-size:var(--font-size-xs);color:var(--text-secondary);font-style:italic}.file-upload-preview{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0;margin-bottom:4px}.file-preview-item{position:relative;display:flex;flex-direction:column;align-items:flex-start;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;max-width:200px}.file-preview-image{width:200px;height:120px;object-fit:cover}.file-preview-generic{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--bg-accent);color:var(--brand)}.file-preview-info{padding:4px 8px;display:flex;flex-direction:column;width:100%;max-width:200px}.file-preview-name{font-size:var(--font-size-xs);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{font-size:var(--font-size-xs);color:var(--text-muted)}.file-preview-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:var(--brand);color:#fff;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background-color .1s ease,color .1s ease}.file-preview-remove:hover{background:var(--danger);color:#fff}.message-input-wrapper{padding:0 16px 24px;position:relative;flex-shrink:0}.message-input-bar{display:flex;align-items:center;gap:var(--space-3);background:var(--text-sidebar-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-3);transition:border-color .15s ease,box-shadow .15s ease}.message-input-bar:focus-within{border-color:var(--brand);box-shadow:0 2px 0 0 var(--brand)}.message-input-wrapper.dragging .message-input-bar{border:2px dashed var(--brand)}.input-attach-btn{color:var(--text-muted);border-radius:var(--radius-sm);font-size:1px;margin-top:2px;flex-shrink:0;align-self:flex-start;transition:color .15s ease}.input-attach-btn:hover{color:var(--brand)}.input-attach-btn:disabled{opacity:.4;cursor:not-allowed}.message-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.5;resize:none;min-height:24px;max-height:200px;overflow-y:auto}.message-input::placeholder{color:var(--text-muted)}.input-emoji-btn{color:var(--text-muted);border-radius:var(--radius-sm);font-size:1px;flex-shrink:0;align-self:flex-end;margin-bottom:2px;transition:color .15s ease}.input-emoji-btn:hover{color:var(--brand)}.input-send-btn{color:var(--text-muted);border-radius:var(--radius-sm);font-size:1px;margin-bottom:2px;flex-shrink:0;align-self:flex-end;transition:color .15s ease}.input-send-btn:hover:not(:disabled){color:var(--brand)}.input-send-btn:disabled{opacity:.4}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#2182741a;border:2px dashed var(--brand);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:600;color:var(--brand);pointer-events:none}.friend-list{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.friend-list-header{padding:0 16px;border-bottom:1px solid var(--border-color);min-height:48px;display:flex;align-items:center}.friend-tabs{display:flex;gap:4px}.friend-tab{padding:4px 10px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);transition:background-color .1s ease,color .1s ease}.friend-tab:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.friend-tab.active{background:#2182741f;color:var(--brand)}.friend-tab-add{color:var(--success)}.friend-tab-add:hover,.friend-tab-add.active{background:#23a55a1a;color:var(--success)}.pending-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--danger);color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;margin-left:4px}.friend-list-body{flex:1;overflow-y:auto;padding:16px}.friend-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);border-bottom:1px solid var(--border-color);transition:background-color .1s ease}.friend-item:hover{background:var(--bg-modifier-hover)}.friend-avatar-wrapper{position:relative;flex-shrink:0}.friend-avatar-wrapper .status-dot{position:absolute;bottom:-1px;right:-1px}.friend-info{flex:1;display:flex;flex-direction:column}.friend-name{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary)}.friend-discriminator{font-size:var(--font-size-xs);color:var(--text-muted)}.friend-status-text{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:capitalize}.friend-actions{display:flex;gap:8px;align-items:center}.friend-action-btn{padding:6px 14px;font-size:var(--font-size-xs)}.icon-btn-danger:hover{background:var(--danger);color:#fff}.add-friend-section{max-width:600px}.add-friend-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:8px}.add-friend-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:16px}.add-friend-form{display:flex;gap:8px}.add-friend-input{flex:1}.add-success{color:var(--success);font-size:var(--font-size-sm);margin-top:8px}.empty-list{text-align:center;color:var(--text-muted);padding:32px 0}.dm-list{width:var(--sidebar-channel-width);background:var(--bg-secondary);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;border-right:1px solid var(--border-sidebar)}.dm-list-header{padding:12px 8px;border-bottom:1px solid var(--border-sidebar);min-height:48px;display:flex;align-items:center}.dm-friends-btn{width:100%;padding:8px 12px;border-radius:var(--radius-sm);background:none;color:var(--text-sidebar-secondary);font-size:var(--font-size-sm);font-weight:500;text-align:left;transition:background-color .1s ease,color .1s ease}.dm-friends-btn:hover{background:#ffffff0f;color:var(--text-sidebar-primary)}.dm-section-label{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-sidebar-muted);padding:16px 16px 4px}.dm-channels{flex:1;overflow-y:auto;padding:4px 8px}.dm-channel-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .1s ease;border-left:3px solid transparent}.dm-channel-item:hover{background:#ffffff0d}.dm-channel-item.active{border-left:3px solid var(--brand-light);background:#9af3e214}.dm-avatar-wrapper{position:relative;flex-shrink:0}.dm-avatar-wrapper .status-dot{position:absolute;bottom:-1px;right:-1px;border-color:var(--bg-secondary)}.dm-channel-info{display:flex;flex-direction:column;min-width:0}.dm-username{font-size:var(--font-size-sm);font-weight:500;color:var(--text-sidebar-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-discriminator{font-size:var(--font-size-xs);color:var(--text-sidebar-muted)}.dm-channel-item.active .dm-username,.dm-channel-item:hover .dm-username,.dm-channel-item.active .dm-discriminator,.dm-channel-item:hover .dm-discriminator{color:var(--text-sidebar-primary)}.voice-user-tile{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--radius-sm);transition:background-color .1s ease}.voice-user-tile:hover{background:var(--bg-modifier-hover)}.voice-user-tile.speaking{background:#23a55a1a}.voice-avatar-wrapper{position:relative;flex-shrink:0;margin-top:2px}.voice-avatar-wrapper.speaking:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:2px solid var(--success)}.voice-avatar{width:24px;height:24px;background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.voice-user-info-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.voice-user-info{display:flex;align-items:baseline;gap:2px}.voice-username{font-size:var(--font-size-sm);color:var(--text-sidebar-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-discriminator{font-size:10px;color:var(--text-muted)}.voice-stream-row{display:flex;align-items:center;gap:6px}.streaming-badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--brand)}.stream-action-btn{font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px;line-height:1.6;transition:opacity .15s ease}.end-stream-btn{background:var(--danger);color:#fff}.end-stream-btn:hover{opacity:.85}.watch-stream-btn{background:var(--brand);color:#fff}.watch-stream-btn:hover:not(:disabled){opacity:.85}.watch-stream-btn:disabled{opacity:.5;cursor:default}.voice-user-status{display:flex;align-items:center;gap:4px;margin-top:2px;flex-shrink:0}.voice-muted-icon{color:var(--danger)}.speaking-indicator{display:flex;gap:2px;align-items:center}.speaking-indicator span{width:3px;height:3px;border-radius:50%;background:var(--success);animation:speaking-wave .8s ease-in-out infinite}.speaking-indicator span:nth-child(2){animation-delay:.15s}.speaking-indicator span:nth-child(3){animation-delay:.3s}@keyframes speaking-wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(2)}}.voice-controls{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg-tertiary);border-top:1px solid rgba(0,0,0,.2)}.voice-user-panel{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.voice-user-avatar{flex-shrink:0}.voice-user-name{display:flex;flex-direction:column;min-width:0}.voice-ctrl-username{font-size:var(--font-size-sm);font-weight:600;color:var(--text-sidebar-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-ctrl-discriminator{font-size:10px;color:var(--text-sidebar-muted)}.voice-ctrl-buttons{display:flex;gap:2px;flex-shrink:0}.voice-ctrl-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-sidebar-muted);transition:background-color .1s ease,color .1s ease}.voice-ctrl-btn:hover{background:#ffffff1a;color:var(--text-sidebar-primary)}.voice-ctrl-btn.active.danger{color:var(--danger)}.voice-ctrl-btn.active.danger:hover{background:#d6404533}.voice-ctrl-screenshare-active{color:var(--brand-light)}.voice-ctrl-screenshare-active:hover{background:#9af3e226;color:var(--brand-light)}.voice-ctrl-leave{color:var(--danger)}.voice-ctrl-leave:hover{background:var(--danger);color:#fff}.screen-share-modal{background:#fff;border-radius:var(--radius-md);padding:24px;width:420px;max-width:90vw;box-shadow:0 8px 32px #00000080}.screen-share-modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.screen-share-modal-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin:0 0 20px;line-height:1.5}.quality-options{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.quality-option{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.quality-option:hover{background:var(--bg-modifier-hover)}.quality-option.selected{border-color:var(--brand);background:#21827414}.quality-option input[type=radio]{accent-color:var(--brand);width:16px;height:16px;flex-shrink:0}.quality-info{display:flex;flex-direction:column;gap:2px}.quality-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.quality-desc{font-size:var(--font-size-xs);color:var(--text-muted)}.screen-share-modal-actions{display:flex;justify-content:flex-end;gap:8px}.btn-primary{padding:8px 20px;border-radius:var(--radius-sm);background:var(--brand);color:#fff;font-size:var(--font-size-sm);font-weight:600;transition:opacity .15s ease}.btn-primary:hover{opacity:.9}.btn-secondary{padding:8px 20px;border-radius:var(--radius-sm);background:var(--bg-modifier-hover);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600;transition:background-color .15s ease}.btn-secondary:hover{background:var(--bg-modifier-active)}.screen-share-viewer{position:fixed;top:0;left:calc(var(--sidebar-server-width) + var(--sidebar-channel-width));right:0;bottom:0;background:#000;z-index:50;display:flex;flex-direction:column}.screen-share-video-wrap{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.screen-share-video{width:90%;aspect-ratio:16/9;object-fit:contain}.screen-share-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-tertiary);border-top:1px solid var(--border-color);flex-shrink:0}.screen-share-viewer-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.screen-share-viewer-label svg{color:var(--brand)}.screen-share-viewer-actions{display:flex;align-items:center;gap:6px}.screen-share-action-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background-color .15s ease,color .15s ease}.screen-share-action-btn:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.screen-share-close-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-sm);background:var(--danger);color:#fff;font-size:var(--font-size-xs);font-weight:600;transition:opacity .15s ease}.screen-share-close-btn:hover{opacity:.85}.voice-channel-bar{position:fixed;bottom:0;left:0;width:var(--sidebar-channel-width);background:var(--bg-tertiary);border-top:1px solid rgba(0,0,0,.2);z-index:100}.voice-channel-status{padding:8px 12px 4px}.voice-channel-connected{display:flex;align-items:center;gap:6px;margin-bottom:2px}.voice-channel-status-text{font-size:var(--font-size-xs);font-weight:600;color:var(--brand-light)}.voice-channel-name{font-size:var(--font-size-xs);color:var(--text-sidebar-muted)}.voice-participants{display:flex;flex-direction:column;gap:2px;padding:4px 8px;max-height:200px;overflow-y:auto}.settings-modal{max-width:680px;height:740px;max-height:90vh;display:flex;gap:0;padding:0;overflow:hidden}.settings-nav{width:200px;background:var(--bg-secondary);padding:16px 8px;flex-shrink:0;overflow-y:auto;border-right:1px solid var(--border-sidebar)}.settings-nav-title{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-sidebar-muted);padding:4px 8px;margin-bottom:4px}.settings-nav-item{display:block;width:100%;padding:8px 10px;border-radius:var(--radius-sm);text-align:left;color:var(--text-sidebar-secondary);font-size:var(--font-size-sm);transition:background-color .1s ease,color .1s ease;cursor:pointer;border-left:3px solid transparent}.settings-nav-item:hover{background:#ffffff0f;color:var(--text-sidebar-primary)}.settings-nav-item.active{background:#9af3e21f;color:var(--text-sidebar-primary);border-left:3px solid var(--brand-light);padding-left:7px}.settings-nav-divider{height:1px;background:var(--border-sidebar);margin:8px 4px}.settings-logout{color:var(--danger)}.settings-logout:hover{background:#d6404526;color:var(--danger)}.settings-content{flex:1;min-height:0;padding:24px;overflow-y:auto;background:var(--bg-primary);color:var(--text-primary)}.add-success{color:var(--success);font-size:var(--font-size-sm)}.usertag-display{padding:10px 12px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-md);color:var(--text-primary);font-weight:600;-webkit-user-select:all;user-select:all}.usertag-discriminator{color:var(--text-muted);font-weight:400}.usertag-hint{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:6px}.description-textarea{resize:none;height:calc(6 * 1.4em + 20px);font-family:inherit;line-height:1.4;overflow-y:auto}.description-textarea::-webkit-scrollbar{width:4px}.description-textarea::-webkit-scrollbar-thumb{background:#9af3e24d}.description-textarea::-webkit-scrollbar-track{background:transparent}.form-label{display:flex;justify-content:space-between;align-items:baseline}.description-counter{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:400}.threshold-row{display:flex;align-items:center;gap:12px}.threshold-slider{flex:1;accent-color:var(--brand);cursor:pointer}.threshold-value{min-width:36px;text-align:right;font-size:var(--font-size-sm);color:var(--text-secondary)}.ctx-menu{position:fixed;z-index:calc(var(--z-modal) + 10);background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-high);padding:0;min-width:200px;outline:none;animation:ctx-menu-in .08s ease}@keyframes ctx-menu-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.ctx-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:7px var(--space-3);font-size:var(--font-size-xs);font-weight:500;color:var(--text-primary);background:none;border:none;text-align:left;cursor:pointer;border-radius:0;transition:background-color .1s ease,color .1s ease;outline:none}.ctx-menu-item:hover,.ctx-menu-item:focus{background:var(--brand);color:#fff}.ctx-menu-item--danger:hover,.ctx-menu-item--danger:focus{background:var(--danger);color:#fff}.ctx-menu-item--disabled{color:var(--text-muted);cursor:default;pointer-events:none}.ctx-menu-item--submenu{justify-content:space-between;position:relative;cursor:default}.ctx-menu-item--submenu:hover,.ctx-menu-item--submenu:focus,.ctx-menu-item--submenu-open{background:var(--brand);color:#fff}.ctx-submenu-arrow{flex-shrink:0;opacity:.7}.ctx-menu-divider{height:1px;background:var(--border-color);margin:0}.ctx-submenu{position:absolute;left:100%;top:0;background:#fff;border:1px solid var(--border-color);box-shadow:var(--shadow-high);padding:0;min-width:200px;max-height:320px;overflow-y:auto;z-index:1;animation:ctx-menu-in .08s ease}.ctx-submenu--left{left:auto;right:100%}.ctx-submenu--bottom{top:auto;bottom:0}.ctx-submenu-server{gap:var(--space-2)}.ctx-submenu-server-icon{width:24px;height:24px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.ctx-submenu-server-icon--placeholder{width:24px;height:24px;border-radius:var(--radius-sm);background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.ctx-submenu-server-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ctx-status-item{justify-content:flex-start;gap:var(--space-2)}.ctx-status-check{margin-left:auto;flex-shrink:0;opacity:.8}.ctx-server-info{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0}.ctx-server-info-icon{width:64px;height:64px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.ctx-server-info-icon--placeholder{width:64px;height:64px;border-radius:var(--radius-md);background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:700;color:#fff;flex-shrink:0}.ctx-server-info-meta{display:flex;flex-direction:column;gap:var(--space-1)}.ctx-server-info-label{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.ctx-server-info-value{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg-primary);border-top:3px solid var(--brand)}.app-body{flex:1;display:flex;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);border-left:1px solid var(--border-color)}.message-area{display:flex;flex-direction:column;height:100%;overflow:hidden}.empty-channel{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--font-size-lg);position:relative}.empty-channel:before{content:"#";position:absolute;font-size:140px;font-weight:700;opacity:.04;color:var(--brand);pointer-events:none;line-height:1}.invite-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.invite-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:32px;width:100%;max-width:440px;box-shadow:var(--shadow-high);text-align:center}.invite-header{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:24px}.invite-server{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-accent);border-radius:var(--radius-md);margin-bottom:24px;text-align:left}.invite-icon{width:56px;height:56px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.invite-icon-placeholder{width:56px;height:56px;border-radius:var(--radius-md);background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.invite-server-name{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary)}.invite-member-count{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:4px}.invite-join{width:100%;padding:14px}.invite-error{color:var(--danger);margin-bottom:16px}.invite-loading{color:var(--text-muted)}:root{--bg-primary: #F4FEFA;--bg-secondary: #3F4946;--bg-tertiary: #00685C;--bg-accent: #E8F5F0;--bg-hover: #DCF0E9;--bg-selected: #C8E8DC;--bg-modifier-hover: rgba(0, 102, 92, .15);--bg-modifier-active: #218274;--text-primary: #1A2B27;--text-secondary: #2E4A43;--text-muted: #6B8C84;--text-link: #006B5E;--text-sidebar-primary: #E8F5F0;--text-sidebar-secondary: #A6FEED;--text-sidebar-muted: #6B9E95;--brand: #218274;--brand-rgb: 33, 130, 116;--brand-hover: #006B5E;--brand-active: #00685C;--brand-light: #9AF3E2;--brand-light-rgb: 154, 243, 226;--danger: #D64045;--danger-hover: #B03337;--success: #218274;--warning: #C4873A;--online: #218274;--idle: #C4873A;--dnd: #D64045;--offline: #8AADA7;--border-color: rgba(0, 102, 92, .3);--border-sidebar: rgba(0, 0, 0, .18);--border-accent: #9AF3E2;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--radius-sm: 0px;--radius-md: 2px;--radius-lg: 2px;--radius-round: 50%;--sidebar-server-width: 72px;--sidebar-channel-width: 240px;--sidebar-member-width: 240px;--font-sans: "DM Sans", "Jost", "Noto Sans", "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, "Courier New", Courier, monospace;--font-size-xs: 11px;--font-size-sm: 14px;--font-size-md: 15px;--font-size-lg: 18px;--font-size-xl: 22px;--shadow-low: 0 1px 3px rgba(0, 102, 92, .12);--shadow-mid: 0 4px 16px rgba(0, 102, 92, .15);--shadow-high: 0 8px 32px rgba(0, 102, 92, .2);--shadow-sidebar: 2px 0 8px rgba(0, 0, 0, .25);--z-modal: 1000;--z-dropdown: 500;--z-tooltip: 200}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--text-primary);background-color:var(--bg-primary);line-height:1.4;-webkit-font-smoothing:antialiased}#root{height:100%;display:flex;flex-direction:column}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:inherit}img{max-width:100%;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#9af3e24d}::-webkit-scrollbar-thumb:hover{background-color:#9af3e28c}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary);font-size:var(--font-size-lg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.avatar{object-fit:cover}.avatar-placeholder{background:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;text-transform:uppercase;flex-shrink:0}.status-dot{width:12px;height:12px;border:2px solid var(--bg-primary);flex-shrink:0}.status-dot.online{background:var(--online)}.status-dot.idle{background:var(--idle)}.status-dot.dnd{background:var(--dnd)}.status-dot.offline{background:var(--offline)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;border:1px solid transparent;transition:background-color .15s ease,opacity .15s ease;cursor:pointer}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--brand)}.btn-ghost:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.form-label{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary)}.form-input{padding:10px 12px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-md);outline:none;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.form-input:focus{border-color:var(--brand);box-shadow:0 2px 0 0 var(--brand)}.form-input::placeholder{color:var(--text-muted)}.form-error{color:var(--danger);font-size:var(--font-size-xs);margin-top:var(--space-1)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a2b27a6;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.modal{background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-color);padding:var(--space-6);width:100%;max-width:740px;box-shadow:var(--shadow-high)}.modal-header{margin-bottom:var(--space-4)}.modal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.modal-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5)}.divider{height:1px;background:var(--border-color);margin:var(--space-4) 0}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background-color .15s ease,color .15s ease}.icon-btn:hover{background:var(--bg-modifier-hover);color:var(--text-primary)}.section-header{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-sidebar-muted);padding:12px var(--space-4) var(--space-2);display:flex;align-items:center;justify-content:space-between}.section-header:hover{color:var(--text-sidebar-secondary)}.channel-row{display:flex;align-items:center;gap:var(--space-2);padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-sidebar-muted);transition:background-color .1s ease,color .1s ease;margin:1px 0;border-left:3px solid transparent}.channel-row:hover{background:#ffffff0d;color:var(--text-sidebar-primary)}.channel-row.active:not(.voice-channel-row){border-left:3px solid var(--brand-light);background:#9af3e214;color:var(--text-sidebar-primary);padding-left:9px}
