.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:var(--bg-secondary);padding:32px;border-radius:8px;width:100%;max-width:480px;box-shadow:0 8px 32px #0000004d}.login-box h1{font-size:24px;font-weight:600;margin-bottom:8px;text-align:center}.subtitle{text-align:center;color:var(--text-secondary);margin-bottom:24px;font-size:16px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px}.form-group input{width:100%;padding:10px;background:var(--bg-tertiary);border:none;border-radius:4px;color:var(--text-primary);font-size:16px}.form-group input:focus{outline:2px solid var(--accent)}.checkbox-group{margin-bottom:16px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary);text-transform:none;font-weight:400}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer;accent-color:var(--accent)}.checkbox-label span{-webkit-user-select:none;user-select:none}.submit-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border-radius:4px;font-size:16px;font-weight:500;transition:background .2s;margin-top:8px}.submit-btn:hover:not(:disabled){background:var(--accent-hover)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.switch-mode{margin-top:16px;text-align:center;color:var(--text-secondary);font-size:14px}.link-btn{background:none;color:var(--accent);text-decoration:underline;font-size:14px;padding:0;margin-left:4px}.link-btn:hover{color:var(--accent-hover)}.server-list{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 0;overflow-y:auto;overflow-x:hidden;min-height:0;position:relative}.server-item{width:48px;height:48px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;margin-bottom:8px;transition:border-radius .2s,background .2s;color:var(--text-primary);font-weight:600;font-size:18px;position:relative}.server-item:hover,.server-item.active{background:var(--accent);border-radius:16px}.server-item.active:before{content:"";position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:4px;height:40px;background:#fff;border-radius:0 4px 4px 0}.home-server{background:var(--bg-secondary);color:var(--text-primary);font-size:20px}.home-server:hover{background:var(--accent);color:#fff;border-radius:16px}.home-server.active{background:var(--accent);border-radius:16px;color:#fff}.add-server{background:var(--bg-secondary);color:var(--text-primary);margin-top:auto;position:relative;display:flex;align-items:center;justify-content:center}.add-server:hover{background:var(--success);color:#fff;border-radius:16px}.server-add-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease-out}.server-add-menu{position:relative;display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:8px;padding:8px;box-shadow:0 8px 32px #00000080;z-index:10001;min-width:280px;border:1px solid var(--border-color);animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.server-add-option{padding:12px 16px;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:4px;font-size:16px;font-weight:500;transition:background .2s;width:100%;pointer-events:auto;position:relative;z-index:10001;-webkit-user-select:none;user-select:none;margin-bottom:4px}.server-add-option:hover{background:var(--bg-hover)}.server-divider{width:32px;height:2px;background:var(--border-color);margin:8px 0;border-radius:1px}.channel-list{width:240px;background:var(--bg-secondary);display:flex;flex-direction:column;color:var(--text-primary);overflow:hidden}.channel-header{height:48px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px #0003;border-bottom:1px solid var(--border-color)}.channel-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.channel-header-actions{display:flex;gap:4px;align-items:center}.invite-btn{background:none;color:var(--text-secondary);font-size:18px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s,color .2s;border:none;cursor:pointer}.invite-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.add-channel-btn{background:none;color:var(--text-secondary);font-size:20px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s,color .2s}.add-channel-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.channel-category{padding:16px 16px 8px;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px}.channels{flex:1;overflow-y:auto;padding:8px 8px 0}.channel-item{padding:6px 8px;border-radius:4px;cursor:pointer;display:flex;align-items:center;color:var(--text-secondary);transition:background .2s,color .2s;margin-bottom:2px}.channel-item:hover,.channel-item.active{background:var(--channel-hover);color:var(--text-primary)}.channel-icon{margin-right:6px;font-weight:500}.channel-name{font-size:16px}.channel-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.channel-modal{background:var(--bg-secondary);padding:24px;border-radius:8px;width:90%;max-width:440px}.channel-modal h3{margin-bottom:16px;font-size:20px}.channel-modal input{width:100%;padding:10px;background:var(--bg-tertiary);border:none;border-radius:4px;color:var(--text-primary);font-size:16px;margin-bottom:16px}.channel-modal-buttons{display:flex;gap:8px;justify-content:flex-end}.channel-modal-buttons button{padding:10px 16px;border-radius:4px;font-size:14px;font-weight:500}.channel-modal-buttons button[type=button]{background:transparent;color:var(--text-secondary)}.channel-modal-buttons button[type=button]:hover{background:var(--bg-hover);color:var(--text-primary)}.channel-modal-buttons button[type=submit]{background:var(--accent);color:#fff}.channel-modal-buttons button[type=submit]:hover{background:var(--accent-hover)}.invites-modal{max-width:500px}.invites-content{margin-bottom:16px}.create-invite-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;margin-bottom:16px}.create-invite-btn:hover:not(:disabled){background:var(--accent-hover)}.create-invite-btn:disabled{opacity:.5;cursor:not-allowed}.invites-list{max-height:300px;overflow-y:auto}.invite-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:4px;margin-bottom:8px}.invite-code{flex:1;cursor:pointer;padding:8px;background:var(--bg-secondary);border-radius:4px;display:flex;flex-direction:column;gap:4px;transition:background .2s}.invite-code:hover{background:var(--bg-hover)}.invite-code code{font-size:18px;font-weight:600;color:var(--accent);font-family:monospace;letter-spacing:2px}.copy-hint{font-size:11px;color:var(--text-secondary)}.invite-info{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary);min-width:100px}.invite-info .expired{color:#ed4245;font-weight:600}.delete-invite-btn{background:transparent;border:none;color:var(--text-secondary);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.delete-invite-btn:hover{background:#ed42451a;color:#ed4245}.empty-invites{text-align:center;padding:20px;color:var(--text-secondary);font-size:14px}.loading{text-align:center;padding:20px;color:var(--text-secondary)}.voice-call-panel{position:absolute;top:0;left:0;right:0;background:var(--bg-secondary, #2f3136);border-bottom:1px solid var(--border-color, #202225);z-index:1000;display:flex;flex-direction:column;box-shadow:0 4px 16px #0000004d;animation:slideDown .3s ease-out;min-height:150px;max-height:80vh}.voice-call-resize-handle{width:100%;height:8px;cursor:ns-resize;background:transparent;position:relative;flex-shrink:0;z-index:1001;order:2}.voice-call-resize-handle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:4px;background:var(--text-secondary, #b9bbbe);border-radius:2px;opacity:.5;transition:opacity .2s}.voice-call-resize-handle:hover:before{opacity:1;background:var(--accent, #5865f2)}.voice-call-content{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:16px}.voice-call-incoming,.voice-call-active{width:100%;max-width:400px;text-align:center;padding:16px}.call-avatar-large{width:120px;height:120px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:48px;font-weight:600;margin:0 auto 24px}.call-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:600;margin:0 auto 12px}.call-header{margin-bottom:32px}.call-info{margin-bottom:24px}.call-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.call-status{font-size:14px;color:var(--text-secondary)}.call-controls{display:flex;justify-content:center;gap:16px;align-items:center}.call-btn{width:64px;height:64px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:24px}.call-btn:hover{transform:scale(1.1)}.call-btn.accept{background:#3ba55d;color:#fff}.call-btn.reject{background:#ed4245;color:#fff}.call-control-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;font-size:18px}.call-control-btn:hover{background:var(--bg-hover)}.call-control-btn.active{background:var(--accent);color:#fff}.call-control-btn.end-call{background:#ed4245;color:#fff;width:48px;height:48px}.call-control-btn.end-call:hover{background:#c03537}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden;position:relative}.chat-header{height:48px;padding:0 16px;display:flex;align-items:center;box-shadow:0 1px #0003;border-bottom:1px solid var(--border-color)}.channel-icon{margin-right:8px;font-weight:500;color:var(--text-secondary)}.chat-header h2{font-size:16px;font-weight:600;color:var(--text-primary)}.messages-container{flex:1;overflow-y:auto;padding:16px;margin-top:0}.message{display:flex;padding:8px 16px;margin-bottom:4px;border-radius:4px;transition:background .2s}.message:hover{background:var(--message-hover)}.message-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;flex-shrink:0;margin-right:16px;font-size:16px}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;margin-bottom:4px}.message-author{font-weight:600;color:var(--text-primary);margin-right:8px;font-size:16px}.message-time{font-size:12px;color:var(--text-secondary)}.message-text{color:var(--text-primary);font-size:16px;word-wrap:break-word;line-height:1.375}.message-input-container{padding:0 16px 24px;display:flex;gap:8px}.message-input{flex:1;padding:10px 16px;background:var(--bg-secondary);border:none;border-radius:4px;color:var(--text-primary);font-size:16px;resize:none}.message-input::placeholder{color:var(--text-secondary)}.send-button{padding:10px 20px;background:var(--accent);color:#fff;border-radius:4px;font-size:14px;font-weight:500;transition:background .2s}.send-button:hover:not(:disabled){background:var(--accent-hover)}.send-button:disabled{opacity:.5;cursor:not-allowed}.friend-info-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease-out}.friend-info-modal{background:var(--bg-secondary, #2f3136);border-radius:8px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080;animation:slideUp .3s ease-out;overflow:hidden}.friend-info-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color, #202225)}.friend-info-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary, #fff)}.close-btn{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary, #b9bbbe);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:var(--bg-hover, #202225);color:var(--text-primary, #fff)}.friend-info-content{padding:20px;overflow-y:auto;flex:1}.friend-info-layout{display:flex;gap:24px;align-items:flex-start}.friend-info-left{flex:1;min-width:0}.friend-info-right{width:300px;flex-shrink:0;border-left:1px solid var(--border-color, #202225);padding-left:24px}.loading{text-align:center;padding:40px;color:var(--text-secondary, #b9bbbe)}.friend-profile{text-align:center;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border-color, #202225)}.friend-avatar-large{width:80px;height:80px;border-radius:50%;background:var(--accent, #5865f2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:600;margin:0 auto 12px}.friend-name-large{font-size:24px;font-weight:600;color:var(--text-primary, #fff)}.friend-info-section{margin-bottom:24px}.friend-info-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-secondary, #b9bbbe);text-transform:uppercase}.common-servers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.server-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:var(--bg-tertiary, #202225);border-radius:8px;transition:all .2s;cursor:pointer}.server-tile:hover{background:var(--bg-hover, #36393f);transform:translateY(-2px)}.server-tile .server-icon{width:48px;height:48px;border-radius:50%;background:var(--accent, #5865f2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:20px;flex-shrink:0}.server-tile .server-name{color:var(--text-primary, #fff);font-weight:500;font-size:13px;text-align:center;word-break:break-word;max-width:100%}.empty-state{color:var(--text-secondary, #b9bbbe);font-size:14px;padding:20px;text-align:center}.friend-note-input{width:100%;padding:12px;background:var(--bg-tertiary, #202225);border:1px solid var(--border-color, #040405);border-radius:4px;color:var(--text-primary, #fff);font-size:14px;font-family:inherit;resize:vertical;min-height:80px}.friend-note-input:focus{outline:none;border-color:var(--accent, #5865f2)}.saving-indicator{font-size:12px;color:var(--text-secondary, #b9bbbe);margin-top:4px}.note-character-count{font-size:12px;color:var(--text-secondary, #b9bbbe);text-align:right;margin-top:4px}.friend-info-actions{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color, #202225)}.btn-remove-friend{width:100%;padding:12px;background:#ed4245;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.btn-remove-friend:hover{background:#c03537}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.friends-container{display:flex;flex-direction:column;height:100vh;width:240px;background:var(--bg-secondary);color:var(--text-primary);border-right:1px solid var(--border-color);flex-shrink:0;overflow:hidden}.friends-list-compact{padding:8px;overflow-y:auto}.friends-list-compact .friend-item{margin-bottom:4px}.compact-requests-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color, #202225)}.compact-section-title{font-size:11px;font-weight:600;color:var(--text-secondary, #b9bbbe);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;padding:0 8px}.friend-item.pending-compact{display:flex;align-items:center;justify-content:space-between;padding:8px;border-radius:4px;transition:background .2s}.friend-item.pending-compact:hover{background:var(--bg-hover, #36393f)}.btn-accept-compact{width:28px;height:28px;border:none;background:var(--accent, #5865f2);color:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;transition:background .2s;flex-shrink:0}.btn-accept-compact:hover{background:#4752c4}.friends-header{padding:20px;background:var(--bg-secondary, #2f3136);border-bottom:1px solid var(--border-color, #202225);flex-shrink:0}.friends-header-top{display:flex;align-items:center;gap:10px;margin-bottom:15px}.friends-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.friends-tabs{display:flex;gap:10px}.friends-tabs button{padding:8px 16px;background:transparent;border:none;color:#b9bbbe;cursor:pointer;border-radius:4px;font-size:14px;transition:background .2s,color .2s}.friends-tabs button:hover{background:#202225;color:#fff}.friends-tabs button.active{background:#5865f2;color:#fff}.requests-badge{display:inline-block;background:#ed4245;color:#fff;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600;margin-left:6px;min-width:20px;text-align:center}.requests-count{color:#b9bbbe;font-size:12px;margin-left:4px}.friends-content{flex:1;padding:20px;overflow-y:auto;min-height:0}.add-friend-form{display:flex;gap:10px;margin-bottom:20px;padding:15px;background:#2f3136;border-radius:8px}.add-friend-form input{flex:1;padding:10px;background:#202225;border:1px solid #040405;border-radius:4px;color:#dcddde;font-size:16px}.add-friend-form button{padding:10px 20px;background:#5865f2;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.add-friend-form button:hover:not(:disabled){background:#4752c4}.add-friend-form button:disabled{opacity:.5;cursor:not-allowed}.message{padding:12px;border-radius:4px;margin-bottom:20px}.message.error{background:#ed4245;color:#fff}.message.success{background:#43b581;color:#fff}.friends-list{display:flex;flex-direction:column;gap:10px}.friend-item{display:flex;align-items:center;justify-content:space-between;padding:15px;background:#2f3136;border-radius:8px;transition:background .2s}.friend-item:hover{background:#36393f}.friend-info{display:flex;align-items:center;gap:15px}.friend-avatar{width:40px;height:40px;border-radius:50%;background:#5865f2;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:18px}.friend-name{font-weight:600;color:#fff;margin-bottom:4px}.friend-email,.friend-mutual{font-size:14px;color:#b9bbbe}.friend-status{font-size:12px;color:var(--text-secondary, #b9bbbe)}.friend-status.online{color:#43b581}.friend-status.offline{color:#747f8d}.btn-remove,.btn-accept{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-remove{background:#ed4245;color:#fff}.btn-remove:hover{background:#c03537}.btn-accept{background:#43b581;color:#fff}.btn-accept:hover{background:#3ca374}.status-pending{color:#faa61a;font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:#b9bbbe}.empty-state p{margin:10px 0}.empty-state .hint{font-size:14px;color:#72767d}.requests-container{display:flex;flex-direction:column;gap:30px}.requests-section h3{margin:0 0 15px;font-size:16px;font-weight:600;color:#b9bbbe;text-transform:uppercase}.pending-requests-banner{background:#2f3136;border-radius:8px;padding:16px;margin-bottom:20px;border:1px solid #5865f2}.pending-requests-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pending-requests-header h3{margin:0;font-size:14px;font-weight:600;color:#5865f2;text-transform:uppercase}.view-all-requests-btn{background:transparent;border:1px solid #5865f2;color:#5865f2;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.view-all-requests-btn:hover{background:#5865f2;color:#fff}.pending-requests-list{display:flex;flex-direction:column;gap:8px}.friend-item.pending{background:#202225;padding:12px}.show-more-requests{background:transparent;border:none;color:#5865f2;padding:8px;border-radius:4px;font-size:14px;cursor:pointer;text-align:center;transition:background .2s;margin-top:4px}.show-more-requests:hover{background:#2f3136}.direct-messages{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);flex:1;position:relative;overflow:hidden}.dm-header{height:48px;padding:0 16px;display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.call-btn-header{width:36px;height:36px;border-radius:50%;background:transparent;border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-left:auto}.call-btn-header:hover{background:var(--bg-hover);color:var(--accent)}.dm-user-info{display:flex;align-items:center;gap:12px;flex:1}.dm-user-info.clickable{cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.dm-user-info.clickable:hover{background:var(--bg-hover, rgba(255, 255, 255, .05))}.dm-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.dm-username{font-weight:600;color:var(--text-primary);font-size:16px}.dm-status{font-size:12px;color:var(--text-secondary, #b9bbbe)}.dm-status.online{color:#43b581}.dm-status.offline{color:#747f8d}.dm-messages-container{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.dm-message{display:flex;gap:12px;align-items:flex-start}.dm-message.own{flex-direction:row-reverse}.dm-message-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:600;font-size:16px;flex-shrink:0}.dm-message-content{flex:1;max-width:70%}.dm-message.own .dm-message-content{display:flex;flex-direction:column;align-items:flex-end}.dm-message-header{display:flex;gap:8px;align-items:center;margin-bottom:4px}.dm-message-author{font-weight:600;color:var(--text-primary);font-size:16px}.dm-message-time{font-size:12px;color:var(--text-secondary)}.dm-message-text{background:var(--bg-secondary);padding:8px 12px;border-radius:8px;color:var(--text-primary);word-wrap:break-word}.dm-message.own .dm-message-text{background:var(--accent);color:#fff}.dm-input-container{padding:16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;gap:8px;flex-shrink:0}.dm-input{flex:1;padding:10px 16px;background:var(--bg-tertiary);border:none;border-radius:8px;color:var(--text-primary);font-size:16px}.dm-input:focus{outline:none}.dm-send-button{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.dm-send-button:hover:not(:disabled){background:var(--accent-hover)}.dm-send-button:disabled{opacity:.5;cursor:not-allowed}.home-view{display:flex;height:100vh;background:var(--bg-primary);flex:1}.home-sidebar{width:240px;background:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border-color);flex-shrink:0}.home-header{padding:20px;border-bottom:1px solid var(--border-color)}.home-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.home-actions{display:flex;flex-direction:column;padding:8px;gap:4px;border-bottom:1px solid var(--border-color)}.home-action-btn{width:100%;padding:10px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left;display:flex;align-items:center;gap:8px}.home-action-btn svg{flex-shrink:0}.home-action-btn:hover,.home-action-btn.active{background:var(--bg-hover);color:var(--text-primary)}.add-friend-form-container{padding:8px;border-bottom:1px solid var(--border-color)}.add-friend-form-inline{display:flex;flex-direction:column;gap:8px}.add-friend-form-inline input{padding:8px;background:var(--bg-tertiary);border:none;border-radius:4px;color:var(--text-primary);font-size:14px}.add-friend-form-inline button{padding:8px;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-friend-form-inline button:hover:not(:disabled){background:var(--accent-hover)}.add-friend-form-inline button:disabled{opacity:.5;cursor:not-allowed}.error-message-small{font-size:12px;color:#ed4245;margin-top:4px}.success-message-small{font-size:12px;color:#43b581;margin-top:4px}.home-content{flex:1;overflow-y:auto;min-height:0}.dms-list{padding:8px}.dm-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:4px;cursor:pointer;transition:background .2s;margin-bottom:4px}.dm-item:hover,.dm-item.active{background:var(--bg-hover)}.dm-item-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0}.dm-item-info{flex:1;min-width:0}.dm-item-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-placeholder{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--text-secondary)}.home-placeholder h2{margin-bottom:8px;color:var(--text-primary)}.empty-state{padding:20px;text-align:center;color:var(--text-secondary)}.empty-state p{margin:0}.settings-container{display:flex;height:100vh;width:100%;background:var(--bg-primary);color:var(--text-primary);flex:1}.settings-sidebar{width:240px;background:var(--bg-secondary);padding:20px;border-right:1px solid var(--border-color);overflow-y:auto;flex-shrink:0}.settings-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.settings-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.back-btn{width:32px;height:32px;border:none;background:transparent;color:#b9bbbe;font-size:20px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.back-btn:hover{background:#202225;color:#fff}.settings-nav{display:flex;flex-direction:column;gap:5px}.settings-nav button{padding:10px 15px;background:transparent;border:none;color:#b9bbbe;text-align:left;cursor:pointer;border-radius:4px;font-size:16px;transition:background .2s,color .2s}.settings-nav button:hover{background:#202225;color:#fff}.settings-nav button.active{background:#5865f2;color:#fff}.settings-content{flex:1;padding:40px;overflow-y:auto;min-width:0}.settings-section h3{margin:0 0 30px;font-size:24px;font-weight:600;color:#fff}.settings-field{margin-bottom:20px}.settings-field label{display:block;margin-bottom:8px;font-size:12px;font-weight:600;color:#b9bbbe;text-transform:uppercase}.settings-field input[type=text],.settings-field input[type=email],.settings-field select{width:100%;max-width:400px;padding:10px;background:#202225;border:1px solid #040405;border-radius:4px;color:#dcddde;font-size:16px}.settings-field input:disabled{opacity:.5;cursor:not-allowed}.settings-field input[type=checkbox]{margin-right:10px;width:18px;height:18px;cursor:pointer}.settings-field label:has(input[type=checkbox]){display:flex;align-items:center;text-transform:none;font-weight:400;cursor:pointer}.settings-actions{margin-top:30px;padding-top:30px;border-top:1px solid #40444b}.btn-danger{padding:10px 20px;background:#ed4245;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#c03537}.settings-note{color:#b9bbbe;font-size:14px;margin-top:20px}.member-list{width:240px;background:var(--bg-secondary, #2f3136);border-left:1px solid var(--border-color, #202225);display:flex;flex-direction:column;height:100%;flex-shrink:0}.member-list-header{padding:16px;border-bottom:1px solid var(--border-color, #202225)}.member-list-header h3{margin:0;font-size:12px;font-weight:600;color:var(--text-secondary, #b9bbbe);text-transform:uppercase;letter-spacing:.5px}.member-list-content{flex:1;overflow-y:auto;padding:8px}.member-list-loading,.member-list-empty{padding:20px;text-align:center;color:var(--text-secondary, #b9bbbe);font-size:14px}.members{display:flex;flex-direction:column;gap:2px}.member-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:4px;transition:background .2s;cursor:pointer}.member-item:hover{background:var(--bg-hover, #36393f)}.member-item.current-user{background:var(--bg-tertiary, #202225)}.member-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent, #5865f2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0;overflow:hidden}.member-avatar img{width:100%;height:100%;object-fit:cover}.member-info{flex:1;min-width:0}.member-username{color:var(--text-primary, #fff);font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-badge{font-size:11px;color:var(--text-secondary, #b9bbbe);font-weight:400}.member-role{font-size:12px;color:var(--text-secondary, #b9bbbe);margin-top:2px;text-transform:capitalize}.dashboard{display:flex;height:100vh;width:100vw;background:var(--bg-primary);overflow:hidden}.dashboard-sidebar{display:flex;flex-direction:column;width:72px;height:100vh;background:var(--bg-tertiary)}.user-menu{margin-top:auto;padding:8px 0;background:var(--bg-tertiary);border-top:1px solid var(--border-color);width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}.user-avatar-menu{width:48px;height:48px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:600;font-size:18px;cursor:pointer;transition:all .2s;margin-bottom:4px}.user-status-menu{margin-bottom:8px;width:100%;display:flex;justify-content:center}.status-select{width:90%;padding:4px 8px;background:var(--bg-secondary, #2f3136);border:1px solid var(--border-color, #202225);border-radius:4px;color:var(--text-primary, #fff);font-size:12px;cursor:pointer;transition:all .2s}.status-select:hover{background:var(--bg-hover, #36393f);border-color:var(--accent, #5865f2)}.status-select:focus{outline:none;border-color:var(--accent, #5865f2)}.user-avatar-menu:hover{border-radius:16px;background:var(--accent);color:#fff}.user-actions{display:flex;flex-direction:column;gap:4px;align-items:center}.nav-btn{width:48px;height:48px;border:none;background:var(--bg-secondary, #2f3136);border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-bottom:4px}.nav-btn:hover{border-radius:16px;background:var(--accent, #5865f2)}.nav-btn.active{background:var(--accent, #5865f2);border-radius:16px;color:#fff}.logout-btn:hover{background:#ed4245!important}.chat-area-wrapper{flex:1;display:flex;height:100%;overflow:hidden}.chat-placeholder{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--text-secondary)}.chat-placeholder h2{margin-bottom:8px;color:var(--text-primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:var(--bg-secondary);padding:24px;border-radius:8px;width:90%;max-width:440px}.modal h2{margin-bottom:16px}.modal input{width:100%;padding:10px;background:var(--bg-tertiary);border:none;border-radius:4px;color:var(--text-primary);font-size:16px;margin-bottom:16px}.modal-buttons{display:flex;gap:8px;justify-content:flex-end}.modal-buttons button{padding:10px 16px;border-radius:4px;font-size:14px;font-weight:500}.modal-buttons button[type=button]{background:transparent;color:var(--text-secondary)}.modal-buttons button[type=button]:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-buttons button[type=submit]{background:var(--accent);color:#fff}.modal-buttons button[type=submit]:hover{background:var(--accent-hover)}.error-message{background:#ed42451a;border:1px solid rgba(237,66,69,.3);color:#ed4245;padding:10px;border-radius:4px;margin-bottom:16px;font-size:14px}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #36393f;--bg-secondary: #2f3136;--bg-tertiary: #202225;--bg-hover: #34373c;--text-primary: #dcddde;--text-secondary: #b9bbbe;--accent: #5865f2;--accent-hover: #4752c4;--success: #3ba55d;--border-color: #202225;--channel-hover: #3c3f44;--message-hover: #32353b}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-tertiary);color:var(--text-primary);overflow:hidden}#root{height:100vh;width:100vw;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea{font-family:inherit;outline:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4e5258}
