*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333;background-color:#f5f5f5}:root{--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s;--transition-slower: .4s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes bubbleInSent{0%{opacity:0;transform:scale(.88) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bubbleInReceived{0%{opacity:0;transform:scale(.88) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(12px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes highlightPulse{0%{background-color:#07c16059}to{background-color:transparent}}@keyframes badgePop{0%{transform:translate(12px) scale(0)}70%{transform:translate(12px) scale(1.2)}to{transform:translate(12px) scale(1)}}@keyframes loginBoxIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes lineGrow{0%{width:0}to{width:60px}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*,*:before,*:after{transition-timing-function:var(--ease-default)!important}.wechat-green{color:#07c160}.wechat-green-bg{background-color:#07c160}.login-container,.register-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);position:relative;overflow:hidden}.login-container:before,.register-container:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#07c1601a;top:-150px;right:-150px}.login-container:after,.register-container:after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:#07c16014;bottom:-100px;left:-100px}.login-box,.register-box{width:400px;padding:45px;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;position:relative;z-index:10;transition:transform var(--transition-slow) var(--ease-spring),box-shadow var(--transition-slow) var(--ease-default)!important;animation:loginBoxIn .45s var(--ease-spring) both}.login-box:hover,.register-box:hover{transform:translateY(-4px);box-shadow:0 18px 40px #00000024}.beian-info{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:12px;color:#999;z-index:10}.beian-info a{color:#999;text-decoration:none;transition:color var(--transition-fast) var(--ease-default)!important}.beian-info a:hover{color:#07c160;text-decoration:underline}.logo{text-align:center;margin-bottom:40px;position:relative;animation:fadeIn .5s var(--ease-out) both}.logo h1{font-size:32px;color:#07c160;font-weight:700;margin:0;position:relative;display:inline-block}.logo h1:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,#07c160,#06b355);border-radius:3px;animation:lineGrow .5s var(--ease-out) .4s both}.login-form .form-group:nth-child(1){animation:slideInUp .35s var(--ease-out) .05s both}.login-form .form-group:nth-child(2){animation:slideInUp .35s var(--ease-out) .12s both}.login-form .btn-primary{animation:slideInUp .35s var(--ease-out) .19s both}.login-form .forgot-password{animation:slideInUp .35s var(--ease-out) .26s both}.login-form .register-link{animation:slideInUp .35s var(--ease-out) .33s both}@keyframes slideInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:25px;position:relative}.form-control{height:50px;border-radius:8px;border:1px solid #e0e0e0;padding:0 20px;font-size:15px;background-color:#fafafa;width:100%;transition:border-color var(--transition-base) var(--ease-default),box-shadow var(--transition-base) var(--ease-default),background-color var(--transition-base) var(--ease-default),transform var(--transition-base) var(--ease-default)!important}.form-control:focus{border-color:#07c160;box-shadow:0 0 0 .2rem #07c16040;background-color:#fff;transform:translateY(-1px);outline:none}.btn{padding:8px 16px;border-radius:4px;cursor:pointer;border:none;font-size:14px;transition:background-color var(--transition-base) var(--ease-default),transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default),color var(--transition-base) var(--ease-default),border-color var(--transition-base) var(--ease-default),opacity var(--transition-base) var(--ease-default)!important}.btn-primary{background:linear-gradient(135deg,#07c160,#06b355);border:none;height:50px;font-size:16px;font-weight:700;border-radius:8px;box-shadow:0 4px 15px #07c1604d;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#06b355,#05a04a);transform:translateY(-2px);box-shadow:0 6px 20px #07c16066}.btn-primary:active{transform:translateY(0) scale(.98);box-shadow:0 2px 10px #07c1604d}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.btn-light{background-color:#f5f5f5;color:#333}.btn-light:hover{background-color:#e2e6ea}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-danger:active{background-color:#bd2130}.w-100{width:100%}.mt-2{margin-top:8px}.forgot-password{text-align:right;margin-top:15px}.forgot-password a,.back-link a{color:#07c160;text-decoration:none;font-size:14px;transition:color var(--transition-fast) var(--ease-default)!important}.register-link,.login-link,.admin-link{text-align:center;margin-top:25px;font-size:14px;color:#666}.register-link a,.login-link a,.admin-link a{color:#07c160;text-decoration:none;font-weight:700;transition:color var(--transition-fast) var(--ease-default)!important}.main-container{display:flex;height:100vh;background-color:#f5f5f5}.sidebar{width:80px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column}.sidebar-header{padding:15px;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;align-items:center}.sidebar-header .avatar{width:50px;height:50px;border-radius:4px;margin-bottom:8px;background-size:cover;background-position:center;background-color:#07c160;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default)!important}.sidebar-header .avatar:hover{transform:scale(1.06);box-shadow:0 2px 8px #07c16040}.sidebar-header .avatar-text{color:#fff;font-size:20px;font-weight:500}.nav-item{padding:15px 0;cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default)!important;display:flex;flex-direction:column;align-items:center;position:relative}.nav-item:hover{background-color:#f5f5f5}.nav-item.active{background-color:#e8f5e8;color:#07c160;font-weight:700}.search-box{padding:10px;border-bottom:1px solid #e0e0e0}.search-input{width:100%;padding:8px 15px;border:1px solid #e0e0e0;border-radius:18px;background-color:#f5f5f5;font-size:14px;transition:border-color var(--transition-base) var(--ease-default),box-shadow var(--transition-base) var(--ease-default),background-color var(--transition-base) var(--ease-default)!important}.search-input:focus{outline:none;border-color:#07c160;background-color:#fff}.friend-list{flex:1;overflow-y:auto}.friend-item{padding:10px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default)!important;position:relative}.friend-item:hover{background-color:#f5f5f5}.friend-item.active{background-color:#e8f5e8}.friend-item .avatar{width:50px;height:50px;border-radius:4px;margin-right:10px;background-size:cover;background-position:center;background-color:#07c160;display:flex;align-items:center;justify-content:center}.friend-item .avatar-text{color:#fff;font-size:20px;font-weight:500}.friend-item .friend-info{flex:1;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.friend-item .friend-name{font-weight:700;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-item .last-message{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-item .message-time{font-size:10px;color:#999;position:absolute;right:10px;top:10px}.friend-item .friend-status{font-size:12px;color:#07c160}.contact-section{margin-bottom:20px}.section-header{padding:5px 10px;background-color:#f5f5f5;font-size:12px;font-weight:700;color:#666}.chat-area{flex:1;display:flex;flex-direction:column;background-color:#f5f5f5;min-height:0;overflow:visible}.chat-header{padding:15px;background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.chat-header .friend-info{display:flex;align-items:center}.chat-header .avatar{width:40px;height:40px;border-radius:4px;margin-right:15px;background-size:cover;background-position:center;background-color:#07c160;display:flex;align-items:center;justify-content:center}.chat-header .avatar-text{color:#fff;font-size:16px;font-weight:500}.chat-header .friend-name{font-weight:700}.chat-header .friend-status{font-size:12px;color:#999}.chat-header .action-buttons{display:flex;gap:10px}.chat-content{flex:1;padding:20px;overflow-y:auto;background-color:#f5f5f5;min-height:0;overflow:visible}.message-item{margin-bottom:15px;display:flex;animation:bubbleIn .25s var(--ease-out) both}.message-item.sent{justify-content:flex-end;animation-name:bubbleInSent}.message-item.received{justify-content:flex-start;animation-name:bubbleInReceived}@keyframes bubbleIn{0%{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bubbleInSent{0%{opacity:0;transform:scale(.92) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bubbleInReceived{0%{opacity:0;transform:scale(.92) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.message-item .avatar{width:36px;height:36px;border-radius:4px;margin:0 10px;background-size:cover;background-position:center;background-color:#07c160;display:flex;align-items:center;justify-content:center}.message-item .avatar-text{color:#fff;font-size:14px;font-weight:500}.message-item .message-content-wrapper{display:flex;flex-direction:column;max-width:60%}.message-item .message-content{padding:10px 15px;border-radius:18px;word-wrap:break-word;word-break:break-all;white-space:pre-wrap}.message-item.sent .message-content{background-color:#06ad56;color:#fff;border-bottom-right-radius:4px}.message-item.sent .message-content *{color:#fff!important}.message-item.received .message-content{background-color:#fff;color:#333;border-bottom-left-radius:4px;border:1px solid #e0e0e0}.message-item .message-meta{display:flex;align-items:center;font-size:11px;margin-top:4px;padding:0 4px}.message-item.sent .message-meta{justify-content:flex-end;color:#a0d6b4}.message-item.sent .message-time{color:#a0d6b4}.message-item.received .message-meta{color:#999}.message-item .message-time{color:inherit}.message-item .message-status{margin-left:6px}.chat-input-area{padding:15px;background-color:#fff;border-top:1px solid #e0e0e0;display:flex;flex-direction:column}.chat-input-tools{display:flex;gap:15px;margin-bottom:10px}.tool-button{width:36px;height:36px;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:background-color var(--transition-fast) var(--ease-default)!important}.tool-button:hover{background-color:#f0f0f0}.tool-button.active{background-color:#e8f5e9}.ttl-tool-button{position:relative}.ttl-badge{position:absolute;top:-4px;right:-4px;background:#07c160;color:#fff;font-size:9px;padding:1px 4px;border-radius:8px;min-width:12px;text-align:center}.chat-input{display:flex;align-items:flex-end;gap:10px}.chat-input textarea{flex:1;border:1px solid #e0e0e0;border-radius:4px;padding:10px;resize:none;min-height:40px;max-height:300px;font-family:inherit;font-size:14px;overflow-y:auto;transition:border-color var(--transition-base) var(--ease-default)!important}.chat-input textarea:focus{outline:none;border-color:#07c160}.send-button{background-color:#07c160;color:#fff;border:none;border-radius:4px;padding:0 20px;height:40px;cursor:pointer;font-weight:700;transition:background-color var(--transition-base) var(--ease-default)!important}.send-button:hover{background-color:#06b355}.right-sidebar{width:300px;background-color:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;animation:panelSlideIn .25s var(--ease-out) both}@keyframes panelSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.right-sidebar-header{padding:15px;border-bottom:1px solid #e0e0e0;font-weight:700}.right-sidebar-content{flex:1;padding:15px;overflow-y:auto}.notification-container{display:flex;height:100vh;background-color:#f5f5f5;animation:panelSlideIn .25s var(--ease-out) both}.notification-sidebar{width:200px;background-color:#fff;border-right:1px solid #e0e0e0}.notification-sidebar-item{padding:15px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color var(--transition-fast) var(--ease-default)!important}.notification-sidebar-item:hover{background-color:#f5f5f5}.notification-sidebar-item.active{background-color:#e8f5e8;color:#07c160;font-weight:700}.notification-content{flex:1;padding:20px;overflow-y:auto}.notification-item{background-color:#fff;padding:15px;border-radius:8px;margin-bottom:15px;box-shadow:0 2px 4px #0000000d;transition:transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default),background-color var(--transition-base) var(--ease-default)!important}.notification-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.notification-item .notification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.notification-item .notification-title{font-weight:700}.notification-item .notification-time{font-size:12px;color:#999}.notification-item .notification-content{color:#666;line-height:1.4}.profile-container{display:flex;height:100vh;background-color:#f5f5f5;animation:panelSlideIn .25s var(--ease-out) both}.profile-sidebar{width:200px;background-color:#fff;border-right:1px solid #e0e0e0}.profile-sidebar-item{padding:15px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color var(--transition-fast) var(--ease-default)!important}.profile-sidebar-item:hover{background-color:#f5f5f5}.profile-sidebar-item.active{background-color:#e8f5e8;color:#07c160;font-weight:700}.profile-content{flex:1;padding:20px;overflow-y:auto}.profile-section{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000000d;transition:transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default)!important}.profile-section:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.profile-section h3{margin-bottom:20px;font-size:16px;font-weight:700}.profile-form .form-group{margin-bottom:15px}.profile-form label{display:block;margin-bottom:5px;font-weight:700;font-size:14px}.profile-avatar{text-align:center;margin-bottom:20px}.profile-avatar .avatar{width:100px;height:100px;border-radius:0;margin:0 auto 10px;background-size:cover;background-position:center}.profile-avatar .avatar-upload{color:#666;cursor:pointer;font-size:14px}.add-friend-container{display:flex;height:100vh;background-color:#f5f5f5;animation:panelSlideIn .25s var(--ease-out) both}.add-friend-content{flex:1;padding:40px;display:flex;flex-direction:column}.add-friend-header{margin-bottom:30px}.add-friend-header h2{font-size:20px;font-weight:700}.add-friend-search{margin-bottom:30px}.add-friend-search .search-input{width:100%;padding:12px 15px;border:1px solid #e0e0e0;border-radius:25px;font-size:14px}.add-friend-results{flex:1;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.search-result-item{padding:15px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;transition:transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default),background-color var(--transition-base) var(--ease-default)!important}.search-result-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.search-result-item .user-info{display:flex;align-items:center}.search-result-item .avatar{width:50px;height:50px;border-radius:0;margin-right:15px;background-size:cover;background-position:center}.search-result-item .user-name{font-weight:700}.search-result-item .user-id{font-size:12px;color:#999}.search-result-item .add-button{background-color:#07c160;color:#fff;border:none;border-radius:18px;padding:6px 20px;font-size:14px;cursor:pointer;transition:background-color var(--transition-base) var(--ease-default)!important}.search-result-item .add-button:hover{background-color:#06b355}.file-transfer-container{display:flex;height:100vh;background-color:#f5f5f5;animation:panelSlideIn .25s var(--ease-out) both}.file-transfer-content{flex:1;padding:40px;display:flex;flex-direction:column}.file-transfer-header{margin-bottom:30px}.file-transfer-header h2{font-size:20px;font-weight:700}.file-upload-area{border:2px dashed #e0e0e0;border-radius:8px;padding:40px;text-align:center;margin-bottom:30px;cursor:pointer;transition:border-color var(--transition-base) var(--ease-default)!important}.file-upload-area:hover{border-color:#07c160}.file-upload-area .upload-icon{font-size:48px;color:#07c160;margin-bottom:15px}.file-upload-area .upload-text{font-size:16px;color:#666;margin-bottom:10px}.file-upload-area .upload-hint{font-size:12px;color:#999}.file-list{flex:1;background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.file-item{padding:15px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;transition:transform var(--transition-base) var(--ease-spring),box-shadow var(--transition-base) var(--ease-default),background-color var(--transition-base) var(--ease-default)!important}.file-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.file-item .file-info{display:flex;align-items:center}.file-item .file-icon{font-size:24px;color:#07c160;margin-right:15px}.file-item .file-name{font-weight:700;margin-bottom:5px}.file-item .file-size{font-size:12px;color:#999}.file-item .file-actions{display:flex;gap:10px}.file-item .progress-bar{width:100%;height:6px;background-color:#f0f0f0;border-radius:3px;margin-top:10px;overflow:hidden}.file-item .progress-bar .progress{height:100%;background-color:#07c160;border-radius:3px;transition:width .3s}.custom-context-menu{position:fixed;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 10px #0000001a;z-index:10000}.custom-context-menu ul{list-style:none;padding:5px 0}.custom-context-menu li{padding:8px 20px;cursor:pointer;font-size:14px;transition:background-color var(--transition-fast) var(--ease-default)!important}.custom-context-menu li:hover{background-color:#f5f5f5}@media (max-width: 1200px){.right-sidebar{display:none}}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000000b8;color:#fff;padding:10px 14px;border-radius:6px;z-index:10001;font-size:14px;max-width:min(90vw,520px);white-space:pre-wrap;animation:toastIn .25s var(--ease-spring) both}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nav-badge{animation:badgePop .3s var(--ease-spring)}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #07C160;border-radius:50%;animation:spin 1s linear infinite}.error-message{color:#ff4d4f;font-size:12px;margin-top:5px}.success-message{color:#07c160;font-size:12px;margin-top:5px}.toast-stack[data-v-60060fd5]{position:fixed;left:50%;bottom:20px;transform:translate(-50%);z-index:10001;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast-item[data-v-60060fd5]{background:#000000b8;color:#fff;padding:10px 14px;border-radius:6px;font-size:14px;max-width:min(90vw,520px);white-space:pre-wrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.toast-enter-active[data-v-60060fd5]{transition:opacity .25s var(--ease-spring),transform .25s var(--ease-spring)}.toast-leave-active[data-v-60060fd5]{transition:opacity .2s var(--ease-in),transform .2s var(--ease-in)}.toast-enter-from[data-v-60060fd5]{opacity:0;transform:translateY(12px) scale(.95)}.toast-leave-to[data-v-60060fd5]{opacity:0;transform:translateY(-6px) scale(.96)}.toast-move[data-v-60060fd5]{transition:transform .25s var(--ease-spring)}.login-container[data-v-305a4695]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.login-box[data-v-305a4695]{width:400px;padding:40px;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;animation:adminLoginIn-305a4695 .45s var(--ease-spring) both}@keyframes adminLoginIn-305a4695{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.logo[data-v-305a4695]{text-align:center;margin-bottom:32px;animation:fadeIn-305a4695 .5s var(--ease-out) both}.logo h1[data-v-305a4695]{font-size:36px;font-weight:700;color:#07c160;margin:0}.logo-sub[data-v-305a4695]{font-size:14px;color:#666;margin-top:8px}.login-form[data-v-305a4695]{animation:slideInUp-305a4695 .4s var(--ease-out) .15s both}.login-form .form-group[data-v-305a4695]{margin-bottom:20px}.login-form .form-group[data-v-305a4695]:nth-child(1){animation:slideInUp-305a4695 .35s var(--ease-out) .05s both}.login-form .form-group[data-v-305a4695]:nth-child(2){animation:slideInUp-305a4695 .35s var(--ease-out) .12s both}.login-form .btn-primary[data-v-305a4695]{animation:slideInUp-305a4695 .35s var(--ease-out) .19s both}.login-form .back-link[data-v-305a4695]{animation:slideInUp-305a4695 .35s var(--ease-out) .26s both}@keyframes slideInUp-305a4695{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn-305a4695{0%{opacity:0}to{opacity:1}}.form-control[data-v-305a4695]{width:100%;padding:12px 16px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;transition:border-color .2s var(--ease-default),box-shadow .2s var(--ease-default),transform .2s var(--ease-default)!important}.form-control[data-v-305a4695]:focus{outline:none;border-color:#07c160;box-shadow:0 0 0 .2rem #07c16040;transform:translateY(-1px)}.btn[data-v-305a4695]{padding:12px 24px;border-radius:6px;font-size:16px;cursor:pointer;transition:background .2s var(--ease-default),transform .2s var(--ease-spring),box-shadow .2s var(--ease-default)!important}.btn-primary[data-v-305a4695]{background:#07c160;color:#fff;border:none;box-shadow:0 4px 12px #07c1604d}.btn-primary[data-v-305a4695]:hover{background:#06ad56;transform:translateY(-2px);box-shadow:0 6px 18px #07c16066}.btn-primary[data-v-305a4695]:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #07c1604d}.btn-primary[data-v-305a4695]:disabled{background:#a8dcc0;cursor:not-allowed}.w-100[data-v-305a4695]{width:100%}.back-link[data-v-305a4695]{text-align:center;margin-top:16px}.back-link a[data-v-305a4695]{color:#07c160;text-decoration:none;font-size:14px;transition:color .15s var(--ease-default)!important}.back-link a[data-v-305a4695]:hover{color:#06ad56;text-decoration:underline}.friend-item[data-v-9bd1b59e]{cursor:pointer;position:relative}.friend-item[data-v-9bd1b59e]:hover{background-color:#f5f5f5}.friend-item.active[data-v-9bd1b59e]{background-color:#e6f7ff}.friend-item.pinned[data-v-9bd1b59e]{background:#f0f8f5}.pinned-icon[data-v-9bd1b59e]{color:#07c160;margin-right:4px;font-size:12px}.avatar[data-v-9bd1b59e]{position:relative;width:40px;height:40px;border-radius:4px;background-color:#07c160;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700;flex-shrink:0}.avatar-text[data-v-9bd1b59e]{font-size:16px;font-weight:500}.unread-badge[data-v-9bd1b59e]{position:absolute;top:-4px;right:-4px;background:#ff4d4f;color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #fff}.custom-context-menu{position:fixed;z-index:10000}.custom-context-menu ul{list-style:none;margin:0;padding:5px 0;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000026;min-width:180px}.custom-context-menu li{padding:8px 16px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px}.custom-context-menu li:hover{background:#f5f5f5}.custom-context-menu .divider{height:1px;background:#e0e0e0;margin:5px 0;padding:0;cursor:default}.custom-context-menu .divider:hover{background:#e0e0e0}.status-online[data-v-bbef3be8]{color:#07c160}.status-offline[data-v-bbef3be8]{color:#999;font-size:12px}.preview-modal[data-v-8fc31686]{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999}.preview-content[data-v-8fc31686]{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.close-btn[data-v-8fc31686]{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:5px 10px;line-height:1}.close-btn[data-v-8fc31686]:hover{color:#ccc}.preview-image[data-v-8fc31686]{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px}.preview-video[data-v-8fc31686]{max-width:90vw;max-height:90vh;border-radius:4px}.attachment-preview[data-v-64f8577b]{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}.attachment-block.file-block[data-v-64f8577b]{display:flex;align-items:center;padding:10px;background:#0000000a;border-radius:6px;cursor:pointer}.attachment-block.file-block[data-v-64f8577b]:hover{background:#00000014}.video-block[data-v-64f8577b]{max-width:100%;width:200px;height:150px;border-radius:6px;overflow:hidden;cursor:pointer;background:#333}.video-cover[data-v-64f8577b]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#444,#222)}.play-icon[data-v-64f8577b]{font-size:48px;color:#fff;opacity:.9}.video-label[data-v-64f8577b]{margin-top:8px;font-size:12px;color:#ccc}.video-preview[data-v-64f8577b]{width:100%;height:100%;object-fit:cover;display:block}.video-click-area[data-v-64f8577b]{position:relative;display:block;width:100%;height:100%}.video-play-icon-overlay[data-v-64f8577b]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;pointer-events:none;z-index:10}.video-block img.video-preview[data-v-64f8577b]{width:100%;height:100%;object-fit:cover}.password-overlay[data-v-64f8577b]{width:200px;height:150px;border-radius:6px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;cursor:pointer}.password-dialog-overlay[data-v-64f8577b]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.password-dialog[data-v-64f8577b]{background:#fff;border-radius:8px;padding:24px;width:320px;box-shadow:0 4px 20px #0003}.password-dialog-title[data-v-64f8577b]{font-size:16px;font-weight:700;margin-bottom:16px;text-align:center}.password-input[data-v-64f8577b]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box}.password-input[data-v-64f8577b]:focus{outline:none;border-color:#667eea}.password-dialog-error[data-v-64f8577b]{color:#e74c3c;font-size:12px;margin-top:8px}.password-dialog-buttons[data-v-64f8577b]{display:flex;gap:12px;margin-top:16px}.password-dialog-buttons .btn[data-v-64f8577b]{flex:1}.uploading-overlay[data-v-64f8577b]{width:200px;height:150px;border-radius:6px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.failed-overlay[data-v-64f8577b]{width:200px;height:150px;border-radius:6px;background:linear-gradient(135deg,#e74c3c,#c0392b);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;cursor:pointer}.uploading-spinner[data-v-64f8577b]{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-64f8577b 1s linear infinite}.uploading-spinner-small[data-v-64f8577b]{width:20px;height:20px;border:2px solid rgba(0,0,0,.1);border-top-color:#666;border-radius:50%;animation:spin-64f8577b 1s linear infinite}@keyframes spin-64f8577b{to{transform:rotate(360deg)}}.message-list[data-v-1727de71]{animation:fadeInList-1727de71 .3s var(--ease-out) both}@keyframes fadeInList-1727de71{0%{opacity:0}to{opacity:1}}.message-list[data-v-1727de71] .highlight{animation:highlightPulse-1727de71 2s ease-out}@keyframes highlightPulse-1727de71{0%{background-color:#07c1604d}to{background-color:transparent}}.resize-handle[data-v-e1988a6d]{position:absolute;left:50%;top:-8px;transform:translate(-50%);width:40px;height:16px;display:flex;align-items:center;justify-content:center;cursor:ns-resize;color:#ccc;background:#fff;border:1px solid #e0e0e0;border-radius:8px;transition:all .2s;z-index:10}.resize-handle[data-v-e1988a6d]:hover{color:#07c160;border-color:#07c160}.resize-handle i[data-v-e1988a6d]{font-size:12px}.emoji-panel-wrapper[data-v-e1988a6d]{position:absolute;left:10px;z-index:100;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:320px}.emoji-panel-header[data-v-e1988a6d]{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #f0f0f0;font-weight:500;color:#333}.emoji-panel-close[data-v-e1988a6d]{background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:0 4px;line-height:1}.emoji-panel-close[data-v-e1988a6d]:hover{color:#333}.emoji-panel[data-v-e1988a6d]{padding:10px;max-height:200px;overflow-y:auto;display:flex;flex-wrap:wrap;gap:4px}.emoji-btn[data-v-e1988a6d]{border:none;background:transparent;border-radius:6px;padding:4px;cursor:pointer;font-size:22px;line-height:1}.emoji-btn[data-v-e1988a6d]:hover{background:#f0f0f0}.pending-panel[data-v-e1988a6d]{border:1px solid #eee;border-radius:8px;padding:10px;margin-bottom:10px;display:flex;flex-direction:column;gap:8px}.pending-item[data-v-e1988a6d]{display:flex;justify-content:space-between;align-items:center;gap:10px}.ttl-setting-bar[data-v-e1988a6d]{display:flex;align-items:center;padding:6px 12px;background:#f8f8f8;border-bottom:1px solid #e8e8e8}.ttl-dropdown[data-v-e1988a6d]{position:relative}.ttl-dropdown-btn[data-v-e1988a6d]{display:flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;color:#666;cursor:pointer;transition:all .2s}.ttl-dropdown-btn[data-v-e1988a6d]:hover{border-color:#07c160;color:#07c160}.ttl-dropdown-btn .fa-chevron-down[data-v-e1988a6d]{font-size:10px;transition:transform .2s}.ttl-dropdown-btn .fa-chevron-down.open[data-v-e1988a6d]{transform:rotate(180deg)}.ttl-dropdown-menu[data-v-e1988a6d]{position:absolute;top:auto;bottom:100%;left:0;margin-bottom:4px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 -4px 12px #00000026;min-width:100px;z-index:100;overflow:hidden}.ttl-dropdown-item[data-v-e1988a6d]{padding:8px 12px;font-size:13px;color:#333;cursor:pointer;transition:background .2s}.ttl-dropdown-item[data-v-e1988a6d]:hover{background:#f5f5f5}.ttl-dropdown-item.active[data-v-e1988a6d]{color:#07c160;font-weight:500}.divider[data-v-cd97e206]{height:1px;background-color:#e0e0e0;margin:5px 0;padding:0;cursor:default}.search-modal-mask[data-v-7ff35001]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:10000}.search-modal[data-v-7ff35001]{width:560px;max-width:90vw;max-height:70vh;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;overflow:hidden}.search-header[data-v-7ff35001]{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #eee}.search-title[data-v-7ff35001]{font-size:16px;font-weight:600;color:#333}.close-btn[data-v-7ff35001]{background:none;border:none;font-size:18px;color:#999;cursor:pointer;padding:4px}.close-btn[data-v-7ff35001]:hover{color:#333}.search-input-wrapper[data-v-7ff35001]{padding:12px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:10px}.search-icon[data-v-7ff35001]{color:#999;font-size:16px}.search-input[data-v-7ff35001]{flex:1;border:none;outline:none;font-size:15px;background:transparent}.search-input[data-v-7ff35001]::placeholder{color:#bbb}.search-results[data-v-7ff35001]{flex:1;overflow-y:auto;min-height:200px;max-height:400px}.search-loading[data-v-7ff35001],.search-empty[data-v-7ff35001],.search-hint[data-v-7ff35001]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#999}.search-loading i[data-v-7ff35001],.search-empty i[data-v-7ff35001],.search-hint i[data-v-7ff35001]{font-size:32px;margin-bottom:12px}.search-empty p[data-v-7ff35001],.search-hint p[data-v-7ff35001]{margin:0;font-size:14px}.results-list[data-v-7ff35001]{padding:8px 0}.result-item[data-v-7ff35001]{padding:12px 20px;cursor:pointer;transition:background .2s}.result-item[data-v-7ff35001]:hover{background:#f5f5f5}.result-sender[data-v-7ff35001]{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sender-name[data-v-7ff35001]{font-size:13px;font-weight:500;color:#333}.sender-time[data-v-7ff35001]{font-size:12px;color:#999}.result-content[data-v-7ff35001]{font-size:14px;color:#666;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.avatar[data-v-d023c336]{width:40px;height:40px;border-radius:4px;background-color:#07c160;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700;flex-shrink:0}.avatar-text[data-v-d023c336]{font-size:16px;font-weight:500}.settings-section[data-v-511796ee]{background:#fff;border-radius:8px;padding:16px;margin-bottom:16px;box-shadow:0 1px 3px #00000014}.setting-item[data-v-511796ee]{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.setting-item[data-v-511796ee]:last-child{border-bottom:none}.setting-label[data-v-511796ee]{display:flex;flex-direction:column}.setting-desc[data-v-511796ee]{font-size:12px;color:#999;margin-top:4px}.switch[data-v-511796ee]{position:relative;display:inline-block;width:44px;height:24px}.switch input[data-v-511796ee]{opacity:0;width:0;height:0}.slider[data-v-511796ee]{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:24px}.slider[data-v-511796ee]:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider[data-v-511796ee]{background-color:#07c160}input:checked+.slider[data-v-511796ee]:before{transform:translate(20px)}.btn[data-v-511796ee]{padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;border:none;transition:all .2s}.btn-primary[data-v-511796ee]{background:#07c160;color:#fff}.btn-primary[data-v-511796ee]:hover{background:#06ad56}.btn-primary[data-v-511796ee]:disabled{background:#a8dcc5;cursor:not-allowed}.btn-secondary[data-v-511796ee]{background:#f0f0f0;color:#666}.btn-secondary[data-v-511796ee]:hover{background:#e0e0e0}.btn-danger[data-v-511796ee]{background:#ff4d4f;color:#fff}.btn-danger[data-v-511796ee]:hover{background:#ff7875}.btn-danger[data-v-511796ee]:disabled{background:#ffccc7;cursor:not-allowed}.btn-outline-primary[data-v-511796ee]{background:transparent;border:1px solid #07C160;color:#07c160}.btn-outline-primary[data-v-511796ee]:hover{background:#07c160;color:#fff}.btn-outline-danger[data-v-511796ee]{background:transparent;border:1px solid #ff4d4f;color:#ff4d4f}.btn-outline-danger[data-v-511796ee]:hover{background:#ff4d4f;color:#fff}.modal-overlay[data-v-511796ee]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content[data-v-511796ee]{background:#fff;padding:24px;border-radius:8px;width:400px;max-width:90%}.modal-actions[data-v-511796ee]{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.form-group[data-v-511796ee]{margin-bottom:16px}.form-group label[data-v-511796ee]{display:block;margin-bottom:6px;font-size:14px;color:#333}.form-control[data-v-511796ee]{width:100%;height:40px;border:1px solid #e0e0e0;border-radius:4px;padding:0 12px;font-size:14px;box-sizing:border-box}.form-control[data-v-511796ee]:focus{border-color:#07c160;outline:none}.form-control[data-v-675337bf]{height:40px;border-radius:4px;border:1px solid #e0e0e0;padding:0 12px;font-size:14px}.form-control[data-v-675337bf]:focus{border-color:#07c160;outline:none}textarea.form-control[data-v-675337bf]{height:80px;padding:10px 12px;resize:none}.btn[data-v-675337bf]{padding:8px 20px;border-radius:4px;border:none;font-size:14px;cursor:pointer}.btn[data-v-675337bf]:disabled{opacity:.6;cursor:not-allowed}.btn-primary[data-v-675337bf]{background:#07c160;color:#fff}.btn-primary[data-v-675337bf]:hover:not(:disabled){background:#06ad56}.btn-secondary[data-v-675337bf]{background:#e0e0e0;color:#333}.btn-secondary[data-v-675337bf]:hover:not(:disabled){background:#d0d0d0}.btn-danger[data-v-675337bf]{background:#ff4d4f;color:#fff}.btn-danger[data-v-675337bf]:hover:not(:disabled){background:#ff7875}.form-control[data-v-5a098a94]{height:40px;border-radius:4px;border:1px solid #e0e0e0;padding:0 12px;font-size:14px}.form-control[data-v-5a098a94]:focus{border-color:#07c160;outline:none}.btn-sm[data-v-5a098a94]{padding:6px 16px;font-size:13px}.notification-item.unread[data-v-ac116855]{background:#f0f9ff;border-left:3px solid #07C160}.btn-icon[data-v-ac116855]{border:none;background:transparent;color:#999;cursor:pointer;padding:4px;border-radius:4px}.btn-icon[data-v-ac116855]:hover{background:#f5f5f5;color:#666}.nav-badge[data-v-fa7551af]{position:absolute;top:2px;right:12px;background:#ff4d4f;color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.ttl-modal-mask[data-v-fa7551af]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:10010}.ttl-modal[data-v-fa7551af]{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;border-radius:10px;padding:16px;width:min(520px,92vw);z-index:10011;box-shadow:0 10px 30px #0000002e}.status-online[data-v-fa7551af]{color:#07c160}.status-offline[data-v-fa7551af]{color:#999;font-size:12px}.staff-manage[data-v-28344a4c]{padding:24px}.page-header[data-v-28344a4c]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2[data-v-28344a4c]{font-size:20px;font-weight:700}.search-bar[data-v-28344a4c]{margin-bottom:16px}.search-input[data-v-28344a4c]{width:300px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px}.table-container[data-v-28344a4c]{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.data-table[data-v-28344a4c]{width:100%;border-collapse:collapse}.data-table th[data-v-28344a4c],.data-table td[data-v-28344a4c]{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.data-table th[data-v-28344a4c]{background:#f9f9f9;font-weight:700;font-size:14px}.data-table tr:last-child td[data-v-28344a4c]{border-bottom:none}.tag[data-v-28344a4c]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px}.tag-admin[data-v-28344a4c]{background:#e6f7ff;color:#1890ff}.tag-staff[data-v-28344a4c],.tag-active[data-v-28344a4c]{background:#f6ffed;color:#52c41a}.tag-inactive[data-v-28344a4c]{background:#fff1f0;color:#ff4d4f}.action-buttons[data-v-28344a4c]{display:flex;gap:8px}.btn-icon[data-v-28344a4c]{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon[data-v-28344a4c]:hover{background:#e0e0e0}.btn-icon.btn-danger[data-v-28344a4c]{color:#ff4d4f}.btn-icon.btn-success[data-v-28344a4c]{color:#52c41a}.empty-text[data-v-28344a4c]{text-align:center;color:#999;padding:40px!important}.modal-mask[data-v-28344a4c]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content[data-v-28344a4c]{background:#fff;border-radius:8px;width:450px;max-width:90vw}.modal-header[data-v-28344a4c]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0}.modal-header h3[data-v-28344a4c]{font-size:16px;font-weight:700}.btn-close[data-v-28344a4c]{background:none;border:none;font-size:24px;cursor:pointer;color:#999}.modal-body[data-v-28344a4c]{padding:20px}.form-group[data-v-28344a4c]{margin-bottom:16px}.form-group label[data-v-28344a4c]{display:block;margin-bottom:6px;font-size:14px;font-weight:500}.form-group .form-control[data-v-28344a4c]{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px}.modal-footer[data-v-28344a4c]{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #f0f0f0}.btn[data-v-28344a4c]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-primary[data-v-28344a4c]{background:#07c160;color:#fff}.btn-primary[data-v-28344a4c]:hover{background:#06ad56}.btn-primary[data-v-28344a4c]:disabled{background:#a8dcc0;cursor:not-allowed}.btn-secondary[data-v-28344a4c]{background:#f5f5f5;color:#666}.btn-secondary[data-v-28344a4c]:hover{background:#e0e0e0}.global-settings[data-v-4b8188b4]{padding:16px}.page-header[data-v-4b8188b4]{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-header h2[data-v-4b8188b4]{font-size:18px;font-weight:700}.header-actions[data-v-4b8188b4]{display:flex;gap:8px}.settings-section[data-v-4b8188b4]{background:#fff;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #00000014}.setting-item[data-v-4b8188b4]{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.setting-item[data-v-4b8188b4]:last-child{border-bottom:none}.setting-label[data-v-4b8188b4]{display:flex;flex-direction:column}.setting-desc[data-v-4b8188b4]{font-size:12px;color:#999;margin-top:2px}.switch[data-v-4b8188b4]{position:relative;display:inline-block;width:40px;height:22px}.switch input[data-v-4b8188b4]{opacity:0;width:0;height:0}.slider[data-v-4b8188b4]{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:22px}.slider[data-v-4b8188b4]:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider[data-v-4b8188b4]{background-color:#07c160}input:checked+.slider[data-v-4b8188b4]:before{transform:translate(18px)}.input-group[data-v-4b8188b4]{display:flex;align-items:center}.preset-list[data-v-4b8188b4]{display:flex;flex-direction:column;gap:6px}.preset-item[data-v-4b8188b4]{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#f9f9f9;border-radius:6px}.preset-fields[data-v-4b8188b4]{display:flex;align-items:center;gap:10px;flex:1;flex-wrap:wrap}.field-group[data-v-4b8188b4]{display:flex;flex-direction:column;gap:2px}.field-group label[data-v-4b8188b4]{font-size:12px;color:#666}.checkbox-field[data-v-4b8188b4]{flex-direction:row;align-items:center}.checkbox-field label[data-v-4b8188b4]{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:14px}.btn-icon[data-v-4b8188b4]{width:28px;height:28px;border:none;background:transparent;color:#999;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.btn-icon[data-v-4b8188b4]:hover{background:#ffeaea;color:#ff4d4f}.btn-sm[data-v-4b8188b4]{padding:4px 10px;font-size:12px}.file-types-grid[data-v-4b8188b4]{display:flex;flex-wrap:wrap;gap:8px;width:100%}.file-type-checkbox[data-v-4b8188b4]{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f5f5f5;border-radius:4px;font-size:12px;cursor:pointer}.file-type-checkbox[data-v-4b8188b4]:hover{background:#e0e0e0}.file-type-checkbox input[data-v-4b8188b4]{cursor:pointer}.form-control[data-v-4b8188b4]{height:30px;border-radius:4px;border:1px solid #e0e0e0;padding:0 8px;font-size:13px}.form-control[data-v-4b8188b4]:focus{border-color:#07c160;outline:none}.btn[data-v-4b8188b4]{padding:6px 14px;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-primary[data-v-4b8188b4]{background:#07c160;color:#fff}.btn-primary[data-v-4b8188b4]:hover{background:#06ad56}.btn-primary[data-v-4b8188b4]:disabled{background:#a8dcc0;cursor:not-allowed}.btn-secondary[data-v-4b8188b4]{background:#f5f5f5;color:#666}.btn-secondary[data-v-4b8188b4]:hover{background:#e0e0e0}.btn-warning[data-v-4b8188b4]{background:#ff7b00;color:#fff}.btn-warning[data-v-4b8188b4]:hover{background:#e66f00}.btn-warning[data-v-4b8188b4]:disabled{background:#ffb380;cursor:not-allowed}.global-stats[data-v-bd9fd507]{padding:24px}.page-header[data-v-bd9fd507]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2[data-v-bd9fd507]{font-size:20px;font-weight:700}.stats-cards[data-v-bd9fd507]{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card[data-v-bd9fd507]{background:#fff;border-radius:8px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 1px 3px #00000014}.stat-icon[data-v-bd9fd507]{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-value[data-v-bd9fd507]{font-size:28px;font-weight:700;color:#333}.stat-label[data-v-bd9fd507]{font-size:14px;color:#999;margin-top:4px}.stats-section[data-v-bd9fd507]{background:#fff;border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:0 1px 3px #00000014}.stats-section h3[data-v-bd9fd507]{font-size:16px;font-weight:700;margin-bottom:20px}.chart-container[data-v-bd9fd507]{height:250px;padding:10px 0}.bar-chart[data-v-bd9fd507]{display:flex;align-items:flex-end;justify-content:space-around;height:100%;gap:20px}.bar-item[data-v-bd9fd507]{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar[data-v-bd9fd507]{width:100%;max-width:60px;background:#07c160;border-radius:4px 4px 0 0;display:flex;align-items:flex-start;justify-content:center;padding-top:8px;transition:height .3s}.bar-value[data-v-bd9fd507]{color:#fff;font-size:12px;font-weight:700}.bar-label[data-v-bd9fd507]{margin-top:8px;font-size:12px;color:#666}.pie-chart-container[data-v-bd9fd507]{display:flex;align-items:center;gap:40px}.pie-chart[data-v-bd9fd507]{width:180px;height:180px;border-radius:50%;position:relative}.pie-chart[data-v-bd9fd507]:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;background:#fff;border-radius:50%}.pie-legend[data-v-bd9fd507]{flex:1}.legend-item[data-v-bd9fd507]{display:flex;align-items:center;padding:8px 0}.legend-color[data-v-bd9fd507]{width:12px;height:12px;border-radius:2px;margin-right:8px}.legend-label[data-v-bd9fd507]{flex:1;font-size:14px}.legend-value[data-v-bd9fd507]{font-size:14px;color:#666}.btn[data-v-bd9fd507]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-secondary[data-v-bd9fd507]{background:#f5f5f5;color:#666}.btn-secondary[data-v-bd9fd507]:hover{background:#e0e0e0}.login-logs[data-v-d699cfb9]{padding:24px}.page-header[data-v-d699cfb9]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2[data-v-d699cfb9]{font-size:20px;font-weight:700}.table-container[data-v-d699cfb9]{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.data-table[data-v-d699cfb9]{width:100%;border-collapse:collapse}.data-table th[data-v-d699cfb9],.data-table td[data-v-d699cfb9]{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.data-table th[data-v-d699cfb9]{background:#f9f9f9;font-weight:700;font-size:14px}.data-table tr:last-child td[data-v-d699cfb9]{border-bottom:none}.tag[data-v-d699cfb9]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px}.tag-success[data-v-d699cfb9]{background:#f6ffed;color:#52c41a}.tag-error[data-v-d699cfb9]{background:#fff1f0;color:#ff4d4f}.empty-text[data-v-d699cfb9]{text-align:center;color:#999;padding:40px!important}.pagination[data-v-d699cfb9]{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:12px;background:#fff;border-radius:8px}.pagination-info[data-v-d699cfb9]{font-size:14px;color:#666}.pagination-buttons[data-v-d699cfb9]{display:flex;gap:8px}.btn[data-v-d699cfb9]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-sm[data-v-d699cfb9]{padding:6px 12px;font-size:13px}.btn-secondary[data-v-d699cfb9]{background:#f5f5f5;color:#666}.btn-secondary[data-v-d699cfb9]:hover{background:#e0e0e0}.btn[data-v-d699cfb9]:disabled{opacity:.5;cursor:not-allowed}.system-logs[data-v-2aae2a46]{padding:24px}.page-header[data-v-2aae2a46]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2[data-v-2aae2a46]{font-size:20px;font-weight:700}.filter-bar[data-v-2aae2a46]{margin-bottom:16px}.filter-bar .form-control[data-v-2aae2a46]{width:200px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px}.table-container[data-v-2aae2a46]{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.data-table[data-v-2aae2a46]{width:100%;border-collapse:collapse}.data-table th[data-v-2aae2a46],.data-table td[data-v-2aae2a46]{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.data-table th[data-v-2aae2a46]{background:#f9f9f9;font-weight:700;font-size:14px}.data-table tr:last-child td[data-v-2aae2a46]{border-bottom:none}.details-cell[data-v-2aae2a46]{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag[data-v-2aae2a46]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px}.tag-success[data-v-2aae2a46]{background:#f6ffed;color:#52c41a}.tag-error[data-v-2aae2a46]{background:#fff1f0;color:#ff4d4f}.tag-warning[data-v-2aae2a46]{background:#fff7e6;color:#fa8c16}.tag-default[data-v-2aae2a46]{background:#f5f5f5;color:#666}.empty-text[data-v-2aae2a46]{text-align:center;color:#999;padding:40px!important}.pagination[data-v-2aae2a46]{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:12px;background:#fff;border-radius:8px}.pagination-info[data-v-2aae2a46]{font-size:14px;color:#666}.pagination-buttons[data-v-2aae2a46]{display:flex;gap:8px}.btn[data-v-2aae2a46]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-sm[data-v-2aae2a46]{padding:6px 12px;font-size:13px}.btn-secondary[data-v-2aae2a46]{background:#f5f5f5;color:#666}.btn-secondary[data-v-2aae2a46]:hover{background:#e0e0e0}.btn[data-v-2aae2a46]:disabled{opacity:.5;cursor:not-allowed}.system-status[data-v-abef84da]{padding:24px}.page-header[data-v-abef84da]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2[data-v-abef84da]{font-size:20px;font-weight:700}.stats-section[data-v-abef84da]{background:#fff;border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:0 1px 3px #00000014}.stats-section h3[data-v-abef84da]{font-size:16px;font-weight:700;margin-bottom:16px}.status-grid[data-v-abef84da]{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.status-item[data-v-abef84da]{padding:12px;background:#f9f9f9;border-radius:6px}.status-label[data-v-abef84da]{font-size:12px;color:#999;margin-bottom:4px}.status-value[data-v-abef84da]{font-size:14px;font-weight:500;color:#333;word-break:break-all}.memory-bar-container[data-v-abef84da]{margin-top:16px;display:flex;align-items:center;gap:12px}.memory-bar-label[data-v-abef84da]{font-size:14px;color:#666;width:80px}.memory-bar[data-v-abef84da]{flex:1;height:20px;background:#f0f0f0;border-radius:10px;overflow:hidden}.memory-bar-fill[data-v-abef84da]{height:100%;background:linear-gradient(90deg,#07c160,#52c41a);border-radius:10px;transition:width .3s}.memory-bar-text[data-v-abef84da]{font-size:14px;font-weight:700;color:#07c160;width:50px;text-align:right}.online-users[data-v-abef84da]{display:flex;flex-wrap:wrap;gap:12px}.online-user-item[data-v-abef84da]{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f9f9f9;border-radius:20px}.user-avatar[data-v-abef84da]{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-name[data-v-abef84da]{font-size:14px;color:#333}.online-badge[data-v-abef84da]{font-size:12px;color:#07c160;background:#f6ffed;padding:2px 8px;border-radius:10px}.empty-text[data-v-abef84da]{text-align:center;color:#999;padding:20px}.btn[data-v-abef84da]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-secondary[data-v-abef84da]{background:#f5f5f5;color:#666}.btn-secondary[data-v-abef84da]:hover{background:#e0e0e0}.broadcast-container[data-v-b52ad91b]{padding:24px}.broadcast-container h2[data-v-b52ad91b]{margin:0 0 8px;font-size:20px;color:#333}.description[data-v-b52ad91b]{color:#666;margin-bottom:24px}.form-card[data-v-b52ad91b]{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.form-group[data-v-b52ad91b]{margin-bottom:20px;position:relative}.form-group label[data-v-b52ad91b]{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input[data-v-b52ad91b],.form-group textarea[data-v-b52ad91b]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.form-group input[data-v-b52ad91b]:focus,.form-group textarea[data-v-b52ad91b]:focus{outline:none;border-color:#07c160}.form-group textarea[data-v-b52ad91b]{resize:vertical;font-family:inherit}.char-count[data-v-b52ad91b]{position:absolute;right:8px;bottom:8px;font-size:12px;color:#999}.form-actions[data-v-b52ad91b]{margin-top:24px}.btn-primary[data-v-b52ad91b]{padding:10px 24px;background:#07c160;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer}.btn-primary[data-v-b52ad91b]:hover:not(:disabled){background:#06ad56}.btn-primary[data-v-b52ad91b]:disabled{background:#ccc;cursor:not-allowed}.result-info[data-v-b52ad91b]{margin-top:20px;padding:16px;background:#f0f9f0;border-radius:4px;border:1px solid #07C160}.result-info p[data-v-b52ad91b]{margin:0 0 8px;color:#07c160;font-weight:500}.result-info ul[data-v-b52ad91b]{margin:0;padding-left:20px;color:#666}.result-info li[data-v-b52ad91b]{margin-bottom:4px}.admin-layout[data-v-c9e0be78]{display:flex;height:100vh;background:#f5f5f5;animation:fadeIn-c9e0be78 .3s var(--ease-out) both}@keyframes fadeIn-c9e0be78{0%{opacity:0}to{opacity:1}}.admin-sidebar[data-v-c9e0be78]{width:220px;background:#2c3e50;color:#fff;display:flex;flex-direction:column}.admin-logo[data-v-c9e0be78]{padding:20px;font-size:18px;font-weight:700;border-bottom:1px solid #34495e;display:flex;align-items:center;gap:10px}.admin-menu[data-v-c9e0be78]{flex:1;padding:10px 0}.menu-item[data-v-c9e0be78]{padding:12px 20px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .2s var(--ease-default),transform .15s var(--ease-spring)!important}.menu-item[data-v-c9e0be78]:hover{background:#34495e;transform:translate(3px)}.menu-item.active[data-v-c9e0be78]{background:#07c160}.menu-item[data-v-c9e0be78]:active{transform:translate(3px) scale(.98)}.menu-divider[data-v-c9e0be78]{height:1px;background:#34495e;margin:10px 0}.admin-content[data-v-c9e0be78]{flex:1;overflow-y:auto;animation:adminContentIn-c9e0be78 .25s var(--ease-out) both}@keyframes adminContentIn-c9e0be78{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}#app{width:100%;height:100vh}.page-fade-enter-active,.page-fade-leave-active{transition:opacity .25s var(--ease-out),transform .25s var(--ease-out)}.page-fade-enter-from{opacity:0;transform:translateY(6px)}.page-fade-leave-to{opacity:0;transform:translateY(-4px)}.page-fade-enter-to,.page-fade-leave-from{opacity:1;transform:translateY(0)}body.is-mobile{overflow-x:hidden}@media (max-width: 768px){*{-webkit-tap-highlight-color:transparent}.mobile-chat-list-page{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:0!important;display:flex!important;flex-direction:column!important;background:#fff!important;animation:mobilePageIn .25s var(--ease-out) both}.mobile-chat-page{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:56px!important;display:flex!important;flex-direction:column!important;background:#f5f5f5!important;animation:mobilePageIn .22s var(--ease-out) both}.mobile-contact-list-page{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:0!important;display:flex!important;flex-direction:column!important;background:#fff!important;animation:mobilePageIn .22s var(--ease-out) both}.mobile-profile-page,.mobile-notification-page,.mobile-settings-page{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:0!important;padding:0!important;background:#f5f5f5!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;animation:mobilePageIn .22s var(--ease-out) both}@keyframes mobilePageIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.mobile-nav-item{flex:1!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;color:#999!important;transition:color .2s,transform .2s!important;position:relative!important;-webkit-tap-highlight-color:transparent!important;-webkit-user-select:none!important;user-select:none!important}.mobile-nav-item:active{transform:scale(.93)!important}.mobile-input-tools .tool-btn:active,.mobile-expand-btn:active{background:#f0f0f0!important;color:#07c160!important;transform:scale(.95)!important}.mobile-send-btn:active{transform:scale(.93)!important;background:#06b355!important}.mobile-emoji-panel{position:fixed!important;bottom:60px!important;left:0!important;right:0!important;background:#fff!important;border-radius:16px 16px 0 0!important;box-shadow:0 -4px 20px #0000001a!important;max-height:300px!important;overflow-y:auto!important;padding:12px!important;z-index:1001!important;animation:slideUpPanel .28s var(--ease-spring) both}.mobile-modal-content{background:#fff!important;border-radius:16px 16px 0 0!important;width:100%!important;max-height:80vh!important;overflow-y:auto!important;padding:20px!important;padding-bottom:calc(20px + env(safe-area-inset-bottom))!important;animation:slideUpPanel .28s var(--ease-spring) both}@keyframes slideUpPanel{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.mobile-friend-item:active{background:#eef9ef!important}.mobile-back-btn:active,.back-btn:active{background:#f0f0f0!important;transform:scale(.93)!important}.mobile-settings-item:active{background:#f0f0f0!important}.mobile-request-btn.accept:active{background:#06ad56!important;transform:scale(.95)!important}.mobile-request-btn.reject:active{background:#e0e0e0!important;transform:scale(.95)!important}@keyframes mobileSlideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.mobile-chat-page .message-item,.mobile-message-list .message-item{animation:mobileBubbleIn .22s var(--ease-out) both}@keyframes mobileBubbleIn{0%{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-header-avatar:active,.mobile-profile-avatar:active{transform:scale(.96)!important}}@media (max-width: 768px){.mobile-expand-btn{display:flex!important}.main-container{display:flex!important;flex-direction:column!important;height:100vh!important;height:100dvh!important;background-color:#f5f5f5!important;position:relative!important;overflow:hidden!important}.main-container>.sidebar{display:none!important}.main-container>[style*="width: 300px"]{display:none!important}.main-container>.content-area{display:none!important}.mobile-content-area{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:56px!important;flex:1!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;background-color:#f5f5f5!important}.mobile-bottom-nav{display:flex!important;position:absolute!important;bottom:0!important;left:0!important;right:0!important;height:56px!important;background:#fff!important;border-top:1px solid #e0e0e0!important;z-index:9999!important;padding-bottom:env(safe-area-inset-bottom)!important}.mobile-nav-item i{font-size:22px!important;margin-bottom:4px!important}.mobile-nav-item span{font-size:10px!important}.mobile-nav-item.active{color:#07c160!important}.mobile-nav-item .nav-badge{position:absolute!important;top:4px!important;right:50%!important;transform:translate(12px)!important;background:#ff4d4f!important;color:#fff!important;font-size:10px!important;min-width:16px!important;height:16px!important;border-radius:8px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0 4px!important}.mobile-chat-list-header{flex-shrink:0!important;height:48px!important;padding:0 16px!important;background:#fff!important;border-bottom:1px solid #f0f0f0!important;display:flex!important;align-items:center!important;justify-content:space-between!important}.mobile-chat-list-header h2,.mobile-chat-list-header .add-btn{display:none!important}.mobile-header-user{display:flex!important;align-items:center!important;gap:8px!important;cursor:pointer!important;transition:opacity .15s!important}.mobile-header-user:active{opacity:.75!important}.mobile-header-avatar{width:32px!important;height:32px!important;border-radius:50%!important;background-color:#07c160!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:14px!important;font-weight:600!important;overflow:hidden!important;flex-shrink:0!important;transition:transform .2s!important}.mobile-header-avatar img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:50%!important}.mobile-header-username{font-size:15px!important;font-weight:500!important;color:#333!important;max-width:120px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.mobile-header-title{font-size:15px!important;font-weight:500!important;color:#666!important}.mobile-search-box{flex-shrink:0!important;padding:8px 16px!important;background:#f5f5f5!important}.mobile-search-input{width:100%!important;padding:8px 12px!important;border:none!important;border-radius:6px!important;background:#fff!important;font-size:14px!important;transition:background-color .2s!important}.mobile-search-input:focus{outline:none!important;background:#fff!important}.mobile-chat-list{flex:1!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;min-height:0!important}.mobile-chat-header{flex-shrink:0!important;height:48px!important;padding:0 12px!important;background:#fff!important;border-bottom:1px solid #e0e0e0!important;display:flex!important;align-items:center!important;gap:12px!important}.mobile-chat-header .back-btn{width:32px!important;height:32px!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#333!important;background:transparent!important;border:none!important;font-size:18px!important;transition:background-color .2s,transform .15s!important}.mobile-chat-header .avatar{width:40px!important;height:40px!important;border-radius:4px!important;background-size:cover!important;background-position:center!important;background-color:#07c160!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#fff!important;font-size:18px!important;flex-shrink:0!important}.mobile-chat-header .chat-info{flex:1!important;min-width:0!important}.mobile-chat-header .chat-name{font-size:16px!important;font-weight:600!important;color:#333!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.mobile-chat-header .chat-status{font-size:12px!important;color:#999!important}.mobile-chat-header .action-btns{display:flex!important;gap:8px!important}.mobile-chat-header .action-btn{width:36px!important;height:36px!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;background:transparent!important;border:none!important;color:#666!important;font-size:18px!important;transition:background-color .2s,transform .15s!important}.mobile-chat-header .action-btn:active{background:#f0f0f0!important;transform:scale(.93)!important}.mobile-message-list,.mobile-chat-page .chat-content,.mobile-chat-page .message-list{flex:1!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;min-height:0!important}.mobile-chat-page .chat-content{padding:8px 8px 100px!important;background-color:#f5f5f5!important}.mobile-message-list .message-item{margin-bottom:12px!important}.mobile-chat-page .message-item .message-content-wrapper,.mobile-message-list .message-item .message-content-wrapper{flex-shrink:0!important;max-width:min(82vw,300px)!important}.mobile-message-list .message-content{max-width:100%!important;min-width:0!important;width:auto!important;padding:10px 14px!important;word-break:normal!important;overflow-wrap:break-word!important}.mobile-chat-page .message-item .message-content,.mobile-chat-page .message-item.received .message-content{max-width:100%!important;width:fit-content!important;word-break:normal!important;overflow-wrap:break-word!important;word-wrap:break-word!important;white-space:pre-wrap!important;writing-mode:horizontal-tb!important;text-orientation:mixed!important}.mobile-chat-page .message-item .message-content>div{word-break:normal!important;overflow-wrap:break-word!important;max-width:100%!important}.mobile-input-area{flex-shrink:0!important;padding:8px 12px!important;padding-bottom:calc(8px + env(safe-area-inset-bottom))!important;background:#fff!important;border-top:1px solid #e0e0e0!important;z-index:100!important;position:relative!important}.mobile-input-tools{display:flex!important;align-items:center!important;gap:12px!important;margin-bottom:8px!important}.mobile-input-tools .tool-btn{width:36px!important;height:36px!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;background:transparent!important;border:none!important;color:#666!important;font-size:20px!important;cursor:pointer!important;transition:all .2s!important}.mobile-expand-btn{width:36px!important;height:36px!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;background:transparent!important;border:none!important;color:#666!important;font-size:18px!important;cursor:pointer!important;transition:all .2s!important}.mobile-input-row{display:flex!important;align-items:flex-end!important;gap:10px!important}.mobile-input-row textarea{flex:1!important;min-height:36px!important;max-height:120px!important;border:1px solid #e0e0e0!important;border-radius:20px!important;padding:8px 14px!important;resize:none!important;font-size:15px!important;line-height:1.4!important;background:#fff!important;color:#333!important;transition:border-color .2s!important}.mobile-input-row textarea:focus{outline:none!important;border-color:#07c160!important}.mobile-send-btn{width:60px!important;height:36px!important;border-radius:20px!important;background:#07c160!important;color:#fff!important;border:none!important;font-size:14px!important;font-weight:500!important;flex-shrink:0!important;cursor:pointer!important;transition:all .2s!important;box-shadow:0 2px 8px #07c1604d!important}.mobile-fullscreen-input{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#fff!important;z-index:10001!important;display:flex!important;flex-direction:column!important;animation:fadeIn .2s ease both!important}.mobile-fullscreen-header{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:12px 16px!important;background:#f5f5f5!important;border-bottom:1px solid #e0e0e0!important}.mobile-fullscreen-restore{font-size:20px!important;color:#666!important;background:none!important;border:none!important;cursor:pointer!important;padding:4px 8px!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:color .2s!important}.mobile-fullscreen-title{font-size:16px!important;font-weight:600!important;color:#333!important}.mobile-fullscreen-send{font-size:15px!important;color:#07c160!important;background:none!important;border:none!important;cursor:pointer!important;padding:4px 8px!important;font-weight:500!important;transition:opacity .2s!important}.mobile-fullscreen-textarea{flex:1!important;width:100%!important;padding:16px!important;border:none!important;resize:none!important;font-size:16px!important;line-height:1.6!important;color:#333!important;background:#fff!important}.mobile-fullscreen-textarea:focus{outline:none!important}.mobile-fullscreen-toolbar{display:flex!important;align-items:center!important;gap:12px!important;padding:8px 16px!important;background:#f5f5f5!important;border-top:1px solid #e0e0e0!important}.mobile-contact-list{flex:1!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;padding-bottom:70px!important}.mobile-contact-section-header{padding:8px 16px!important;background:#f5f5f5!important;font-size:13px!important;font-weight:600!important;color:#666!important}.mobile-settings-page.settings-panel{display:flex!important;flex-direction:column!important;padding-bottom:70px!important}.mobile-settings-page.settings-panel>*{flex-shrink:0!important}.mobile-settings-page.settings-panel>h2{font-size:18px!important;padding:16px!important;margin-bottom:0!important;background:#fff!important}.mobile-settings-section{background:#fff!important;border-radius:0!important;margin-bottom:1px!important;overflow:hidden!important}.mobile-settings-item{padding:14px 16px!important;display:flex!important;justify-content:space-between!important;align-items:center!important;border-bottom:1px solid #f0f0f0!important;background:#fff!important;transition:background-color .15s!important}.mobile-settings-item:last-child{border-bottom:none!important}.mobile-settings-item .label{font-size:15px!important;color:#333!important}.mobile-settings-item .desc{font-size:12px!important;color:#999!important;margin-top:2px!important}.mobile-settings-page .btn{padding:6px 16px!important;border-radius:4px!important;font-size:14px!important;border:none!important}.mobile-settings-page .btn-outline-primary{background:transparent!important;border:1px solid #07C160!important;color:#07c160!important}.mobile-settings-page .btn-outline-danger{background:transparent!important;border:1px solid #ff4d4f!important;color:#ff4d4f!important}.mobile-settings-page .btn-danger{background:#ff4d4f!important;color:#fff!important}.mobile-settings-page .switch{width:44px!important;height:24px!important}.mobile-settings-page .slider{background-color:#ccc!important;border-radius:24px!important}.mobile-settings-page .slider:before{height:20px!important;width:20px!important}.mobile-settings-page input:checked+.slider{background-color:#07c160!important}.mobile-settings-page input:checked+.slider:before{transform:translate(20px)!important}.mobile-settings-page .modal-overlay{position:fixed!important;z-index:10001!important;background:#00000080!important}.mobile-settings-page .modal-content{width:90%!important;padding:20px!important;border-radius:12px!important}.mobile-settings-page .modal-actions{flex-direction:row!important;gap:12px!important}.mobile-settings-page .modal-actions .btn{flex:1!important}.mobile-settings-page .form-group{margin-bottom:16px!important}.mobile-settings-page .form-group label{font-size:14px!important;margin-bottom:8px!important}.mobile-settings-page .form-control{width:100%!important;height:44px!important;padding:0 12px!important;border:1px solid #e0e0e0!important;border-radius:8px!important;font-size:15px!important}.mobile-settings-page .form-control:focus{border-color:#07c160!important;outline:none!important}.mobile-notification-page.notification-panel{padding-bottom:70px!important}.mobile-notification-header{font-size:18px!important;font-weight:600!important;margin-bottom:16px!important;color:#333!important}.mobile-notification-item{background:#fff!important;border-radius:8px!important;padding:14px!important;margin-bottom:10px!important;display:flex!important;gap:12px!important;transition:transform .2s,box-shadow .2s!important}.mobile-friend-request{background:#fff!important;border-radius:8px!important;padding:14px!important;margin-bottom:10px!important;display:flex!important;align-items:center!important;gap:12px!important;transition:transform .2s,box-shadow .2s!important}.mobile-request-actions{display:flex!important;gap:8px!important;flex-shrink:0!important}.mobile-request-btn{padding:6px 14px!important;border-radius:16px!important;font-size:13px!important;border:none!important;cursor:pointer!important;transition:background-color .2s,transform .15s!important}.mobile-request-btn.accept{background:#07c160!important;color:#fff!important}.mobile-request-btn.reject{background:#f0f0f0!important;color:#666!important}.mobile-profile-page.profile-panel{display:flex!important;flex-direction:column!important;padding-bottom:70px!important}.mobile-profile-page.profile-panel>*{flex-shrink:0!important}.mobile-profile-header{text-align:center!important;margin-bottom:20px!important}.mobile-profile-avatar{width:80px!important;height:80px!important;border-radius:50%!important;margin:0 auto 12px!important;background:#07c160!important;background-size:cover!important;background-position:center!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#fff!important;font-size:32px!important;transition:transform .2s!important}.mobile-profile-form{background:#fff!important;border-radius:8px!important;padding:16px!important;margin-bottom:16px!important}.mobile-form-item{margin-bottom:16px!important}.mobile-form-item label{display:block!important;font-size:14px!important;color:#666!important;margin-bottom:6px!important}.mobile-form-item input,.mobile-form-item textarea{width:100%!important;padding:10px 12px!important;border:1px solid #e0e0e0!important;border-radius:6px!important;font-size:15px!important;transition:border-color .2s!important}.mobile-form-item input:focus,.mobile-form-item textarea:focus{border-color:#07c160!important;outline:none!important}.mobile-form-item textarea{height:80px!important;resize:none!important}.mobile-empty-state{flex:1!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;color:#999!important;padding:40px!important}.mobile-empty-state i{font-size:60px!important;margin-bottom:16px!important;color:#ddd!important}.mobile-empty-state p{font-size:14px!important}.mobile-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#00000080!important;z-index:9999!important;display:flex!important;align-items:flex-end!important;justify-content:center!important;animation:fadeIn .2s ease both!important}.mobile-emoji-btn{width:40px!important;height:40px!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:24px!important;background:transparent!important;border:none!important;border-radius:6px!important;cursor:pointer!important;transition:background-color .15s!important}.mobile-emoji-btn:active{background:#f0f0f0!important}.mobile-friend-item{padding:12px 16px!important;display:flex!important;align-items:center!important;gap:12px!important;background:#fff!important;border-bottom:1px solid #f0f0f0!important;cursor:pointer!important;-webkit-tap-highlight-color:transparent!important;transition:background-color .15s!important}.mobile-friend-item .avatar{width:48px!important;height:48px!important;border-radius:4px!important;background-size:cover!important;background-position:center!important;background-color:#07c160!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#fff!important;font-size:18px!important;flex-shrink:0!important;transition:transform .2s!important}.mobile-friend-item .friend-info{flex:1!important;min-width:0!important}.mobile-friend-item .friend-name{font-size:15px!important;font-weight:500!important;color:#333!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.mobile-friend-item .friend-status{font-size:12px!important;color:#999!important;margin-top:2px!important}.mobile-friend-item .last-msg{font-size:13px!important;color:#999!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.mobile-friend-item .msg-time{font-size:11px!important;color:#999!important;flex-shrink:0!important}.mobile-friend-item .unread-badge{min-width:18px!important;height:18px!important;border-radius:9px!important;background:#ff4d4f!important;color:#fff!important;font-size:11px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0 5px!important;flex-shrink:0!important}.mobile-back-btn{width:32px!important;height:32px!important;display:flex!important;align-items:center!important;justify-content:center!important;background:transparent!important;border:none!important;color:#333!important;font-size:18px!important;cursor:pointer!important;transition:background-color .2s,transform .15s!important}.mobile-page-header{padding:12px 16px!important;background:#fff!important;border-bottom:1px solid #f0f0f0!important;display:flex!important;align-items:center!important;gap:12px!important}.mobile-page-title{font-size:18px!important;font-weight:600!important;color:#333!important;flex:1!important}.chat-content .message-item{margin-bottom:10px!important}.mobile-chat-page .chat-content .message-item .message-content-wrapper{flex-shrink:0!important;max-width:min(82vw,300px)!important}.mobile-chat-page .chat-content .message-item .message-content{max-width:100%!important;width:fit-content!important;padding:8px 12px!important;word-break:normal!important;overflow-wrap:break-word!important}.chat-content .message-item .message-content{padding:8px 12px!important}.chat-input-area{padding:8px 10px!important;padding-bottom:calc(8px + env(safe-area-inset-bottom))!important}.chat-input-tools{gap:10px!important;margin-bottom:8px!important}.tool-button{width:32px!important;height:32px!important}.chat-input textarea{min-height:36px!important;max-height:100px!important;padding:8px 12px!important;font-size:15px!important}.send-button{height:36px!important;padding:0 16px!important}.resize-handle{display:none!important}.emoji-panel-wrapper{left:0!important;right:0!important;max-width:100%!important;border-radius:16px 16px 0 0!important;bottom:0!important}.emoji-panel{max-height:250px!important}.pending-panel{padding:8px!important}.pending-item{flex-wrap:wrap!important}.chat-header{padding:10px 12px!important}.chat-header .avatar{width:36px!important;height:36px!important;margin-right:10px!important}.chat-header .friend-name{font-size:15px!important}.chat-header .friend-status{font-size:11px!important}.chat-header .action-buttons{gap:6px!important}.chat-header .btn{padding:6px 10px!important}.friend-item{padding:10px 12px!important}.friend-item .avatar{width:44px!important;height:44px!important}.friend-item .friend-name{font-size:14px!important}.friend-item .last-message{font-size:12px!important}.search-box{padding:8px!important}.search-input{padding:6px 12px!important;font-size:13px!important}.settings-panel{padding:12px!important}.settings-section{padding:12px!important;margin-bottom:12px!important}.setting-item{padding:10px 0!important}.setting-label span:first-child{font-size:14px!important}.modal-content{width:95%!important;padding:16px!important}.modal-actions{flex-direction:row!important;gap:10px!important}.modal-actions .btn{flex:1!important;padding:10px!important}.notification-panel{padding:12px!important}.notification-item{padding:12px!important;margin-bottom:10px!important}.friend-request-item{padding:12px!important;flex-wrap:wrap!important}.friend-request-item .avatar{width:44px!important;height:44px!important}.mobile-request-actions{width:100%!important;justify-content:flex-end!important;margin-top:8px!important}.profile-panel{padding:12px!important}.profile-form{padding:14px!important}.account-info{padding:14px!important;margin-top:16px!important}.form-item{margin-bottom:14px!important}.form-actions{flex-direction:column!important}.form-actions .btn{width:100%!important}.add-friend-container{height:auto!important}.add-friend-content{padding:16px!important}.add-friend-header{margin-bottom:16px!important}.add-friend-header h2{font-size:18px!important}.add-friend-search{margin-bottom:16px!important}.search-result-item{padding:12px!important;flex-wrap:wrap!important}.search-result-item .avatar{width:44px!important;height:44px!important}.search-result-item .user-name{font-size:14px!important}.toast{bottom:80px!important;max-width:90%!important;text-align:center!important}.custom-context-menu{position:fixed!important;left:10%!important;right:10%!important;top:30%!important;bottom:auto!important;transform:none!important}.custom-context-menu ul{min-width:auto!important}.custom-context-menu li{padding:12px 16px!important;font-size:15px!important}.attachment-preview{max-width:200px!important}.attachment-preview img{max-width:200px!important;max-height:200px!important}.add-friend-panel.mobile-full-page{height:100%!important;display:flex!important;flex-direction:column!important}.add-friend-panel.mobile-full-page h2{font-size:18px!important;margin-bottom:16px!important}.add-friend-panel.mobile-full-page .search-section{margin-bottom:16px!important}.add-friend-panel.mobile-full-page .user-card{padding:12px!important;flex-wrap:wrap!important}.add-friend-panel.mobile-full-page .user-card .avatar{width:44px!important;height:44px!important}.add-friend-panel.mobile-full-page .user-info{flex:1!important}.add-friend-panel.mobile-full-page .user-info>div:first-child{font-size:14px!important}.add-friend-panel.mobile-full-page .user-actions{width:100%!important;justify-content:flex-end!important;margin-top:8px!important}.add-friend-panel.mobile-full-page .tips{padding:16px!important}.add-friend-panel.mobile-full-page .tips h3{font-size:15px!important;margin-bottom:10px!important}.add-friend-panel.mobile-full-page .tips ul{font-size:13px!important}}@media (max-width: 768px){.pc-only{display:none!important}}@media (min-width: 769px){.mobile-only,.mobile-bottom-nav,.mobile-expand-btn{display:none!important}}
