@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;600&display=swap";.auth-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-void);position:relative;overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at 30% 20%,rgba(88,101,242,.04) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(88,101,242,.03) 0%,transparent 60%)}.auth-blob{display:none}.auth-card{background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-xl);padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:fadeIn .2s ease}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600;color:var(--white);letter-spacing:1.5px;text-transform:uppercase}.auth-logo-icon{width:32px;height:32px;border-radius:var(--radius-lg);object-fit:cover}.auth-title{font-size:22px;font-weight:600;color:var(--white);margin-bottom:6px}.auth-subtitle{font-size:13px;color:var(--gray-3);margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:11px;font-weight:600;color:var(--gray-4);text-transform:uppercase;letter-spacing:.8px}.auth-field input{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:11px 14px;font-size:14px;color:var(--white);transition:border-color .2s}.auth-field input::placeholder{color:var(--gray-2)}.auth-field input:focus{border-color:var(--accent)}.auth-error{background:var(--danger-dim);border:1px solid rgba(237,66,69,.25);border-radius:var(--radius-md);padding:10px 14px;font-size:13px;color:#f28b8d}.auth-btn{background:var(--accent);color:#fff;font-size:14px;font-weight:600;padding:12px;border-radius:var(--radius-md);border:none;transition:all .15s;margin-top:4px}.auth-btn:hover:not(:disabled){background:#4752c4}.auth-btn:disabled{opacity:.4;cursor:not-allowed}.auth-switch{margin-top:20px;font-size:13px;color:var(--gray-3);text-align:center}.auth-switch-btn{background:none;color:var(--accent);font-size:13px;font-weight:500;transition:color .15s}.auth-switch-btn:hover{color:#7289da;text-decoration:underline}.warning-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.warning-modal{background:#141414;border:1px solid rgba(230,126,34,.3);border-radius:12px;padding:28px 24px;width:340px;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.warning-icon{font-size:36px}.warning-modal h3{font-family:Space Mono,monospace;font-size:13px;font-weight:700;color:#e67e22;text-transform:uppercase;letter-spacing:1px}.warning-modal p{font-size:13px;color:#aaa;line-height:1.5;font-family:Inter,sans-serif}.tos-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tos-modal{background:#141414;border:1px solid #2a2a2a;border-radius:12px;width:520px;max-height:80vh;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;display:flex;flex-direction:column;overflow:hidden}.tos-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #1e1e1e;flex-shrink:0}.tos-header h2{font-family:Space Mono,monospace;font-size:13px;font-weight:700;color:#e8e8e8;text-transform:uppercase;letter-spacing:1.5px}.tos-close{background:none;color:#666;font-size:14px;cursor:pointer;transition:color .15s}.tos-close:hover{color:#e8e8e8}.tos-body{overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px}.tos-intro{font-size:13px;color:#888;line-height:1.6;font-family:Inter,sans-serif}.tos-section{display:flex;flex-direction:column;gap:8px}.tos-section h3{font-family:Space Mono,monospace;font-size:12px;font-weight:700;color:#e8e8e8;text-transform:uppercase;letter-spacing:1px}.tos-section p{font-size:13px;color:#888;line-height:1.6;font-family:Inter,sans-serif}.tos-section ul{list-style:none;display:flex;flex-direction:column;gap:6px;padding-left:8px}.tos-section ul li{font-size:13px;color:#aaa;font-family:Inter,sans-serif;line-height:1.5;padding-left:12px;position:relative}.tos-section ul li:before{content:"—";position:absolute;left:-4px;color:#444}.tos-footer{font-size:11px;color:#444;font-family:Space Mono,monospace;text-align:center;padding-top:10px;border-top:1px solid #1e1e1e}.tos-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #1e1e1e;flex-shrink:0;background:#141414}.channel-sidebar{display:flex;flex-direction:column;height:100%;overflow:hidden}.channel-header{padding:16px 14px 12px;border-bottom:var(--border)}.channel-server-name{font-size:14px;font-weight:600;color:var(--white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-list{flex:1;overflow-y:auto;padding:8px 6px}.channel-empty-state{padding:20px 10px;text-align:center;color:var(--gray-2);font-size:12px}.channel-section-label{display:flex;align-items:center;justify-content:space-between;padding:12px 8px 4px;font-size:11px;font-weight:600;color:var(--gray-2);text-transform:uppercase;letter-spacing:.8px}.channel-add-btn{background:none;color:var(--gray-2);font-size:16px;padding:0 4px;border-radius:var(--radius-sm);transition:color .15s;line-height:1}.channel-add-btn:hover{color:var(--gray-5)}.channel-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border-radius:var(--radius-md);background:transparent;color:var(--gray-3);font-size:13px;font-weight:400;transition:all .1s;text-align:left}.channel-item:hover{background:var(--bg-hover);color:var(--gray-5)}.channel-item.active{background:var(--bg-active);color:var(--white)}.channel-hash{font-size:16px;color:var(--gray-2);line-height:1}.channel-item.active .channel-hash{color:var(--gray-4)}.channel-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-create-form{padding:8px 6px}.channel-create-form input{width:100%;background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:8px 10px;font-size:13px;color:var(--white);margin-bottom:6px}.channel-create-form input:focus{border-color:var(--accent)}.channel-create-form input::placeholder{color:var(--gray-2)}.channel-create-actions{display:flex;gap:6px;justify-content:flex-end}.user-panel{display:none}.channel-copy-id{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);color:var(--gray-3);font-size:11px;font-family:JetBrains Mono,monospace;padding:5px 8px;cursor:pointer;transition:all .15s;margin-top:6px;width:100%;text-align:center}.channel-copy-id:hover{background:var(--bg-active);color:var(--white)}.channel-delete-server{background:var(--danger-dim);border:1px solid rgba(237,66,69,.2);border-radius:var(--radius-md);color:var(--danger);font-size:12px;padding:5px 8px;cursor:pointer;transition:all .15s;margin-top:4px;width:100%}.channel-delete-server:hover{background:#ed424533}.channel-item-wrapper{display:flex;align-items:center;border-radius:var(--radius-md)}.channel-item-wrapper .channel-item{flex:1}.channel-delete-btn{background:none;color:transparent;font-size:11px;padding:4px 6px;border-radius:var(--radius-sm);transition:all .15s;flex-shrink:0}.channel-item-wrapper:hover .channel-delete-btn{color:var(--gray-2)}.channel-delete-btn:hover{color:var(--danger)!important}.channel-rename-server{background:#5865f21a;border:1px solid rgba(88,101,242,.2);border-radius:var(--radius-md);color:var(--accent);font-size:12px;padding:5px 8px;cursor:pointer;transition:all .15s;margin-top:4px;width:100%}.channel-rename-server:hover{background:#5865f233}.channel-leave-server{background:#f0b1321a;border:1px solid rgba(240,177,50,.2);border-radius:var(--radius-md);color:var(--warning);font-size:12px;padding:5px 8px;cursor:pointer;transition:all .15s;margin-top:4px;width:100%}.channel-leave-server:hover{background:#f0b13233}.channel-rename-form{display:flex;flex-direction:column;gap:8px;margin-top:8px}.channel-rename-form input{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:8px 10px;font-size:13px;color:var(--white)}.channel-rename-form input:focus{border-color:var(--accent)}.channel-invite-btn{background:none;border:none;color:var(--gray-3);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);transition:all .15s}.channel-invite-btn:hover{color:var(--white);background:var(--bg-hover)}.invite-box{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-lg);padding:10px;margin-top:8px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal{background:#141414;border:1px solid #2a2a2a;border-radius:12px;padding:24px;width:320px;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;display:flex;flex-direction:column;gap:20px}.confirm-message{font-size:14px;color:#e8e8e8;line-height:1.5;font-family:Inter,sans-serif}.confirm-actions{display:flex;gap:8px;justify-content:flex-end}.confirm-delete-btn{background:#c0392b26;border:1px solid rgba(192,57,43,.3);border-radius:6px;color:#e74c3c;font-size:13px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif}.confirm-delete-btn:hover{background:#c0392b;color:#fff;border-color:#c0392b}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-modal{background:#141414;border:1px solid #2a2a2a;border-radius:12px;width:320px;min-height:200px;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;position:relative}.profile-banner{height:80px;width:100%;border-radius:12px 12px 0 0;opacity:.5}.profile-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:#fff;border:4px solid #141414;position:absolute;top:44px;left:20px}.profile-body{padding:52px 20px 20px;display:flex;flex-direction:column;gap:12px}.profile-username{font-family:Space Mono,monospace;font-size:18px;font-weight:700;color:#e8e8e8}.profile-bio-section{background:#1a1a1a;border:1px solid #1e1e1e;border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.profile-bio-label{font-family:Space Mono,monospace;font-size:10px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:1px}.profile-bio{font-size:13px;color:#aaa;line-height:1.5}.profile-no-bio{font-size:12px;color:#666;font-style:italic}.profile-joined{font-size:11px;color:#666;font-family:Space Mono,monospace}.profile-loading{padding:40px;text-align:center;color:#666;font-size:12px;font-family:Space Mono,monospace}.profile-close{position:absolute;top:10px;right:10px;background:#00000080;color:#fff;width:26px;height:26px;border-radius:9999px;font-size:11px;display:flex;align-items:center;justify-content:center;transition:all .15s;z-index:1;border:none;cursor:pointer}.profile-close:hover{background:#000c}.profile-admin-section{background:#c0392b14;border:1px solid rgba(192,57,43,.2);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.profile-admin-section input{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:8px 10px;font-size:13px;color:#e8e8e8;width:100%;font-family:Inter,sans-serif}.profile-reset-msg{font-size:11px;color:#27ae60;font-family:Space Mono,monospace;text-align:center}.profile-top-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.add-friend-btn{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;color:#ccc;font-size:12px;font-weight:600;padding:6px 12px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;white-space:nowrap}.add-friend-btn:hover:not(.disabled){background:#272727;border-color:#444;color:#e8e8e8}.add-friend-btn.disabled{opacity:.5;cursor:not-allowed}.profile-friend-msg{font-size:11px;color:#27ae60;font-family:Space Mono,monospace}.admin-warn-btn{background:#e67e221a;border:1px solid rgba(230,126,34,.3);border-radius:6px;color:#e67e22;font-size:13px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;width:100%}.admin-warn-btn:hover{background:#e67e22;color:#fff}.admin-ban-btn{background:#c0392b1a;border:1px solid rgba(192,57,43,.3);border-radius:6px;color:#e74c3c;font-size:13px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;width:100%}.admin-ban-btn:hover{background:#c0392b;color:#fff}.admin-unban-btn{background:#27ae601a;border:1px solid rgba(39,174,96,.3);border-radius:6px;color:#27ae60;font-size:13px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif}.admin-unban-btn:hover{background:#27ae60;color:#fff}.friends-sidebar{display:flex;flex-direction:column;height:100%;overflow:hidden}.friends-header{display:flex;align-items:center;justify-content:space-between;padding:16px 14px 12px;border-bottom:var(--border);font-size:13px;font-weight:600;color:var(--gray-4);text-transform:uppercase;letter-spacing:.8px}.friends-add-btn{background:none;color:var(--gray-3);font-size:20px;line-height:1;padding:0 4px;transition:color .15s;border-radius:var(--radius-sm)}.friends-add-btn:hover{color:var(--white)}.friends-add-form{padding:10px;border-bottom:var(--border);display:flex;flex-direction:column;gap:6px}.friends-add-form input{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:8px 10px;font-size:13px;color:var(--white);transition:border-color .2s}.friends-add-form input:focus{border-color:var(--accent)}.friends-add-form input::placeholder{color:var(--gray-2)}.friends-add-form button{background:var(--accent);color:#fff;font-size:13px;font-weight:600;padding:8px;border-radius:var(--radius-md);border:none;transition:all .15s}.friends-add-form button:hover{background:#4752c4}.friends-msg{font-size:12px;color:var(--gray-4);text-align:center}.friends-tabs{display:flex;padding:8px 8px 4px;gap:2px}.friends-tabs button{flex:1;background:none;color:var(--gray-3);font-size:12px;font-weight:500;padding:6px 8px;border-radius:var(--radius-md);border:none;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px}.friends-tabs button:hover{background:var(--bg-hover);color:var(--gray-5)}.friends-tabs button.active{background:var(--bg-active);color:var(--white)}.badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:var(--radius-full);min-width:16px;text-align:center}.friends-list{flex:1;overflow-y:auto;padding:6px}.friends-empty{font-size:12px;color:var(--gray-2);text-align:center;padding:24px 10px;line-height:1.7}.friend-item{display:flex;align-items:center;border-radius:var(--radius-md);transition:all .1s}.friend-item:hover{background:var(--bg-hover)}.friend-item.active{background:var(--bg-active)}.friend-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--white);flex-shrink:0;overflow:hidden}.request-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);color:var(--gray-3);font-size:13px;transition:background .1s}.request-item:hover{background:var(--bg-hover)}.request-actions{display:flex;gap:6px;margin-left:auto}.accept-btn{background:#23a55a1f;color:var(--success);width:26px;height:26px;border-radius:var(--radius-md);font-size:12px;border:1px solid rgba(35,165,90,.2);display:flex;align-items:center;justify-content:center;transition:all .15s}.accept-btn:hover{background:var(--success);color:#fff}.decline-btn{background:var(--danger-dim);color:var(--danger);width:26px;height:26px;border-radius:var(--radius-md);font-size:12px;border:1px solid rgba(237,66,69,.2);display:flex;align-items:center;justify-content:center;transition:all .15s}.decline-btn:hover{background:var(--danger);color:#fff}.friend-avatar-wrapper{position:relative;flex-shrink:0}.friend-item-main{display:flex;align-items:center;gap:10px;flex:1;padding:8px 10px;background:transparent;color:var(--gray-3);font-size:13px;text-align:left;transition:color .1s;border-radius:var(--radius-md)}.friend-item:hover .friend-item-main{color:var(--gray-5)}.friend-item.active .friend-item-main{color:var(--white)}.view-profile-btn{background:none;color:transparent;font-size:12px;padding:4px 6px;border-radius:var(--radius-sm);transition:all .15s}.friend-item:hover .view-profile-btn{color:var(--gray-2)}.view-profile-btn:hover{color:var(--gray-5)!important}.unfriend-btn{background:none;color:transparent;font-size:11px;padding:4px 8px;border-radius:var(--radius-sm);transition:all .15s}.friend-item:hover .unfriend-btn{color:var(--gray-2)}.unfriend-btn:hover{color:var(--danger)!important}.chat-area{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-base);overflow:hidden;height:100%;position:relative}.chat-header{display:flex;align-items:center;gap:10px;padding:0 18px;height:48px;border-bottom:var(--border);flex-shrink:0;background:var(--bg-deep)}.chat-header-hash{font-size:18px;color:var(--gray-2);line-height:1}.chat-header-name{font-size:14px;font-weight:600;color:var(--white)}.chat-messages{flex:1;overflow-y:scroll;padding:16px 18px 8px;min-height:0}.chat-loading{color:var(--gray-2);font-size:12px;text-align:center;padding:20px;animation:pulse 1.5s infinite}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--gray-2)}.chat-empty-icon{width:56px;height:56px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:24px}.chat-empty h2{font-size:16px;color:var(--gray-4);font-weight:600}.chat-empty p{font-size:13px;color:var(--gray-2)}.chat-start{display:flex;flex-direction:column;gap:6px;padding:20px 0 16px}.chat-start-icon{width:48px;height:48px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:6px}.chat-start h3{font-size:18px;font-weight:700;color:var(--white)}.chat-start p{font-size:13px;color:var(--gray-3)}.msg-group{display:flex;gap:12px;padding:4px 8px;border-radius:var(--radius-md);transition:background .1s}.msg-group:hover{background:var(--bg-raised)}.msg-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--white);margin-top:2px;overflow:hidden}.msg-content{flex:1;min-width:0}.msg-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:3px}.msg-author{font-size:14px;font-weight:600;color:var(--white)}.msg-time{font-size:11px;color:var(--gray-2)}.msg-text{font-size:14px;color:var(--gray-4);line-height:1.6;word-break:break-word;white-space:pre-wrap}.msg-date-divider{display:flex;align-items:center;gap:12px;margin:12px 0}.msg-date-line{flex:1;height:1px;background:var(--bg-float)}.msg-date-label{font-size:11px;font-weight:600;color:var(--gray-2);white-space:nowrap;letter-spacing:.3px}.typing-indicator{display:flex;align-items:center;gap:8px;padding:4px 8px;height:26px}.typing-dots{display:flex;gap:3px;align-items:center}.typing-dots span{width:4px;height:4px;border-radius:50%;background:var(--gray-3);animation:pulse 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.typing-text{font-size:12px;color:var(--gray-3);font-style:italic}.chat-input-wrapper{padding:0 16px 16px;flex-shrink:0}.chat-input-form{display:flex;align-items:flex-end;gap:8px;background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-lg);padding:10px 12px;transition:border-color .2s}.chat-input-form:focus-within{border-color:var(--gray-1)}.chat-input{flex:1;background:transparent;color:var(--white);font-size:14px;line-height:1.5;resize:none;max-height:160px;overflow-y:auto}.chat-input::placeholder{color:var(--gray-2)}.chat-send-btn{background:var(--accent);color:#fff;width:32px;height:32px;border-radius:var(--radius-md);border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;opacity:.85}.chat-send-btn:hover:not(:disabled){opacity:1;background:#4752c4}.chat-send-btn:disabled{opacity:.3}.chat-messages-inner{display:flex;flex-direction:column;gap:1px;flex:1}.msg-text-wrapper{display:flex;align-items:center;gap:6px;position:relative}.msg-delete-btn{background:none;color:transparent;font-size:11px;padding:2px 6px;border-radius:var(--radius-sm);transition:all .15s;flex-shrink:0}.msg-group:hover .msg-delete-btn{color:var(--gray-2)}.msg-delete-btn:hover{color:var(--danger)!important}.mention-picker{position:absolute;bottom:100%;left:16px;right:16px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);z-index:100}.mention-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;color:var(--gray-3);font-size:13px;transition:background .1s;cursor:pointer;text-align:left}.mention-item:hover{background:var(--bg-hover);color:var(--white)}.mention-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--white);flex-shrink:0}.mention-highlight{color:var(--accent);background:var(--accent-dim);border-radius:var(--radius-sm);padding:0 3px;font-weight:600}.emoji-picker-wrapper{position:absolute;bottom:60px;right:16px;z-index:9999;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.emoji-btn{background:none;color:var(--gray-3);font-size:18px;padding:2px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;flex-shrink:0}.emoji-btn:hover{color:var(--white)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;width:280px;max-height:200px;overflow-y:auto}.emoji-grid-btn{background:none;font-size:20px;padding:4px;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s;line-height:1}.emoji-grid-btn:hover{background:var(--bg-hover)}.msg-image{max-width:320px;max-height:320px;border-radius:var(--radius-lg);margin-top:6px;cursor:pointer;object-fit:cover}.image-upload-btn{background:none;color:var(--gray-3);font-size:18px;padding:2px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;flex-shrink:0}.image-upload-btn:hover{color:var(--white)}.msg-link{color:var(--accent);text-decoration:underline;word-break:break-all}.msg-link:hover{color:#7289da}.msg-actions{display:none;align-items:center;gap:3px;position:absolute;right:8px;top:0}.msg-text-wrapper:hover .msg-actions{display:flex}.msg-react-btn,.msg-edit-btn,.msg-reply-btn,.msg-delete-btn{background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-md);font-size:13px;padding:3px 7px;cursor:pointer;color:var(--gray-3);transition:all .15s}.msg-react-btn:hover,.msg-edit-btn:hover,.msg-reply-btn:hover{background:var(--bg-active);color:var(--white)}.reaction-picker{display:flex;gap:4px;padding:6px 8px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-lg);flex-wrap:wrap;max-width:220px;position:absolute;bottom:calc(100% + 4px);right:0;z-index:100;box-shadow:var(--shadow-md)}.reaction-picker-btn{background:none;font-size:18px;padding:3px 5px;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s}.reaction-picker-btn:hover{background:var(--bg-hover)}.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-btn{background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-full);padding:2px 8px;font-size:13px;cursor:pointer;color:var(--gray-4);transition:all .15s;display:flex;align-items:center;gap:4px}.reaction-btn:hover{background:var(--bg-active);color:var(--white)}.reaction-btn.reacted{background:var(--accent-dim);border-color:var(--accent);color:var(--white)}.unread-badge{width:8px;height:8px;background:var(--danger);border-radius:50%;display:inline-block;margin-left:4px;flex-shrink:0}.msg-edit-wrapper{display:flex;flex-direction:column;gap:6px;padding:4px 0}.msg-edit-input{background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);color:var(--white);padding:8px 10px;font-size:14px;resize:none;width:100%;font-family:inherit}.msg-edit-input:focus{border-color:var(--accent)}.msg-edit-actions{display:flex;gap:6px;justify-content:flex-end}.msg-edited{font-size:11px;color:var(--gray-2);margin-left:4px}.msg-reply-preview{display:flex;align-items:center;gap:6px;padding:3px 8px;margin-bottom:3px;border-left:2px solid var(--accent);background:var(--accent-glow);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:12px;color:var(--gray-3);max-width:500px}.msg-reply-author{color:var(--accent);font-weight:600;white-space:nowrap}.msg-reply-content{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;background:var(--accent-glow);border-top:var(--border);font-size:13px;color:var(--gray-3)}.reply-bar strong{color:var(--accent)}.reply-bar button{background:none;border:none;color:var(--gray-3);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:var(--radius-sm);transition:all .15s}.reply-bar button:hover{color:var(--white);background:var(--bg-hover)}.avatar-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.avatar-picker{background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-lg);padding:24px;width:320px;box-shadow:var(--shadow-lg);animation:fadeIn .15s ease}.avatar-picker h3{font-family:Space Mono,monospace;font-size:12px;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:20px}.avatar-preview{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding:14px;background:var(--bg-float);border-radius:var(--radius-md);border:var(--border)}.avatar-preview-circle{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--white);flex-shrink:0;transition:background .2s}.avatar-preview span{font-size:14px;font-weight:600;color:var(--white);font-family:Space Mono,monospace}.avatar-colors{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:20px}.color-swatch{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid transparent;transition:all .15s;cursor:pointer}.color-swatch:hover{transform:scale(1.1);border-color:var(--gray-3)}.color-swatch.active{border-color:var(--white);transform:scale(1.1);box-shadow:0 0 0 2px #fff3}.avatar-actions{display:flex;gap:8px;justify-content:flex-end}.avatar-section-label{font-family:Space Mono,monospace;font-size:10px;font-weight:700;color:var(--gray-2);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;margin-top:4px}.avatar-bio-input{width:100%;background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:10px 12px;font-size:13px;color:var(--white);font-family:Inter,sans-serif;resize:none;transition:border-color .2s}.avatar-bio-input:focus{border-color:var(--gray-2)}.avatar-bio-input::placeholder{color:var(--gray-2)}.avatar-char-count{font-size:10px;color:var(--gray-2);text-align:right;font-family:Space Mono,monospace;margin-top:4px}.avatar-msg{font-size:12px;color:#27ae60;font-family:Space Mono,monospace;text-align:center}.app-layout{display:grid;grid-template-rows:1fr;grid-template-columns:72px 240px 1fr 220px;height:100vh;width:100vw;overflow:hidden}.server-rail-panel{grid-column:1;grid-row:1;background:var(--bg-void);border-right:var(--border);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:6px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.server-rail-panel::-webkit-scrollbar{display:none}.server-rail-top{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;width:100%}.rail-bottom{display:flex;flex-direction:column;align-items:center;gap:6px;border-top:var(--border);width:100%;padding:8px 0 0}.rail-user{cursor:pointer;border-radius:50%;transition:all .15s}.rail-user:hover{opacity:.85}.rail-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--white);overflow:hidden;margin:0 auto}.left-panel{grid-column:2;grid-row:1;background:var(--bg-deep);border-right:var(--border);display:flex;flex-direction:column;overflow:hidden}.main-panel{grid-column:3;grid-row:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base)}.right-panel{grid-column:4;grid-row:1;overflow:hidden}.server-unread-dot{position:absolute;bottom:2px;right:2px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-void)}.server-icon.server-danger{color:var(--gray-3);background:transparent}.server-icon.server-danger:hover{background:var(--danger-dim);color:var(--danger);border-color:transparent}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-xl);padding:24px;width:380px;box-shadow:var(--shadow-lg);animation:fadeIn .15s ease}.modal h3{font-size:15px;font-weight:600;color:var(--white);margin-bottom:18px}.modal input{width:100%;background:var(--bg-float);border:var(--border-bright);border-radius:var(--radius-md);padding:10px 12px;font-size:14px;color:var(--white);margin-bottom:16px;transition:border-color .2s}.modal input:focus{border-color:var(--accent)}.modal input::placeholder{color:var(--gray-2)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.btn-ghost{background:transparent;color:var(--gray-4);font-size:13px;font-weight:500;padding:8px 16px;border-radius:var(--radius-md);border:none;transition:all .15s}.btn-ghost:hover{background:var(--bg-hover);color:var(--white)}.btn-primary{background:var(--accent);color:#fff;font-size:13px;font-weight:600;padding:8px 18px;border-radius:var(--radius-md);border:none;transition:all .15s}.btn-primary:hover{filter:brightness(1.1)}.top-bar-settings{background:none;color:var(--gray-3);font-size:16px;padding:5px 8px;border-radius:var(--radius-md);transition:all .15s}.top-bar-settings:hover{color:var(--white);background:var(--bg-hover)}.home-page{flex:1;display:flex;flex-direction:column;padding:40px 48px;background:var(--bg-base);overflow-y:auto;gap:40px}.home-greeting{display:flex;align-items:center;gap:20px;padding-bottom:32px;border-bottom:var(--border)}.home-avatar{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--white);flex-shrink:0}.home-greeting-text h1{font-family:Space Mono,monospace;font-size:22px;font-weight:700;color:var(--white);letter-spacing:-.5px}.home-greeting-text h1 span{color:var(--gray-4)}.home-greeting-text p{font-size:13px;color:var(--gray-2);margin-top:4px}.home-section{display:flex;flex-direction:column;gap:14px}.home-section-label{font-family:Space Mono,monospace;font-size:10px;font-weight:700;color:var(--gray-2);text-transform:uppercase;letter-spacing:1.5px}.home-empty{font-size:13px;color:var(--gray-2);padding:20px 0;font-family:Space Mono,monospace}.home-friends-grid{display:flex;flex-wrap:wrap;gap:10px}.home-friend-card{display:flex;align-items:center;gap:10px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-md);padding:12px 16px;cursor:pointer;transition:all .15s;color:var(--gray-3);font-size:13px;font-weight:500}.home-friend-card:hover{background:var(--bg-float);border-color:var(--gray-1);color:var(--white);transform:translateY(-1px)}.home-friend-avatar{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--white)}.home-contact-btn{display:flex;align-items:center;gap:10px;background:var(--bg-raised);border:var(--border-bright);border-radius:var(--radius-md);padding:12px 16px;cursor:pointer;transition:all .15s;color:var(--gray-3);font-size:13px;font-weight:500;font-family:Inter,sans-serif}.home-contact-btn:hover{background:var(--bg-float);border-color:var(--gray-1);color:var(--white);transform:translateY(-1px)}.members-sidebar{width:220px;min-width:220px;background:var(--bg-deep);border-left:var(--border);display:flex;flex-direction:column;overflow:hidden;height:100%}.members-header{padding:16px 14px 12px;border-bottom:var(--border);font-size:13px;font-weight:600;color:var(--gray-4);text-transform:uppercase;letter-spacing:.8px}.members-list{flex:1;overflow-y:auto;padding:8px 6px}.members-section-label{font-size:11px;font-weight:600;color:var(--gray-2);text-transform:uppercase;letter-spacing:.8px;padding:12px 8px 4px}.member-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 8px;border-radius:var(--radius-md);background:transparent;color:var(--gray-3);font-size:13px;transition:all .1s;text-align:left}.member-item:hover{background:var(--bg-hover);color:var(--gray-5)}.member-item.offline{opacity:.45}.member-item.offline:hover{opacity:.75}.member-avatar-wrapper{position:relative;flex-shrink:0}.member-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--white);overflow:hidden}.member-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.status-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-deep)}.member-kick-btn{background:none;border:none;cursor:pointer;font-size:13px;padding:2px 4px;border-radius:var(--radius-sm);opacity:0;transition:opacity .15s;color:var(--gray-3)}.member-item:hover .member-kick-btn{opacity:1}.member-kick-btn:hover{background:var(--danger-dim);color:var(--danger)}.browser-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.browser-modal{background:#141414;border:1px solid #2a2a2a;border-radius:12px;width:480px;max-height:70vh;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;display:flex;flex-direction:column;overflow:hidden}.browser-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #1e1e1e}.browser-header h3{font-family:Space Mono,monospace;font-size:12px;font-weight:700;color:#e8e8e8;text-transform:uppercase;letter-spacing:1.5px}.browser-close{background:none;color:#666;font-size:14px;cursor:pointer;transition:color .15s}.browser-close:hover{color:#e8e8e8}.browser-loading{padding:40px;text-align:center;color:#666;font-size:12px;font-family:Space Mono,monospace}.browser-empty{padding:40px;text-align:center;color:#666;font-size:13px;font-family:Space Mono,monospace}.browser-list{flex:1;overflow-y:auto;padding:10px}.browser-server{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:8px;transition:background .1s}.browser-server:hover{background:#1a1a1a}.browser-server-icon{width:44px;height:44px;border-radius:8px;background:#272727;border:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#aaa;font-family:Space Mono,monospace;flex-shrink:0}.browser-server-info{flex:1;display:flex;flex-direction:column;gap:3px}.browser-server-name{font-size:14px;font-weight:600;color:#e8e8e8;font-family:Inter,sans-serif}.browser-server-meta{font-size:11px;color:#555;font-family:Space Mono,monospace}.browser-join-btn{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;color:#aaa;font-size:12px;font-weight:600;padding:7px 16px;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;flex-shrink:0}.browser-join-btn:hover:not(:disabled){background:#272727;border-color:#444;color:#e8e8e8}.browser-join-btn:disabled{opacity:.4;cursor:not-allowed}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999}.toast{display:flex;align-items:center;gap:12px;background:#141414;border:1px solid #2a2a2a;border-radius:10px;padding:14px 16px;min-width:280px;box-shadow:0 8px 32px #0009;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:20px}.toast-text{flex:1;display:flex;flex-direction:column;gap:2px}.toast-title{font-family:Space Mono,monospace;font-size:11px;font-weight:700;color:#27ae60;text-transform:uppercase;letter-spacing:1px}.toast-msg{font-size:13px;color:#aaa;font-family:Inter,sans-serif}.toast-close{background:none;color:#555;font-size:12px;cursor:pointer;transition:color .15s;padding:2px 4px}.toast-close:hover{color:#e8e8e8}.settings-avatar-img{width:64px;height:64px;border-radius:50%;object-fit:cover}.settings-photo-row{display:flex;gap:8px;align-items:center}.settings-upload-btn{cursor:pointer;display:inline-flex;align-items:center;gap:6px}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{background:#141414;border:1px solid #2a2a2a;border-radius:12px;padding:24px;width:360px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 48px #000c;animation:fadeIn .15s ease;display:flex;flex-direction:column;gap:20px}.settings-header{display:flex;align-items:center;justify-content:space-between}.settings-header h3{font-family:Space Mono,monospace;font-size:12px;font-weight:700;color:#e8e8e8;text-transform:uppercase;letter-spacing:1.5px}.settings-close{background:none;color:#666;font-size:14px;cursor:pointer;transition:color .15s}.settings-close:hover{color:#e8e8e8}.settings-profile-preview{display:flex;align-items:center;gap:14px;padding:14px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px}.settings-avatar{width:52px;height:52px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;transition:background .2s}.settings-username{font-family:Space Mono,monospace;font-size:15px;font-weight:700;color:#e8e8e8}.settings-section{display:flex;flex-direction:column;gap:10px;padding-bottom:20px;border-bottom:1px solid #1e1e1e}.settings-label{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:1px;font-family:Space Mono,monospace}.settings-colors{display:flex;flex-wrap:wrap;gap:8px}.settings-color-swatch{width:32px;height:32px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .15s}.settings-color-swatch:hover{transform:scale(1.1)}.settings-color-swatch.active{border-color:#e8e8e8;transform:scale(1.1)}.settings-section form{display:flex;flex-direction:column;gap:10px}.settings-section input{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:10px 12px;font-size:13px;color:#e8e8e8;transition:border-color .2s;font-family:Inter,sans-serif}.settings-section input:focus{border-color:#444}.settings-section input::placeholder{color:#444}.settings-section textarea{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:10px 12px;font-size:13px;color:#e8e8e8;font-family:Inter,sans-serif;resize:none;width:100%;transition:border-color .2s}.settings-section textarea:focus{border-color:#444}.settings-section textarea::placeholder{color:#444}.settings-char-count{font-size:10px;color:#444;text-align:right;font-family:Space Mono,monospace}.settings-error{font-size:12px;color:#e74c3c;font-family:Space Mono,monospace;text-align:center}.settings-success{font-size:12px;color:#27ae60;font-family:Space Mono,monospace;text-align:center}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-void: #060607;--bg-deep: #0d0d0f;--bg-base: #111114;--bg-raised: #18181c;--bg-float: #1e1e24;--bg-hover: #24242c;--bg-active: #2a2a34;--gray-1: #3a3a46;--gray-2: #55555f;--gray-3: #7a7a88;--gray-4: #a0a0b0;--gray-5: #c8c8d8;--white: #eeeef4;--accent: #7a7a88;--accent-dim: rgba(122,122,136,.15);--accent-glow: rgba(122,122,136,.08);--danger: #ed4245;--danger-dim: rgba(237,66,69,.12);--success: #23a55a;--warning: #f0b132;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(0,0,0,.5);--shadow-md: 0 4px 16px rgba(0,0,0,.6);--shadow-lg: 0 8px 32px rgba(0,0,0,.8);--border: 1px solid rgba(255,255,255,.04);--border-bright: 1px solid rgba(255,255,255,.08)}html,body,#root{height:100%;width:100%}body{font-family:DM Sans,sans-serif;background:var(--bg-void);color:var(--white);overflow:hidden;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea{font-family:inherit;outline:none;border:none}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-1);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes slideIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .15s ease forwards}
