body{margin:0;padding:0;font-family:Arial,sans-serif;background-color:#f0f2f5}.login-container,.register-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f0f2f5;padding:20px}.login-form,.register-form{background-color:#fff;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.1);padding:30px;width:100%;max-width:400px;transition:transform .3s ease,box-shadow .3s ease}.login-form:hover,.register-form:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,.15)}.login-form h2,.register-form h2{margin:0 0 25px 0;text-align:center;color:#333;font-size:24px;font-weight:600}.error-message{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px}.error-message,.success-message{padding:10px 15px;margin-bottom:20px;font-size:14px}.success-message{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:6px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555}.form-group input{width:100%;padding:12px 15px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}.captcha-group{margin-bottom:20px}.captcha-row{display:flex;gap:10px;align-items:center}.captcha-row input{flex:1}.captcha-image{display:flex;align-items:center}.captcha-image img{height:40px;border-radius:6px;cursor:pointer;transition:transform .2s ease}.captcha-image img:hover{transform:scale(1.05)}.form-actions{margin-top:30px}.login-btn,.register-btn{width:100%;padding:12px;background-color:#3498db;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.login-btn:hover,.register-btn:hover{background-color:#2980b9;transform:translateY(-2px)}.login-btn:disabled,.register-btn:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none}.form-footer{margin-top:20px;text-align:center;font-size:14px;color:#666}.form-footer a{color:#3498db;text-decoration:none;font-weight:500;transition:color .3s ease}.form-footer a:hover{color:#2980b9;text-decoration:underline}@media (max-width:480px){.login-form,.register-form{padding:20px}.login-form h2,.register-form h2{font-size:20px}.captcha-row{flex-direction:column;align-items:stretch}.captcha-image{justify-content:center;margin-top:10px}.captcha-image img{height:48px}}.private-header{justify-content:space-between;padding:10px 15px;background-color:#fff;border-bottom:1px solid #eee}.private-header,.private-user-avatar,.private-user-info{display:flex;align-items:center}.private-user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;justify-content:center;margin-right:10px;position:relative;flex-shrink:0}.private-user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}#privateUserInitials,.private-user-avatar .user-initials{font-size:18px;font-weight:700;color:#fff;background-color:#3498db;width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:absolute;top:0;left:0}.private-user-details{display:flex;flex-direction:column;justify-content:center}.private-user-details h2{margin:0;font-size:16px;font-weight:600;color:#333}.private-user-details #privateUserStatus,.private-user-details .user-status{font-size:12px;color:#666;margin-top:2px;width:auto;height:auto;min-width:auto;min-height:auto;border-radius:0;margin-left:0;background-color:transparent}.private-actions{display:flex;gap:10px}.private-actions button{padding:8px;border:none;border-radius:50%;background-color:#f0f0f0;color:#333;cursor:pointer;font-size:14px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.private-actions button:hover{background-color:#e0e0e0}.private-actions button:active{background-color:#d0d0d0}.private-chat-interface{display:none;flex-direction:column;height:100%;width:100%;background-color:#fff;overflow:hidden}#privateEmptyState{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#6c757d;text-align:center;background-color:#fafafa;padding:20px}#privateMessageContainer{flex:1 1 auto;overflow-y:auto;margin-bottom:0;padding:10px;background-color:#fafafa;display:flex;flex-direction:column;min-height:0;position:relative}.search-result-item{display:flex;align-items:center;padding:10px;border-bottom:1px solid #eee;cursor:pointer}.search-result-item:hover{background-color:#f5f5f5}.search-result-item .user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;margin-right:10px}.search-result-item .user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.search-result-info{flex:1}.search-result-nickname{font-weight:700;margin-bottom:2px}.search-result-username{font-size:12px;color:#666}.add-friend-btn{background-color:#3498db;color:#fff;border:none;border-radius:50%;width:30px;height:30px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-friend-btn:hover{background-color:#2980b9}#groupMessageContainer,#messageContainer,#privateMessageContainer{max-height:calc(100vh - 200px);overflow-y:auto;overflow-x:hidden;word-break:break-word;hyphens:auto}.file-link-container{display:inline-block;margin:5px 0;padding:8px 12px;background-color:#f1f1f1;border-radius:4px;border:1px solid #ddd}.file-icon{margin-right:8px}.message-link{color:#3498db!important;text-decoration:none!important}.message-link:hover{text-decoration:underline!important}#main-chat{width:100vw;height:100vh;display:flex;overflow:auto;min-width:800px}#sidebar{width:100px;min-width:100px;max-width:100px;height:100%;min-height:100%;max-height:100%;background-color:#2c3e50;color:#fff;box-sizing:border-box;box-shadow:2px 0 10px rgba(0,0,0,.1)}#sidebar,.sidebar-header{display:flex;flex-direction:column;align-items:center}.sidebar-header{justify-content:center;width:100%;padding:10px 0;border-bottom:1px solid #34495e}.user-profile{margin-top:15px;flex-direction:column;gap:8px}#userAvatar,.user-profile{display:flex;align-items:center}#userAvatar{position:relative;width:60px;height:60px;min-width:60px;min-height:60px;border-radius:50%;overflow:hidden;border:2px solid #3498db;background-color:#34495e;justify-content:center}.user-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%;display:block}.user-initials{position:absolute;font-size:24px;font-weight:600;color:#fff;display:none}.sidebar-icon{width:60px;height:60px;border-radius:50%;-o-object-fit:cover;object-fit:cover;cursor:pointer;transition:all .3s ease}.sidebar-icon:hover{transform:scale(1.1);box-shadow:0 0 15px hsla(0,0%,100%,.3)}.menu-section{width:100%;margin-top:20px}.menu-list{list-style:none;padding:0;margin:0;width:100%}.menu-item{display:flex;justify-content:center;align-items:center;width:100%;height:60px;cursor:pointer;transition:all .3s ease;border-radius:8px;margin:5px 0;position:relative;background-color:transparent}.menu-item:hover{background-color:#34495e;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.menu-item.active{background-color:#3498db;color:#fff;box-shadow:0 4px 12px rgba(52,152,219,.4)}.menu-item.active:hover{background-color:#2980b9;transform:translateY(-2px)}.chat-avatar{font-size:24px;display:flex;justify-content:center;align-items:center;width:40px;height:40px;border-radius:50%;transition:all .3s ease}.menu-item:hover .chat-avatar{transform:scale(1.2)}.menu-item.active .chat-avatar{transform:scale(1.2);color:#fff}#secondary-sidebar{width:250px;min-width:250px;max-width:250px;height:100%;background-color:#34495e;color:#fff;box-sizing:border-box;padding:15px;overflow-y:auto;box-shadow:2px 0 10px rgba(0,0,0,.1)}.sidebar-section{margin-bottom:25px;border-bottom:1px solid #2c3e50;padding-bottom:15px}.sidebar-section:last-child{border-bottom:none}.section-header{margin-bottom:10px}.section-header,.sidebar-section h3{display:flex;justify-content:space-between;align-items:center}.sidebar-section h3{font-size:16px;font-weight:600;margin:0 0 10px 0;cursor:pointer}.toggle-section{font-size:12px;cursor:pointer;transition:transform .3s ease}.toggle-section:hover{color:#3498db}.settings-list,.user-list{list-style:none;padding:0;margin:0}.settings-list li,.user-list li{padding:8px 6px;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:14px;margin-bottom:5px}.settings-list li:hover,.user-list li:hover{background-color:#2c3e50;transform:translateX(5px)}.secondary-content{display:none;width:100%;height:100%}.secondary-content.active{display:block}.chat-content{width:100%;height:100%;min-height:100%;flex-direction:column;box-sizing:border-box;overflow:hidden;padding-top:0}.chat-content,.chat-content.active{display:flex;flex:1}#groupMessageContainer,#messageContainer{flex:1 1 auto;overflow-y:auto;margin-bottom:0;padding:10px;background-color:#fafafa;display:flex;flex-direction:column;min-height:0;position:relative}.input-area{flex:0 0 auto;margin-top:auto}.empty-chat-state{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#6c757d;text-align:center;background-color:#fafafa;padding:20px}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5;transition:all .3s ease}.empty-chat-state:hover .empty-icon{transform:scale(1.1) rotate(5deg);opacity:.7}.empty-chat-state h3{margin:0 0 10px 0;font-size:24px;font-weight:600;color:#495057}.empty-chat-state p{margin:0;font-size:16px;max-width:400px;line-height:1.5}.group-chat-interface{display:none;flex-direction:column;height:100%;width:100%;background-color:#fff;overflow:hidden}.group-chat-interface.active{display:flex}#groupEmptyState{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#6c757d;text-align:center;background-color:#fafafa;padding:20px}#groupChatInterface{display:none;flex-direction:column;height:100%;width:100%;background-color:#fff}#groupChatInterface.active{display:flex}#groupMessageContainer{flex:1}.group-message-input-area{display:flex;flex-direction:column;padding:15px;background-color:#fff;border-top:1px solid #e9ecef;gap:10px}.group-input-container{position:relative;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:10px;transition:all .3s ease;max-height:220px}.group-input-container:focus-within{border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}#groupMessageInput{width:100%;min-height:60px;max-height:200px;border:none;background:transparent;resize:none;font-size:14px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;color:#495057;outline:none;box-sizing:border-box}#groupMessageInput::-moz-placeholder{color:#95a5a6}#groupMessageInput::placeholder{color:#95a5a6}.group-input-buttons{display:flex;gap:10px;justify-content:flex-end;align-items:center}.group-input-buttons button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500}#sendGroupMessage{background-color:#3498db;color:#fff}#sendGroupMessage:hover:not(:disabled){background-color:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,152,219,.4)}#groupFileUploadButton,#groupImageUploadButton{background-color:#27ae60;color:#fff}#groupFileUploadButton:hover:not(:disabled),#groupImageUploadButton:hover:not(:disabled){background-color:#229954;transform:translateY(-1px);box-shadow:0 4px 12px rgba(39,174,96,.4)}.group-input-buttons button:disabled{background-color:#bdc3c7;color:#ecf0f1;cursor:not-allowed;transform:none;box-shadow:none}#groupMessageContainer::-webkit-scrollbar{width:6px}#groupMessageContainer::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}#groupMessageContainer::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}#groupMessageContainer::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.message{background:#fff;border-radius:10px;padding:12px 15px;margin-bottom:12px;box-shadow:0 2px 5px rgba(0,0,0,.1);max-width:80%;position:relative;animation:fadeIn .3s ease;min-height:auto;word-wrap:break-word}.message.own-message{background:#dcf8c6;margin-left:20%;max-width:80%;display:block}.message-header{display:flex;align-items:center;margin-bottom:5px;font-size:14px}.message-sender{font-weight:700;font-size:12px;color:#666}.message-time{color:#999;font-size:10px;position:absolute;right:15px;bottom:5px}.message-content{color:#343a40;line-height:1.4;word-wrap:break-word;margin-bottom:5px}.message-content p{margin:3px 0;line-height:1.4}.message-image{max-width:100%;max-height:300px;border-radius:8px;margin-top:5px;margin-bottom:5px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:2px solid transparent;-o-object-fit:contain;object-fit:contain}.message-image:hover{transform:scale(1.02);box-shadow:0 4px 12px rgba(0,0,0,.15);border-color:#07c160}.user-list li{display:flex;align-items:center;gap:10px}.friend-name{font-size:14px;color:#ecf0f1;flex:1;text-align:left}.friend-status{margin-left:auto}.user-avatar{display:flex;justify-content:center;align-items:center;width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;background-color:#3498db;color:#fff;font-weight:600;font-size:14px;overflow:hidden;position:relative}.user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.user-name{font-size:14px;color:#ecf0f1}.user-status{width:8px;height:8px;min-width:8px;min-height:8px;border-radius:50%;margin-left:auto}.user-status.online{background-color:#2ecc71}.user-status.offline{background-color:#95a5a6}.group-name{font-size:14px;color:#ecf0f1;font-weight:500;flex:1}.group-member-count{font-size:12px;color:#95a5a6}.unread-count{background-color:#e74c3c;color:#fff;font-size:12px;font-weight:700;border-radius:10px;min-width:20px;height:20px;display:flex;justify-content:center;align-items:center;padding:0 6px;box-shadow:0 2px 5px rgba(0,0,0,.2);transition:all .3s ease;z-index:10}.menu-item .unread-count{position:absolute;top:10px;right:10px}.menu-item[data-section=group-chat] .unread-count,.menu-item[data-section=public-chat] .unread-count{top:8px;right:20px}.user-list li.friend-item,.user-list li[data-group-id]{position:relative;display:flex;align-items:center;justify-content:space-between}.group-unread-count,.private-unread-count{position:static;margin-left:auto;margin-right:10px;font-size:11px;min-width:18px;height:18px;padding:0 5px}.unread-count:empty{display:none}.group-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background-color:#3498db;color:#fff;border-bottom:1px solid #2980b9}.group-header h2{margin:0;font-size:20px;font-weight:600}.group-actions{display:flex;gap:10px}.group-actions button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500;background-color:hsla(0,0%,100%,.2);color:#fff}.group-actions button:hover{background-color:hsla(0,0%,100%,.3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2)}#leaveGroupButton{background-color:rgba(231,76,60,.8)}#leaveGroupButton:hover{background-color:#e74c3c}.settings-container{display:flex;flex-direction:column;height:100%;padding:20px;background-color:#fafafa;overflow-y:auto}.settings-detail{background-color:#fff;border-radius:8px;padding:25px;box-shadow:0 2px 10px rgba(0,0,0,.1)}.settings-detail h2{margin:0 0 20px 0;font-size:24px;font-weight:600;color:#495057;border-bottom:1px solid #e9ecef;padding-bottom:10px}.group-avatar{display:flex;justify-content:center;align-items:center;width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;background-color:#3498db;color:#fff;font-weight:600;font-size:14px;overflow:hidden;position:relative;cursor:pointer;transition:all .3s ease}.group-avatar:hover{transform:scale(1.1);box-shadow:0 2px 8px rgba(0,0,0,.2)}.group-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}#groupList li{display:flex;align-items:center;padding:8px 6px;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:14px;margin-bottom:5px}#groupList li:hover{background-color:#2c3e50;transform:translateX(5px)}#groupList li.active{background-color:#3498db;color:#fff}#groupList li.active:hover{background-color:#2980b9}.settings-form{gap:20px}.form-group,.settings-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{font-size:14px;font-weight:600;color:#495057}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;color:#495057;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}.form-group textarea{resize:vertical;min-height:100px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.cancel-btn,.save-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500}.save-btn{background-color:#3498db;color:#fff}.save-btn:hover:not(:disabled){background-color:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,152,219,.4)}.save-btn:disabled{background-color:#bdc3c7;color:#ecf0f1;cursor:not-allowed;transform:none;box-shadow:none}.cancel-btn{background-color:#6c757d;color:#fff}.cancel-btn:hover{background-color:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px hsla(208,7%,46%,.4)}.avatar-upload-container{display:flex;flex-direction:column;align-items:center;gap:20px}.avatar-preview{width:150px;height:150px;border-radius:50%;border:2px dashed #dee2e6;display:flex;justify-content:center;align-items:center;background-color:#f8f9fa;overflow:hidden;position:relative}.avatar-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.no-avatar{color:#6c757d;font-size:14px;text-align:center}.avatar-upload-actions,.theme-options{display:flex;gap:10px}.theme-options{flex-direction:column}.theme-option{display:flex;align-items:center;gap:8px;padding:10px;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:400!important}.theme-option:hover{background-color:#f8f9fa;border-color:#3498db}.theme-option input[type=radio]{width:16px;height:16px;cursor:pointer}.shortcuts-list{display:flex;flex-direction:column;gap:15px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background-color:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}.shortcut-action{font-size:14px;color:#495057}.shortcut-key{background-color:#e9ecef;padding:4px 10px;border-radius:4px;font-size:13px;font-weight:600;color:#495057;border:1px solid #dee2e6}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal{display:none;position:fixed;z-index:1000;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);justify-content:center;align-items:center}.modal,.modal-content{top:0;animation:fadeIn .3s ease}.modal-content{background-color:#fff;padding:0;border:1px solid #888;width:400px;max-width:90%;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);position:relative;margin:0;transform:none}.modal-header{padding:15px 20px;background-color:#f5f5f5;border-bottom:1px solid #ddd;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:18px;color:#333}.close{color:#aaa;float:right;font-size:28px;font-weight:700;cursor:pointer;line-height:1}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer}.modal-body{padding:20px}.group-info-item{margin-bottom:15px;display:flex;align-items:center}.group-info-item label{width:100px;font-weight:700;color:#555}.group-info-item span{color:#333;flex:1}.modal-footer{padding:15px 20px;background-color:#f5f5f5;border-top:1px solid #ddd;border-radius:0 0 8px 8px;display:flex;justify-content:flex-end}.modal-footer button{margin-left:10px;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:background-color .2s ease}.modal-footer .cancel-btn{background-color:#f44336;color:#fff}.modal-footer .cancel-btn:hover{background-color:#d32f2f}.modal-footer .save-btn{background-color:#4caf50;color:#fff}.modal-footer .save-btn:hover{background-color:#45a049}.group-members-list{max-height:200px;overflow-y:auto;border:1px solid #dee2e6;border-radius:6px;padding:10px;background-color:#f8f9fa}.group-members-list .loading-members{text-align:center;color:#6c757d;font-style:italic;padding:20px}.member-item{display:flex;align-items:center;padding:8px;border-radius:4px;transition:background-color .2s ease}.member-item:hover{background-color:#e9ecef}.member-checkbox{margin-right:10px;transform:scale(1.1)}.member-nickname{font-weight:500;color:#495057}.create-group-message{margin-top:10px;padding:10px;border-radius:6px;font-size:14px;font-weight:500;text-align:center}.create-group-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.create-group-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message-content code{background-color:#f1f1f1;padding:2px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.message-content pre{background-color:#f8f9fa;border-radius:5px;overflow-x:auto;margin:0;border:1px solid #e9ecef;font-family:Courier New,monospace}.message-content pre code{background:none;padding:0;font-family:Courier New,monospace;white-space:pre-wrap;word-wrap:break-word}.message .message-content .file-link-container{display:flex!important;align-items:center!important;padding:12px!important;background-color:#f5f5f5!important;border-radius:8px!important;border:1px solid #ddd!important;max-width:100%!important;word-break:break-all!important;transition:all .3s!important;cursor:pointer!important;margin:5px 0!important;width:auto!important}.message .message-content .file-link-container .file-link{display:flex!important;align-items:center!important;color:#1890ff!important;text-decoration:none!important;border-bottom:none!important;font-size:14px!important;width:100%!important}.message .message-content .file-link-container .file-link:before{content:none!important;margin-right:0!important;display:none!important}.message .message-content .file-link-container .file-link span{display:inline-block!important;max-width:200px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.message .message-content .file-link-container:hover{background-color:#e9ecef!important;border-color:#adb5bd!important}.image-preview-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);z-index:2000;justify-content:center;align-items:center;animation:fadeIn .3s ease}.image-preview-content{max-width:90%;max-height:90%;display:flex;justify-content:center;align-items:center}.preview-img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.5)}.close-preview{position:absolute;top:20px;right:20px;color:#fff;font-size:30px;cursor:pointer;background:rgba(0,0,0,.5);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-preview:hover{background:rgba(0,0,0,.8);transform:scale(1.1)}.version-info{display:flex;flex-direction:column;gap:10px;padding:15px;background-color:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}.version-info p{margin:0;font-size:14px;color:#495057}.help-content{display:flex;flex-direction:column;gap:20px}.help-content h3{margin:0;font-size:18px;font-weight:600;color:#495057}.help-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.help-list li a{color:#3498db;text-decoration:none;font-size:14px;transition:all .3s ease}.help-list li a:hover{color:#2980b9;text-decoration:underline}.help-content p{margin:0;font-size:14px;color:#495057;line-height:1.5}.search-container{margin-top:10px;position:relative}.search-input{width:100%;padding:8px 12px;padding-right:30px;border:1px solid #2c3e50;border-radius:20px;background-color:#2c3e50;color:#fff;font-size:14px;box-sizing:border-box;transition:all .3s ease}.search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}.search-input::-moz-placeholder{color:#95a5a6}.search-input::placeholder{color:#95a5a6}.clear-search-btn{position:absolute;right:40px;top:50%;transform:translateY(-50%);background:none;border:none;color:#95a5a6;cursor:pointer;font-size:16px;padding:2px;border-radius:50%;transition:all .3s ease}.clear-search-btn:hover{color:#fff;background-color:#e74c3c}.create-group-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background-color:#4caf50;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background-color .3s ease}.create-group-btn:hover{background-color:#45a049}#chat-main{flex:1;display:flex;flex-direction:column;height:100%;background-color:#fff;box-shadow:0 0 10px rgba(0,0,0,.1);position:relative;overflow:hidden}.markdown-toolbar{display:flex;flex-wrap:wrap;padding:10px 15px;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;gap:8px;box-sizing:border-box;z-index:10;pointer-events:auto}#markdownToolbar{position:absolute;top:0;left:0;right:0;width:100%;z-index:100}#groupMarkdownToolbar{position:relative;width:100%}.markdown-btn{background-color:#fff;border:1px solid #dee2e6;border-radius:4px;padding:6px 12px;font-size:14px;cursor:pointer;transition:all .3s ease;color:#495057}.markdown-btn:hover{background-color:#e9ecef;border-color:#3498db;transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}#groupMessageContainer,#messageContainer{flex:1 1 auto;overflow-y:auto;padding:10px;background-color:#fafafa;display:flex;flex-direction:column;min-height:0;position:relative;margin-bottom:0}.empty-state{height:100%}.empty-state h3{margin:0 0 10px 0;font-size:20px}.empty-state p{margin:0}.input-area{display:flex;flex-direction:column;padding:15px;background-color:#fff;border-top:1px solid #e9ecef;gap:10px}.chat-content.active{margin-bottom:0!important;padding-bottom:0!important;overflow:hidden}.input-buttons .more-button{pointer-events:auto;z-index:100;position:relative;background-color:#95a5a6;color:#fff;border:none;border-radius:5px;padding:8px 15px;cursor:pointer;font-size:14px;transition:background-color .3s}.input-buttons .more-button:hover{background-color:#7f8c8d}.more-functions.show{display:flex}.input-container{position:relative;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:10px;transition:all .3s ease;max-height:220px}.input-container:focus-within{border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}#groupMessageInput,#messageInput,#privateMessageInput,.editable-div{width:100%;min-height:60px;max-height:200px;border:none;background:transparent;resize:none;font-size:14px;font-weight:500;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;color:#495057;outline:none;box-sizing:border-box;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}#groupMessageInput[placeholder]:empty:before,#messageInput[placeholder]:empty:before,#privateMessageInput[placeholder]:empty:before{content:attr(placeholder);color:#95a5a6!important;pointer-events:none!important;display:inline-block!important;font-style:normal!important;font-size:14px!important;font-weight:500!important;line-height:1.5!important}#groupMessageInput[placeholder]:empty:focus:before,#messageInput[placeholder]:empty:focus:before,#privateMessageInput[placeholder]:empty:focus:before{content:attr(placeholder);color:#95a5a6!important;pointer-events:none!important;display:inline-block!important}#groupMessageInput,#messageInput,#privateMessageInput{min-height:60px;padding:0;margin:0;border:none;outline:none;background:transparent;overflow:hidden;white-space:pre-wrap;word-wrap:break-word}#groupMessageInput:empty,#messageInput:empty,#privateMessageInput:empty{content:""}.editable-div:focus{outline:none}.editable-div{padding:0;margin:0;display:block;font:inherit;text-align:left;word-break:break-word}#messageInput::-moz-placeholder{color:#95a5a6}#messageInput::placeholder{color:#95a5a6}.input-buttons{display:flex;gap:10px;justify-content:flex-end;align-items:center}.input-buttons button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500}#sendButton{background-color:#3498db;color:#fff}#sendButton:hover:not(:disabled){background-color:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,152,219,.4)}#fileUploadButton,#imageUploadButton{background-color:#27ae60;color:#fff}#fileUploadButton:hover:not(:disabled),#imageUploadButton:hover:not(:disabled){background-color:#229954;transform:translateY(-1px);box-shadow:0 4px 12px rgba(39,174,96,.4)}.input-buttons button:disabled{background-color:#bdc3c7;color:#ecf0f1}.more-button{background-color:#95a5a6!important;color:#fff}.more-button:hover:not(:disabled){background-color:#7f8c8d!important;transform:translateY(-1px);box-shadow:0 4px 12px hsla(184,9%,62%,.4)}.more-functions{display:none;flex-direction:row;flex-wrap:wrap;gap:10px;margin-top:10px;padding:10px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;width:100%;justify-content:flex-start}.more-functions.show{display:flex!important}.more-functions button{margin:0;padding:8px 16px;background-color:#3498db;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .3s ease}.more-functions button:hover:not(:disabled){background-color:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,152,219,.4)}#privateSendGroupCardButton,#sendGroupCardButton,#sendGroupCardButtonGroup{background-color:#e67e22!important;color:#fff}#privateSendGroupCardButton:hover:not(:disabled),#sendGroupCardButton:hover:not(:disabled),#sendGroupCardButtonGroup:hover:not(:disabled){background-color:#d35400!important;transform:translateY(-1px);box-shadow:0 4px 12px rgba(230,126,34,.4)}.input-container.lifted{transform:translateY(0);transition:transform .3s ease}.input-buttons button:disabled{cursor:not-allowed;transform:none;box-shadow:none}.button-text{font-size:13px}.upload-progress{height:3px;background-color:#e9ecef;border-radius:2px;overflow:hidden;display:none}.upload-progress-bar{height:100%;background-color:#3498db;width:0;transition:width .3s ease}#groupCardPopup,#groupCardPopup *,#sendGroupCardModal .modal-body p,.group-card-container,.group-card-container *,.send-group-card-container,.send-group-card-container *,.send-group-card-container p,.send-group-card-item,.send-group-card-item *{color:#333!important}#messageContainer::-webkit-scrollbar,#secondary-sidebar::-webkit-scrollbar{width:6px}#messageContainer::-webkit-scrollbar-track,#secondary-sidebar::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}#messageContainer::-webkit-scrollbar-thumb,#secondary-sidebar::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}#messageContainer::-webkit-scrollbar-thumb:hover,#secondary-sidebar::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.group-members-container{max-height:300px;overflow-y:auto;margin:20px 0;border:1px solid #e9ecef;border-radius:8px;padding:15px;background-color:#f8f9fa}.group-member-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e9ecef}.group-member-item:last-child{border-bottom:none}.group-member-info{display:flex;align-items:center;gap:12px;flex:1}.group-member-name{font-weight:500;color:#343a40;font-size:14px}.group-member-id{color:#6c757d;font-size:12px;margin-left:auto}.group-member-role{color:#1971c2;font-size:12px;font-weight:600;margin-left:5px}.kick-member-btn{background-color:#dc3545;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer;transition:all .3s ease;font-weight:500}.kick-member-btn:hover{background-color:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px rgba(220,53,69,.3)}.group-manage-section{margin-top:20px;padding-top:20px;border-top:1px solid #e9ecef}.group-manage-section h3{margin:0 0 15px 0;font-size:16px;color:#343a40;font-weight:600}.group-manage-buttons{display:flex;gap:10px;margin-top:15px}.group-manage-buttons button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.group-manage-buttons button.save-btn{background-color:#4caf50;color:#fff}.group-manage-buttons button.save-btn:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:0 4px 12px rgba(76,175,80,.3)}.group-member-role.owner{color:#e67e22;font-weight:600}.loading-members{color:#6c757d;font-style:italic;text-align:center;padding:20px}.loading-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#6c757d;font-size:14px;text-align:center;min-height:200px}.loading-spinner{width:40px;height:40px;border:4px solid rgba(13,110,253,.1);border-radius:50%;border-top-color:#0d6efd;animation:spin 1s ease-in-out infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{font-size:14px;color:#6c757d;font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;min-height:200px;color:#6c757d}.empty-state h3{font-size:18px;font-weight:600;margin-bottom:8px;color:#212529}.empty-state p{font-size:14px;margin-bottom:16px;color:#6c757d}.error-state{background-color:#fef2f2;border:1px solid #fee2e2;border-radius:8px}.error-icon{font-size:48px;margin-bottom:16px;color:#dc3545}.retry-button{background-color:#0d6efd;color:#fff;border:none;border-radius:4px;padding:8px 16px;font-size:14px;cursor:pointer;transition:background-color .2s ease}.retry-button:hover{background-color:#0b5ed7}.highlight{position:relative;margin:10px 0;border-radius:8px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.1)}.highlight-tools{display:flex;align-items:center;padding:8px 12px;background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.macStyle{display:flex;gap:8px;margin-right:12px}.mac-close,.mac-maximize,.mac-minimize{width:12px;height:12px;border-radius:50%}.mac-close{background-color:#ff5f57}.mac-minimize{background-color:#ffbd2e}.mac-maximize{background-color:#28ca42}.code-lang{flex:1;font-weight:500}.code-lang,.copy-notice{font-size:12px;color:#666}.copy-notice{margin-right:10px;display:none}.copy-button,.fullpage-button{cursor:pointer;margin-left:10px;color:#666;font-size:14px;transition:color .2s}.copy-button:hover,.fullpage-button:hover{color:#333}.highlight table{width:100%;border-collapse:collapse;background-color:#fff}.highlight .gutter{background-color:#f8f9fa;border-right:1px solid #e9ecef;padding:0;text-align:right;width:40px;-webkit-user-select:none;-moz-user-select:none;user-select:none;vertical-align:top}.highlight .gutter pre{margin:0;padding:10px 0;background-color:#f8f9fa;color:#666;font-size:14px;font-family:Courier New,monospace;line-height:1.5}.highlight .code{padding:0;width:100%;vertical-align:top}.highlight .code pre{margin:0;padding:0;overflow-x:auto;background-color:#fff;line-height:1.5}.highlight .code code,.highlight .code pre{font-size:14px;font-family:Courier New,monospace;white-space:pre}.highlight .code code{background:none;padding:10px;display:block}.highlight .line{font-size:14px;line-height:1.5;display:block;padding:0 10px;margin:0}#mobile-chat{display:none;flex-direction:column;width:100vw;height:100vh;background-color:#fff;position:relative;overflow:hidden}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;background-color:#2c3e50;color:#fff;height:60px;box-sizing:border-box;box-shadow:0 2px 5px rgba(0,0,0,.1);z-index:100}.mobile-header .menu-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:5px}.mobile-header h1{margin:0;font-size:18px;font-weight:600}.mobile-sidebar{position:fixed;top:0;left:-300px;width:250px;height:100vh;background-color:#34495e;color:#fff;transition:left .3s ease;z-index:200;box-shadow:2px 0 10px rgba(0,0,0,.2);overflow-y:auto}.mobile-sidebar.active{left:0}.mobile-sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:rgba(0,0,0,.5);z-index:150;display:none}.mobile-sidebar-overlay.active{display:block}.mobile-sidebar-header{padding:20px;border-bottom:1px solid #2c3e50;text-align:center}.mobile-sidebar-header .user-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 10px;overflow:hidden;border:2px solid #3498db}.mobile-sidebar-header .user-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mobile-sidebar-header .user-info{text-align:center}.mobile-menu-list{list-style:none;padding:0;margin:0}.mobile-menu-item{padding:15px 20px;cursor:pointer;border-bottom:1px solid #2c3e50;transition:background-color .2s ease;display:flex;align-items:center;gap:10px}.mobile-menu-item:hover{background-color:#2c3e50}.mobile-menu-item.active{background-color:#3498db}.mobile-message-container{flex:1;overflow-y:auto;padding:10px;background-color:#fafafa;min-height:0}.mobile-input-area{padding:15px;background-color:#fff;border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:10px}.mobile-input-container{position:relative;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:25px;padding:10px 15px;transition:all .3s ease}.mobile-input-container:focus-within{border-color:#3498db;box-shadow:0 0 0 2px rgba(52,152,219,.2)}#mobileMessageInput{width:100%;min-height:40px;max-height:150px;border:none;background:transparent;resize:none;font-size:14px;font-weight:500;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;color:#495057;outline:none;box-sizing:border-box;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}#mobileMessageInput:empty:before{content:attr(placeholder);color:#95a5a6;pointer-events:none;display:inline-block}.mobile-input-buttons{display:flex;gap:10px;justify-content:flex-end;align-items:center}.mobile-input-buttons button{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:20px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500}#mobileSendButton{background-color:#3498db;color:#fff}#mobileSendButton:hover:not(:disabled){background-color:#2980b9;transform:scale(1.05)}.mobile-message{background:#fff;border-radius:10px;padding:12px 15px;margin-bottom:12px;box-shadow:0 2px 5px rgba(0,0,0,.1);max-width:80%;position:relative;word-wrap:break-word}.mobile-message.own-message{background:#dcf8c6;margin-left:20%}.mobile-message-sender{font-weight:700;font-size:12px;color:#666;margin-bottom:5px}.mobile-message-content{color:#343a40;line-height:1.4;margin-bottom:5px}.mobile-message-time{color:#999;font-size:10px;position:absolute;right:15px;bottom:5px}#mobile-group-chat{display:none;flex-direction:column;height:100%;width:100%}.mobile-loading{text-align:center;padding:20px;color:#6c757d}.mobile-empty-state{text-align:center;padding:40px 20px;color:#6c757d}.mobile-empty-state h3{margin:0 0 10px 0;font-size:18px;color:#495057}.mobile-empty-state p{margin:0;font-size:14px;line-height:1.5}