*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #07c160;--green-light: #95ec69;--green-dark: #06ae56;--sidebar-bg: #2e2e2e;--sidebar-hover: rgba(255,255,255,.08);--sidebar-active: rgba(255,255,255,.14);--panel-bg: #ffffff;--panel-header-bg: #f7f7f7;--chat-bg: #ededed;--bubble-mine: #95ec69;--bubble-theirs: #ffffff;--text-primary: #191919;--text-secondary: #888;--text-hint: #b2b2b2;--border: #e8e8e8;--hover-bg: #f5f5f5;--active-bg: #ebebeb;--shadow: 0 2px 8px rgba(0,0,0,.08);--radius: 4px}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;font-size:14px;color:var(--text-primary);background:#f5f5f5;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,textarea,select{font:inherit;outline:none;border:none;background:none}input::placeholder,textarea::placeholder{color:var(--text-hint)}.conv-items::-webkit-scrollbar{width:4px}.conv-items::-webkit-scrollbar-track{background:transparent}.conv-items::-webkit-scrollbar-thumb{background:#0000001f;border-radius:4px;transition:background .2s}.conv-items::-webkit-scrollbar-thumb:hover{background:#00000047}.conv-items{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}html.dark .conv-items::-webkit-scrollbar-thumb{background:#ffffff1f}html.dark .conv-items::-webkit-scrollbar-thumb:hover{background:#ffffff47}html.dark .conv-items{scrollbar-color:rgba(255,255,255,.15) transparent}.messages-area::-webkit-scrollbar,.contact-items::-webkit-scrollbar,.contact-detail::-webkit-scrollbar,.member-list::-webkit-scrollbar,.modal-body::-webkit-scrollbar,.gm-body::-webkit-scrollbar,.gm-add-list::-webkit-scrollbar,.notice-list::-webkit-scrollbar,.mention-picker-list::-webkit-scrollbar{width:5px;height:5px}.messages-area::-webkit-scrollbar-track,.contact-items::-webkit-scrollbar-track,.contact-detail::-webkit-scrollbar-track,.member-list::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track,.gm-body::-webkit-scrollbar-track,.gm-add-list::-webkit-scrollbar-track,.notice-list::-webkit-scrollbar-track,.mention-picker-list::-webkit-scrollbar-track{background:transparent}.messages-area::-webkit-scrollbar-thumb,.contact-items::-webkit-scrollbar-thumb,.contact-detail::-webkit-scrollbar-thumb,.member-list::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb,.gm-body::-webkit-scrollbar-thumb,.gm-add-list::-webkit-scrollbar-thumb,.notice-list::-webkit-scrollbar-thumb,.mention-picker-list::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.messages-area::-webkit-scrollbar-thumb:hover,.contact-items::-webkit-scrollbar-thumb:hover,.contact-detail::-webkit-scrollbar-thumb:hover,.member-list::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover,.gm-body::-webkit-scrollbar-thumb:hover,.gm-add-list::-webkit-scrollbar-thumb:hover,.notice-list::-webkit-scrollbar-thumb:hover,.mention-picker-list::-webkit-scrollbar-thumb:hover{background:#0000004d}html.dark .messages-area::-webkit-scrollbar-track,html.dark .contact-items::-webkit-scrollbar-track,html.dark .contact-detail::-webkit-scrollbar-track,html.dark .member-list::-webkit-scrollbar-track,html.dark .modal-body::-webkit-scrollbar-track,html.dark .gm-body::-webkit-scrollbar-track,html.dark .gm-add-list::-webkit-scrollbar-track{background:transparent}html.dark .messages-area::-webkit-scrollbar-thumb,html.dark .contact-items::-webkit-scrollbar-thumb,html.dark .contact-detail::-webkit-scrollbar-thumb,html.dark .member-list::-webkit-scrollbar-thumb,html.dark .modal-body::-webkit-scrollbar-thumb,html.dark .gm-body::-webkit-scrollbar-thumb,html.dark .gm-add-list::-webkit-scrollbar-thumb{background:#ffffff26}.login-page{min-height:100vh;min-height:-webkit-fill-available;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f0f7f0,#e8ecf0);padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom))}.login-box{background:#fff;border-radius:16px;padding:36px 32px 28px;width:100%;max-width:380px;box-shadow:0 8px 40px #0000001a}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;justify-content:center}.login-logo-icon{display:flex}.login-logo-text{font-size:22px;font-weight:600;color:var(--text-primary);letter-spacing:1px}.login-tabs{display:flex;margin-bottom:24px;border-bottom:2px solid var(--border)}.login-tabs button{flex:1;padding:10px 4px;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;white-space:nowrap}.login-tabs button.active{color:var(--green);border-bottom-color:var(--green);font-weight:500}.login-form{display:flex;flex-direction:column;gap:14px}.form-group input,.form-group select{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;transition:border-color .2s;background:#fff;-webkit-appearance:none}.form-group input:focus,.form-group select:focus{border-color:var(--green);outline:none}.phone-group{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s;background:#fff}.phone-group:focus-within{border-color:var(--green)}.phone-prefix{padding:13px 12px 13px 14px;font-size:15px;color:var(--text-primary);border-right:1.5px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0}.phone-group input{border:none!important;border-radius:0!important;padding:13px 14px!important;flex:1;min-width:0}.phone-group input:focus{outline:none}.code-group{display:flex;gap:10px}.code-group input{flex:1;min-width:0;border:1.5px solid var(--border);border-radius:10px;padding:13px 14px;font-size:15px;letter-spacing:4px;background:#fff;transition:border-color .2s}.code-group input:focus{border-color:var(--green);outline:none}.btn-send-code{flex-shrink:0;padding:0 14px;background:#e8f8ed;color:var(--green);border:1.5px solid #b8e8cc;border-radius:10px;font-size:13px;font-weight:500;white-space:nowrap;transition:background .15s;height:48px}.btn-send-code:hover:not(:disabled){background:#d4f0e0}.btn-send-code.sent,.btn-send-code:disabled{background:#f5f5f5;color:var(--text-hint);border-color:var(--border);cursor:not-allowed}.demo-code-hint{padding:10px 14px;background:#fffbe6;border:1px solid #ffe58f;border-radius:8px;font-size:13px;color:#7c5800;text-align:center}.demo-code-hint strong{font-size:18px;letter-spacing:4px;color:#d48806}.phone-mode-switch{text-align:right;margin-top:-6px}.phone-mode-switch button{font-size:13px;color:var(--green);padding:4px 0}.form-error{color:#e64340;font-size:13px;padding:4px 0}.btn-primary{width:100%;padding:14px;background:var(--green);color:#fff;border-radius:10px;font-size:16px;font-weight:500;transition:background .2s;margin-top:4px;letter-spacing:2px}.btn-primary:hover{background:var(--green-dark)}.btn-primary:active{background:var(--green-dark);transform:scale(.99)}.btn-primary:disabled{background:#a0d9b8;cursor:not-allowed}.login-demo{margin-top:20px;padding:12px;background:#f9f9f9;border-radius:8px;font-size:12px;color:var(--text-secondary);line-height:2;text-align:center}.login-demo strong{color:var(--text-primary)}@media (max-width: 480px){.login-page{align-items:flex-start;padding-top:60px;background:#fff}.login-box{box-shadow:none;border-radius:0;padding:0 24px 32px;max-width:100%}.login-logo{margin-bottom:36px}.btn-primary{padding:16px;font-size:17px}.form-group input,.form-group select,.code-group input,.phone-prefix{font-size:16px}.phone-group input{font-size:16px!important}}.main-layout{display:flex;height:100vh;height:100dvh;min-height:0;overflow:hidden;flex-direction:row;flex-wrap:nowrap;box-sizing:border-box}.main-layout.has-titlebar{padding-top:32px;box-sizing:border-box}.main-layout.has-titlebar .wx-input-wrap{padding-bottom:20px}.main-layout.has-titlebar .wx-input-row{padding-bottom:8px}.main-content{flex:1;min-width:0;min-height:0;height:100%;max-height:100%;overflow:hidden;background:#fff;display:flex;flex-direction:column}:root{--titlebar-bg: #1a1a26;--titlebar-h: 32px}.app-titlebar{position:fixed;top:0;left:0;right:0;height:var(--titlebar-h);background:var(--titlebar-bg);display:flex;align-items:center;justify-content:space-between;z-index:9999;-webkit-app-region:drag;-webkit-user-select:none;user-select:none}.app-titlebar-drag{display:flex;align-items:center;gap:8px;padding-left:12px;flex:1;height:100%;-webkit-app-region:drag}.app-titlebar-name{font-size:13px;font-weight:600;color:#ffffffd9;letter-spacing:1px}.app-titlebar-btns{display:flex;height:100%;-webkit-app-region:no-drag}.app-titlebar-btn{width:46px;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3;background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s;-webkit-app-region:no-drag}.app-titlebar-btn:hover{background:#ffffff1a;color:#fff}.app-titlebar-btn-close:hover{background:#e81123;color:#fff}.dl-page .app-titlebar{background:#1c1f27}.sidebar{width:72px;background:var(--sidebar-bg);display:flex;flex-direction:column;align-items:center;padding:14px 0 12px;flex-shrink:0;min-height:0;height:100%;z-index:10}.sidebar-avatar{margin-bottom:18px;cursor:pointer;transition:opacity .2s}.sidebar-avatar:hover{opacity:.85}.sidebar-nav{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:0 6px}.sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:0 6px}.nav-btn{position:relative;width:100%;height:auto;padding:7px 4px 5px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#9a9a9a;transition:background .15s,color .15s}.nav-btn-icon{position:relative;display:flex;align-items:center;justify-content:center;width:22px;height:22px}.nav-label{font-size:10.5px;font-weight:400;line-height:1;color:inherit;white-space:nowrap;letter-spacing:.02em}.nav-btn:hover{background:var(--sidebar-hover);color:#fff}.nav-btn.active{background:var(--sidebar-active);color:#fff}.nav-btn-logout{color:#8a8a8a}.nav-btn-logout:hover{background:#e6434026;color:#e64340}.nav-badge{position:absolute;top:2px;right:2px;background:#e64340;color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;font-weight:600}.panel-header{padding:12px 12px 8px;background:var(--panel-header-bg);border-bottom:1px solid var(--border)}.search-bar{display:flex;align-items:center;gap:6px;background:#eaeaea;border-radius:6px;padding:6px 10px}.search-bar input{flex:1;font-size:13px;background:transparent}.chat-panel{display:grid;grid-template-columns:290px minmax(0,1fr);flex:1 1 auto;height:100%;max-height:100%;min-width:0;min-height:0;overflow:hidden}.conv-list{width:auto;flex-shrink:0;min-width:0;min-height:0;height:100%;border-right:1px solid var(--border);display:flex;flex-direction:column;background:#fff;overflow:hidden;position:relative}.conv-items{flex:1;min-height:0;overflow-y:auto}.conv-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .12s;position:relative}.conv-item:hover{background:var(--hover-bg)}.conv-item.active{background:var(--active-bg)}.conv-avatar{position:relative;flex-shrink:0}.conv-info{flex:1;min-width:0}.conv-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px}.conv-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.conv-time{font-size:11px;color:var(--text-hint);flex-shrink:0}.conv-bottom{display:flex;justify-content:space-between;align-items:center}.conv-preview{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:170px}.unread-badge{background:#e64340;color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-weight:600;flex-shrink:0}.unread-dot-muted{width:8px;height:8px;border-radius:50%;background:#bbb;flex-shrink:0}html.dark .unread-dot-muted{background:#666}.empty-list{text-align:center;padding:40px 20px;color:var(--text-hint);font-size:13px}.chat-area{flex:1 1 auto;height:100%;max-height:100%;min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column}.chat-window{flex:1 1 auto;height:100%;max-height:100%;min-width:0;min-height:0;overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#fff;position:relative}.chat-header{grid-row:1;display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:56px;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;z-index:5}.chat-header-title{display:flex;align-items:baseline;gap:6px}.chat-name{font-size:15px;font-weight:600}.chat-member-count{font-size:12px;color:var(--text-secondary)}.chat-header-actions{display:flex;gap:4px}.icon-btn{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#666;transition:background .15s,color .15s}.icon-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.icon-btn--active{color:#07c160!important}.member-panel{position:absolute;right:0;top:56px;width:220px;background:#fff;border-left:1px solid var(--border);border-bottom:1px solid var(--border);z-index:20;box-shadow:-4px 4px 12px #00000014;max-height:400px;display:flex;flex-direction:column}.member-panel-header{padding:12px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);border-bottom:1px solid var(--border)}.member-list{overflow-y:auto}.member-item{display:flex;align-items:center;gap:10px;padding:8px 14px;transition:background .12s}.member-item:hover{background:var(--hover-bg)}.member-info{display:flex;align-items:center;gap:6px}.member-name{font-size:13px}.member-tag{font-size:10px;padding:1px 5px;background:#fff3e0;color:#fa9d3b;border-radius:3px}.messages-area{grid-row:2;flex:1 1 auto;height:auto;max-height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:16px;background:#ededed;display:flex;flex-direction:column;gap:2px}.load-more-tip{text-align:center;font-size:11px;color:#aaa;padding:6px 0}.date-separator{text-align:center;margin:10px 0}.date-separator span{background:#00000014;color:#888;font-size:11px;padding:3px 10px;border-radius:10px}.recalled-msg{text-align:center;font-size:12px;color:var(--text-hint);margin:6px 0}.msg-highlight{animation:msg-flash 2s ease-out}@keyframes msg-flash{0%{background:#07c16040;border-radius:8px}to{background:transparent}}.msg-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}.msg-row.mine{flex-direction:row-reverse}.msg-avatar{width:36px;flex-shrink:0}.msg-body{display:flex;flex-direction:column;max-width:65%;position:relative}.msg-row.mine .msg-body{align-items:flex-end}.msg-sender-name{font-size:11px;color:var(--text-secondary);margin-bottom:3px;margin-left:4px}.msg-content-wrap{display:flex;align-items:flex-end;gap:4px}.msg-row.mine .msg-content-wrap{flex-direction:row-reverse}.msg-bubble{padding:9px 12px;border-radius:4px;font-size:14px;line-height:1.5;word-break:break-word;white-space:pre-wrap;box-shadow:0 1px 2px #0000000f;position:relative}.bubble-mine{background:var(--bubble-mine);border-radius:12px 2px 12px 12px}.bubble-theirs{background:var(--bubble-theirs);border-radius:2px 12px 12px}.bubble-mine:after{content:"";position:absolute;top:10px;right:-6px;border:6px solid transparent;border-left-color:var(--bubble-mine);border-right:0}.bubble-theirs:after{content:"";position:absolute;top:10px;left:-6px;border:6px solid transparent;border-right-color:var(--bubble-theirs);border-left:0}.msg-time{font-size:10px;color:var(--text-hint);flex-shrink:0;margin-bottom:4px}.ctx-menu{position:absolute;top:0;left:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;overflow:hidden;min-width:80px}.ctx-menu button{display:block;width:100%;padding:8px 16px;text-align:left;font-size:13px;transition:background .12s}.ctx-menu button:hover{background:var(--hover-bg)}.ctx-menu button.ctx-delete{color:#ff4d4f}.ctx-menu button.ctx-delete:hover{background:#fff1f0}.conv-ctx-menu{position:fixed;background:#fff;border-radius:10px;box-shadow:0 4px 20px #0000002e;min-width:130px;z-index:9999;overflow:hidden}.conv-ctx-menu button{display:block;width:100%;padding:12px 18px;background:none;border:none;text-align:left;font-size:14px;cursor:pointer;color:var(--text)}.conv-ctx-menu button:not(:last-child){border-bottom:1px solid var(--border)}.conv-ctx-menu button:hover{background:var(--hover-bg)}.conv-ctx-menu button.ctx-delete{color:#ff4d4f}.conv-ctx-menu button.ctx-delete:hover{background:#fff1f0}.conv-item.pinned{background:#f5fdf7}.conv-top-right{display:flex;align-items:center;gap:4px}.pin-icon{font-size:11px}.msg-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999}.msg-confirm-box{background:#fff;border-radius:12px;padding:24px 28px;min-width:260px;box-shadow:0 8px 32px #0000002e}.msg-confirm-box p{font-size:14px;color:#333;margin-bottom:18px;line-height:1.5}.msg-confirm-btns{display:flex;gap:10px;justify-content:flex-end}.msg-confirm-btns button{padding:7px 20px;border-radius:6px;font-size:13px;cursor:pointer;border:1px solid #ddd;background:#f5f5f5;color:#555}.msg-confirm-btns .btn-danger{background:#ff4d4f;color:#fff;border-color:#ff4d4f}.msg-confirm-btns .btn-danger:hover{background:#d9363e}.edit-banner{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#e8f4ff;border-top:1px solid #c5dff8;color:#1677ff;font-size:13px}.edit-banner-preview{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#555}.edit-banner-close{color:#999;font-size:14px;line-height:1;padding:2px 4px;border-radius:4px;flex-shrink:0}.edit-banner-close:hover{background:#00000014}.msg-edited{font-size:10px;color:#00000059;margin-left:5px;vertical-align:middle}.typing-indicator{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:12px;color:var(--text-secondary)}.typing-dots{display:flex;gap:3px;align-items:center}.typing-dots span{width:5px;height:5px;background:var(--text-hint);border-radius:50%;animation:bounce 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.emoji-picker{display:flex;flex-wrap:wrap;gap:4px;padding:10px 14px;background:#fff;border-top:1px solid var(--border);max-height:120px;overflow-y:auto}.emoji-picker button{width:34px;height:34px;font-size:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .12s}.emoji-picker button:hover{background:var(--hover-bg)}.input-area{border-top:1px solid var(--border);background:#fff;flex-shrink:0}.input-toolbar{display:flex;align-items:center;gap:2px;padding:6px 10px 4px;border-bottom:1px solid var(--border)}.toolbar-btn{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#666;transition:background .12s}.toolbar-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.input-row{display:flex;align-items:flex-end;gap:10px;padding:8px 14px 12px}.msg-input{flex:1;resize:none;font-size:14px;line-height:1.5;max-height:120px;color:var(--text-primary);padding:4px 0}.send-btn{padding:7px 20px;background:#efefef;color:var(--text-secondary);border-radius:6px;font-size:13px;font-weight:500;transition:background .15s,color .15s;flex-shrink:0;align-self:flex-end}.send-btn.active{background:var(--green);color:#fff}.send-btn.active:hover{background:var(--green-dark)}.contact-panel{display:flex;flex:1;min-height:0}.contact-detail-panel{flex:1;overflow-y:auto;background:#fff;display:flex;flex-direction:column}.detail-close-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .12s}.detail-close-btn:hover{background:var(--hover-bg)}.contact-list{width:290px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;position:relative}.contact-tabs{display:flex;padding:8px 12px 0;border-bottom:1px solid var(--border);background:var(--panel-header-bg);gap:0}.contact-tabs button{flex:1;padding:7px;font-size:13px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;text-align:center}.contact-tabs button.active{color:var(--green);border-bottom-color:var(--green);font-weight:500}.contact-items{flex:1;min-height:0;overflow-y:scroll}.dept-header{display:flex;align-items:center;gap:6px;padding:8px 14px;cursor:pointer;background:#f9f9f9;border-bottom:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-secondary);transition:background .12s;-webkit-user-select:none;user-select:none}.dept-header:hover{background:#f0f0f0}.dept-count{margin-left:auto;font-size:11px;color:var(--text-hint);font-weight:400}.contact-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:background .12s}.contact-item:hover{background:var(--hover-bg)}.contact-item.active{background:var(--active-bg)}.contact-info{min-width:0}.contact-name{display:block;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-position{display:block;font-size:11px;color:var(--text-hint)}.status-dot-sm{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;background:#ccc;border:1.5px solid #fff}.status-dot-sm.online{background:var(--green)}.contact-detail{flex:1;min-height:0;overflow-y:auto;background:#fafafa}.detail-card{max-width:460px;margin:0 auto;padding:40px 32px;position:relative}.detail-avatar{margin-bottom:16px}.detail-name{font-size:22px;font-weight:600;margin-bottom:6px}.detail-position{font-size:13px;color:var(--text-secondary);margin-bottom:20px}.detail-fields{margin-bottom:24px}.detail-row{display:flex;align-items:center;padding:11px 0;border-bottom:1px solid var(--border);gap:16px}.detail-label{font-size:13px;color:var(--text-secondary);width:60px;flex-shrink:0}.detail-value{font-size:14px;color:var(--text-primary)}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;font-size:12px;margin-top:12px}.status-badge.online{background:#e8f8ed;color:var(--green)}.status-badge.offline{background:#f5f5f5;color:var(--text-hint)}.detail-announcement{margin-top:8px;padding:12px;background:#fff8e1;border-radius:8px;border-left:3px solid #fa9d3b}.ann-label{display:block;font-size:11px;color:#fa9d3b;margin-bottom:4px;font-weight:600}.detail-announcement p{font-size:13px;color:var(--text-primary);line-height:1.6}.btn-chat{display:flex;align-items:center;gap:7px;padding:10px 24px;background:var(--green);color:#fff;border-radius:8px;font-size:14px;font-weight:500;transition:background .15s}.btn-chat:hover{background:var(--green-dark)}.workstation{flex:1;min-height:0;overflow-y:auto;background:#f5f5f5}.workstation-inner{max-width:780px;margin:0 auto;padding:24px 32px}.ws-section{background:#fff;border-radius:10px;padding:20px;margin-bottom:16px}.ws-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.app-item{display:flex;flex-direction:column;align-items:center;gap:7px;padding:12px 8px;border-radius:8px;transition:background .15s}.app-item:hover{background:var(--hover-bg)}.app-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 2px 8px #0000001a}.app-name{font-size:12px;color:var(--text-primary);text-align:center}.notice-list{display:flex;flex-direction:column}.notice-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.notice-item:last-child{border-bottom:none}.notice-item:hover{background:var(--hover-bg);margin:0 -8px;padding:12px 8px;border-radius:6px}.notice-dot-wrap{width:16px;display:flex;justify-content:center}.notice-dot{width:7px;height:7px;background:#e64340;border-radius:50%}.notice-content{flex:1;min-width:0}.notice-title{display:block;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notice-meta{display:block;font-size:11px;color:var(--text-hint);margin-top:2px}.todo-list{display:flex;flex-direction:column;gap:2px}.todo-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.todo-item:last-child{border-bottom:none}.todo-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--green);flex-shrink:0;cursor:pointer}.todo-content{display:flex;flex-direction:column;gap:2px}.todo-text{font-size:13px}.todo-time{font-size:11px;color:var(--text-hint)}.todo-time.urgent{color:#e64340}.profile-page{flex:1;min-height:0;overflow-y:auto;background:#f5f5f5;-webkit-overflow-scrolling:touch}.profile-card{max-width:540px;margin:0 auto;padding:32px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}.profile-header{display:flex;align-items:center;gap:20px;background:#fff;padding:24px;border-radius:10px;margin-bottom:16px;box-shadow:var(--shadow)}.profile-header-info h2{font-size:20px;font-weight:600;margin-bottom:4px}.profile-header-info p{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.status-online-badge{font-size:11px;padding:2px 8px;background:#e8f8ed;color:var(--green);border-radius:10px}.profile-body{background:#fff;border-radius:10px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}.profile-form{display:flex;flex-direction:column;gap:12px}.profile-field{display:flex;flex-direction:column;gap:5px}.profile-field label{font-size:12px;color:var(--text-secondary)}.profile-field input{padding:9px 12px;border:1.5px solid var(--border);border-radius:7px;font-size:14px;transition:border-color .2s}.profile-field input:focus{border-color:var(--green)}.profile-actions{display:flex;gap:10px;margin-top:4px}.btn-save{flex:1;padding:10px;background:var(--green);color:#fff;border-radius:7px;font-size:14px;font-weight:500;transition:background .15s}.btn-save:hover{background:var(--green-dark)}.btn-save:disabled{background:#a0d9b8;cursor:not-allowed}.btn-cancel{flex:1;padding:10px;background:var(--hover-bg);color:var(--text-secondary);border-radius:7px;font-size:14px;transition:background .15s}.btn-cancel:hover{background:var(--active-bg)}.profile-info{display:flex;flex-direction:column}.info-row{display:flex;align-items:center;padding:13px 0;border-bottom:1px solid var(--border);gap:20px}.info-row:last-of-type{border-bottom:none;margin-bottom:12px}.info-label{font-size:13px;color:var(--text-secondary);width:60px;flex-shrink:0}.info-value{font-size:14px;color:var(--text-primary)}.btn-edit{align-self:flex-start;padding:8px 20px;border:1.5px solid var(--green);color:var(--green);border-radius:7px;font-size:13px;font-weight:500;transition:background .15s}.btn-edit:hover{background:#e8f8ed}.save-msg{text-align:center;padding:8px;font-size:13px;color:var(--green);background:#e8f8ed;border-radius:6px;margin-bottom:12px}.profile-settings{background:#fff;border-radius:10px;padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow)}.profile-settings h3{font-size:13px;color:var(--text-secondary);margin-bottom:10px;font-weight:500}.settings-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.settings-row:last-child{border-bottom:none}.settings-row:hover{background:var(--hover-bg);margin:0 -8px;padding:13px 8px;border-radius:6px}.settings-icon{font-size:18px;width:28px;text-align:center}.settings-label{flex:1;font-size:14px}.settings-value{font-size:12px;color:var(--text-hint)}.invite-settings-block{padding:12px 0 14px;border-bottom:1px solid var(--border);margin-bottom:2px}.invite-settings-title{display:flex;align-items:center;gap:8px;margin-bottom:10px}.invite-days-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.invite-days-label{font-size:12px;color:var(--text-hint);white-space:nowrap}.invite-days-chips{display:flex;gap:6px}.invite-day-chip{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;border:1.5px solid var(--border);color:var(--text-secondary);background:var(--hover-bg);transition:all .15s}.invite-day-chip:hover{border-color:var(--green);color:var(--green);background:#f0fbf4}.invite-day-chip.active{border-color:var(--green);color:var(--green);background:#e8f9f0;font-weight:600}.invite-result-block{background:var(--hover-bg);border-radius:8px;padding:12px;text-align:center;margin-bottom:10px}.invite-result-code{font-size:30px;font-weight:700;letter-spacing:8px;color:var(--green);font-family:monospace;margin-bottom:4px}.invite-result-meta{font-size:11.5px;color:var(--text-hint);margin-bottom:8px}.btn-gen-invite{width:100%;padding:10px;background:var(--green);color:#fff;border-radius:8px;font-size:14px;font-weight:500;transition:background .15s}.btn-gen-invite:hover{background:var(--green-dark)}.btn-gen-invite:disabled{opacity:.6;cursor:not-allowed}.btn-logout{width:100%;padding:12px;background:#fff;color:#e64340;border-radius:10px;font-size:15px;font-weight:500;box-shadow:var(--shadow);transition:background .15s}.btn-logout:hover{background:#fef2f2}.empty-state{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--text-hint);font-size:13px;background:var(--chat-bg)}.panel-header-row{display:flex;align-items:center;gap:6px}.new-group-btn{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#666;flex-shrink:0;transition:background .15s,color .15s}.new-group-btn:hover{background:var(--hover-bg);color:var(--green)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border-radius:12px;width:420px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;animation:slideUp .2s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);font-size:16px;font-weight:600}.modal-close{font-size:16px;color:var(--text-secondary);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s}.modal-close:hover{background:var(--hover-bg)}.modal-body{padding:16px 20px;overflow-y:auto;flex:1;min-height:0}.modal-field{margin-bottom:12px}.modal-input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;transition:border-color .2s}.modal-input:focus{border-color:var(--green)}.modal-section-title{font-size:12px;color:var(--text-secondary);margin:12px 0 8px;font-weight:500}.modal-member-list{display:flex;flex-direction:column;gap:2px}.modal-member-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background .12s}.modal-member-item:hover{background:var(--hover-bg)}.modal-member-item input[type=checkbox]{accent-color:var(--green);width:16px;height:16px;cursor:pointer}.modal-member-info{display:flex;flex-direction:column}.modal-member-name{font-size:13px;font-weight:500}.modal-member-dept{font-size:11px;color:var(--text-hint)}.modal-error{padding:8px 20px;font-size:13px;color:#e64340}.modal-footer{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.btn-modal-cancel{flex:1;padding:10px;border-radius:8px;background:var(--hover-bg);color:var(--text-secondary);font-size:14px;transition:background .15s}.btn-modal-cancel:hover{background:var(--active-bg)}.btn-modal-confirm{flex:1;padding:10px;border-radius:8px;background:var(--green);color:#fff;font-size:14px;font-weight:500;transition:background .15s}.btn-modal-confirm:hover{background:var(--green-dark)}.btn-modal-confirm:disabled{background:#a0d9b8;cursor:not-allowed}.gm-panel{display:flex;flex-direction:column;flex:1;min-height:0}.gm-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border)}.gm-tabs{display:flex;gap:0}.gm-tabs button{padding:6px 12px;font-size:13px;color:var(--text-secondary);border-radius:6px;transition:background .12s,color .12s}.gm-tabs button.active{background:var(--active-bg);color:var(--text-primary);font-weight:500}.gm-close{font-size:14px;color:var(--text-secondary);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s}.gm-close:hover{background:var(--hover-bg)}.gm-body{flex:1;min-height:0;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px}.gm-add-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1.5px dashed var(--green);border-radius:8px;color:var(--green);font-size:13px;width:100%;justify-content:center;transition:background .15s}.gm-add-btn:hover{background:#e8f8ed}.gm-add-panel{background:var(--hover-bg);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px}.gm-add-list{display:flex;flex-direction:column;gap:2px;max-height:160px;overflow-y:auto}.gm-empty{font-size:12px;color:var(--text-hint);text-align:center;padding:8px}.gm-member-list{display:flex;flex-direction:column;gap:2px}.gm-member-row{display:flex;align-items:center;gap:8px;padding:7px 6px;border-radius:8px;transition:background .12s}.gm-member-row:hover{background:var(--hover-bg)}.gm-member-info{flex:1;min-width:0}.gm-member-name{display:block;font-size:13px;font-weight:500}.gm-member-dept{display:block;font-size:11px;color:var(--text-hint)}.gm-owner-tag{font-size:10px;padding:2px 6px;background:#fff3e0;color:#fa9d3b;border-radius:3px;flex-shrink:0}.gm-kick-btn{font-size:11px;padding:3px 8px;background:#fff0f0;color:#e64340;border-radius:4px;flex-shrink:0;border:1px solid #ffd0d0;transition:background .15s}.gm-kick-btn:hover{background:#ffe0e0}.gm-field{display:flex;flex-direction:column;gap:5px}.gm-field label{font-size:12px;color:var(--text-secondary)}.gm-input{padding:8px 10px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;width:100%;resize:vertical;transition:border-color .2s}.gm-input:focus{border-color:var(--green)}.btn-dissolve{width:100%;padding:10px;background:#fff0f0;color:#e64340;border-radius:8px;font-size:14px;border:1px solid #ffd0d0;transition:background .15s}.btn-dissolve:hover{background:#ffe0e0}.gm-msg{padding:8px 14px;font-size:12px;color:var(--green);border-top:1px solid var(--border);text-align:center}.toggle{position:relative;width:44px;height:24px;flex-shrink:0;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:24px;transition:background .25s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-slider{background:var(--green)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-disabled{opacity:.45;cursor:not-allowed}.gm-id-qr-row{display:flex;align-items:center;justify-content:space-between;background:var(--hover-bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px}.gm-id-block{display:flex;flex-direction:column;gap:3px}.gm-id-label{font-size:11px;color:var(--text-secondary)}.gm-id-value{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:1px}.gm-restrictions{background:#fafafa;border:1px solid var(--border);border-radius:10px;overflow:hidden}.restrict-title{font-size:11px;color:var(--text-secondary);font-weight:600;letter-spacing:.5px;padding:10px 14px 6px;text-transform:uppercase}.restrict-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-top:1px solid var(--border);gap:12px}.restrict-info{display:flex;flex-direction:column;gap:2px}.restrict-label{font-size:13px;font-weight:500}.restrict-desc{font-size:11px;color:var(--text-hint)}.gm-member-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.role-tag{font-size:10px;padding:2px 6px;border-radius:3px}.role-tag.owner{background:#fff3e0;color:#fa9d3b}.role-tag.admin{background:#e8f0fe;color:#576b95}.gm-role-btn{font-size:11px;padding:3px 7px;background:#e8f0fe;color:#576b95;border-radius:4px;border:1px solid #c5d0f0;transition:background .15s;white-space:nowrap}.gm-role-btn:hover{background:#d0dcf8}.gm-role-btn.demote{background:#f5f5f5;color:#888;border-color:#ddd}.gm-role-btn.demote:hover{background:#eee}.mute-banner{display:flex;align-items:center;gap:7px;padding:8px 14px;background:#fff8e1;color:#856404;font-size:12px;border-bottom:1px solid #ffe082}.input-muted .msg-input{color:var(--text-hint);cursor:not-allowed}.msg-scroll-btn{position:absolute;right:18px;bottom:76px;width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid #ddd;box-shadow:0 2px 10px #0000002e;display:flex;align-items:center;justify-content:center;color:#666;cursor:pointer;z-index:30;transition:box-shadow .15s,color .15s}.msg-scroll-btn:hover{box-shadow:0 4px 14px #00000040;color:var(--green)}html.dark .msg-scroll-btn{background:#2a2a2a;border-color:#444;color:#bbb}.msg-select-row{display:flex;align-items:center;gap:8px;padding:2px 8px;cursor:pointer;transition:background .12s;border-radius:6px}.msg-select-row:hover{background:#07c1600f}.msg-select-row--on{background:#07c1601a}.msg-select-check{flex-shrink:0;width:22px;height:22px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;background:#fff;transition:border-color .15s,background .15s}.msg-select-check--on{border-color:#07c160;background:#07c160}html.dark .msg-select-check{background:#2a2a2a;border-color:#555}html.dark .msg-select-row--on{background:#07c1601f}.msg-select-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg-primary);flex-shrink:0}.msg-select-bar-cancel{padding:7px 16px;border-radius:6px;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:14px;color:#555}html.dark .msg-select-bar-cancel{background:#2a2a2a;border-color:#444;color:#bbb}.msg-select-bar-count{flex:1;text-align:center;font-size:13px;color:var(--text-secondary)}.msg-select-bar-forward{display:flex;align-items:center;padding:7px 18px;border-radius:6px;border:none;background:#07c160;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.msg-select-bar-forward:disabled{background:#ccc;cursor:not-allowed}.msg-select-bar-forward:not(:disabled):hover{background:#06ad56}.send-error-toast{position:absolute;bottom:160px;left:50%;transform:translate(-50%);background:#000000b8;color:#fff;font-size:13px;padding:8px 18px;border-radius:20px;white-space:nowrap;z-index:200;pointer-events:none;animation:fadeInUp .2s,fadeOut .3s 3.2s forwards}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{to{opacity:0}}.detail-btns{display:flex;gap:10px;flex-wrap:wrap}.btn-add-friend{display:flex;align-items:center;gap:7px;padding:10px 20px;border:1.5px solid #576b95;color:#576b95;border-radius:8px;font-size:14px;font-weight:500;transition:background .15s}.btn-add-friend:hover{background:#eef2fb}.btn-block{display:flex;align-items:center;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .15s}.btn-block:hover{opacity:.8}.btn-delete-friend{display:flex;align-items:center;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500;color:#e64340;border:1px solid #e64340;background:#fff5f5;cursor:pointer;transition:background .15s}.btn-delete-friend:hover{background:#ffe0e0}.already-friend{display:flex;align-items:center;font-size:13px;color:var(--text-hint);padding:10px 16px;background:var(--hover-bg);border-radius:8px}.add-friend-msg{font-size:12px;color:var(--green);padding:6px 0;margin-bottom:6px}.add-search-form{display:flex;gap:8px;margin-bottom:10px}.add-search-form .modal-input{flex:1}.add-search-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 0 16px;color:#bbb;font-size:13px}.add-results{display:flex;flex-direction:column;gap:2px}.add-result-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:8px;transition:background .12s}.add-result-row:hover{background:var(--hover-bg)}.add-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.add-result-name{font-size:14px;font-weight:500}.add-result-sub{font-size:11px;color:var(--text-secondary)}.add-result-account{font-size:11px;color:var(--text-hint)}.add-result-action{flex-shrink:0}.btn-add-inline{padding:6px 16px;background:var(--green);color:#fff;border-radius:20px;font-size:13px;font-weight:500;transition:background .15s;white-space:nowrap}.btn-add-inline:hover{background:var(--green-dark)}.add-msg-inline{font-size:12px;padding:5px 10px;border-radius:12px;white-space:nowrap}.add-msg-inline.ok{color:var(--green);background:#e8f8ed}.add-msg-inline.err{color:#e64340;background:#fff0f0}.friend-req-entry{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border)}.friend-req-entry:hover{background:var(--hover-bg)}.friend-req-entry.active{background:var(--active-bg)}.freq-icon{width:38px;height:38px;border-radius:8px;background:#e8f0fe;display:flex;align-items:center;justify-content:center;color:#576b95;flex-shrink:0}.freq-label{font-size:14px;font-weight:500;flex:1}.freq-badge{background:#e64340;color:#fff;font-size:11px;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;font-weight:600}.freq-panel{padding:0;height:100%;display:flex;flex-direction:column}.freq-panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;font-size:18px;font-weight:600;border-bottom:1px solid var(--border)}.freq-item{display:flex;align-items:center;gap:14px;padding:16px 24px;border-bottom:1px solid var(--border)}.freq-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.freq-name{font-size:14px;font-weight:500}.freq-dept{font-size:12px;color:var(--text-secondary)}.freq-msg{font-size:12px;color:var(--text-hint);font-style:italic}.freq-actions{display:flex;gap:8px;flex-shrink:0}.btn-accept{padding:7px 16px;background:var(--green);color:#fff;border-radius:20px;font-size:13px;font-weight:500;transition:background .15s}.btn-accept:hover{background:var(--green-dark)}.btn-reject{padding:7px 16px;background:var(--hover-bg);color:var(--text-secondary);border-radius:20px;font-size:13px;transition:background .15s}.btn-reject:hover{background:var(--active-bg)}.freq-done{font-size:12px;color:var(--text-hint)}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .2s}.call-video-mode{background:#000}.call-box{background:#1e1e2e;border-radius:20px;padding:36px 40px;display:flex;flex-direction:column;align-items:center;gap:16px;min-width:300px;box-shadow:0 24px 80px #00000080;position:relative}.call-box.active{min-width:340px;padding:24px 32px}.call-type-label{font-size:13px;color:#a0a0c0;margin-bottom:-4px}.call-peer-name{font-size:22px;font-weight:600;color:#fff}.call-status{font-size:13px;color:#8080a0}.call-timer{font-size:20px;font-weight:600;color:#07c160;letter-spacing:2px;margin:4px 0}.call-ringing{display:flex;align-items:center;gap:4px}.call-dots{display:flex;gap:3px;align-items:center;margin-left:4px}.call-dots span{width:4px;height:4px;background:#8080a0;border-radius:50%;animation:bounce 1.2s infinite}.call-dots span:nth-child(2){animation-delay:.2s}.call-dots span:nth-child(3){animation-delay:.4s}.call-actions{display:flex;gap:24px;margin-top:12px}.call-btn{width:68px;height:68px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:12px;transition:transform .15s,opacity .15s;color:#fff}.call-btn:hover{transform:scale(1.08)}.call-btn span{font-size:11px;margin-top:2px}.call-btn.reject{background:#e64340}.call-btn.accept{background:#07c160}.call-error-box{gap:12px;padding:32px 40px}.call-error-icon{font-size:36px}.call-error-msg{font-size:15px;color:#fff;text-align:center;font-weight:500}.call-error-hint{font-size:12px;color:#fff9}.audio-call-info{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:8px}.call-controls{display:flex;gap:20px;margin-top:12px}.ctrl-btn{width:60px;height:60px;border-radius:50%;background:#ffffff1f;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#fff;font-size:10px;transition:background .15s}.ctrl-btn:hover{background:#ffffff38}.ctrl-btn.active{background:#ffffff4d}.ctrl-btn.end{background:#e64340}.ctrl-btn.end:hover{background:#c93030}.ctrl-btn span{font-size:10px;margin-top:2px}.call-minimize-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s}.call-minimize-btn:hover{background:#ffffff47}.call-mini-bar{position:fixed;bottom:24px;right:24px;z-index:2000;background:#1e1e2e;border-radius:40px;display:flex;align-items:center;gap:10px;padding:8px 12px;box-shadow:0 8px 32px #00000073;animation:fadeIn .2s;min-width:220px}.call-mini-info{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer;min-width:0}.call-mini-text{display:flex;flex-direction:column;gap:1px;min-width:0}.call-mini-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call-mini-timer{font-size:11px;color:#07c160;letter-spacing:1px}.call-mini-actions{display:flex;align-items:center;gap:6px}.call-mini-btn{width:32px;height:32px;border-radius:50%;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s}.call-mini-btn:hover{background:#ffffff47}.call-mini-btn.active{background:#ffffff4d}.call-mini-end{background:#e64340!important}.call-mini-end:hover{background:#c93030!important}.video-area{position:relative;width:480px;height:320px;background:#111;border-radius:12px;overflow:hidden}.video-remote{width:100%;height:100%;object-fit:cover}.video-local{position:absolute;bottom:12px;right:12px;width:120px;height:90px;object-fit:cover;border-radius:8px;border:2px solid rgba(255,255,255,.3);background:#222}@media (max-width: 600px){.video-area{width:320px;height:240px}.video-local{width:90px;height:68px}}.dl-page{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1f27;display:flex;align-items:center;justify-content:center;flex-direction:column}.dl-center{display:flex;flex-direction:column;align-items:center;gap:0;animation:dlFadeIn .22s ease}@keyframes dlFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.dl-center-form{width:340px}.dl-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.dl-logo-sm{margin-bottom:20px}.dl-logo-name{font-size:22px;font-weight:700;color:#fff;letter-spacing:3px}.dl-logo-sm .dl-logo-name{font-size:18px}.dl-qr-section{display:flex;flex-direction:column;align-items:center;gap:10px}.dl-qr-frame{position:relative;width:220px;height:220px;background:#fff;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #00000073}.dl-qr-img{width:220px;height:220px;display:block;transition:opacity .3s}.dl-qr-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#ffffffeb;font-size:13px;color:#888}.dl-qr-ok{color:#07c160;font-weight:500}.dl-qr-expired{gap:8px}.dl-qr-expired-text{font-size:13px;color:#aaa}.dl-qr-refresh-btn{display:flex;align-items:center;padding:7px 18px;background:#07c160;color:#fff;border-radius:20px;font-size:13px;font-weight:500;transition:background .15s}.dl-qr-refresh-btn:hover{background:#06ae56}.dl-qr-spinner{width:30px;height:30px;border:3px solid rgba(7,193,96,.2);border-top-color:#07c160;border-radius:50%;animation:spin .7s linear infinite}.dl-qr-countdown{font-size:12px;transition:color .3s,opacity .3s;height:18px}.dl-hint{font-size:13px;color:#ffffff61;margin:14px 0 20px;letter-spacing:.3px}.dl-entries{display:flex;align-items:center;gap:6px}.dl-entries button{font-size:13px;color:#ffffff73;padding:4px 2px;transition:color .15s}.dl-entries button:hover{color:#ffffffd9}.dl-dot{width:3px;height:3px;border-radius:50%;background:#fff3;flex-shrink:0}.dl-or{display:flex;align-items:center;gap:10px;margin:16px 0 12px;color:#ccc;font-size:12px;width:100%}.dl-or:before,.dl-or:after{content:"";flex:1;height:1px;background:#e8e8e8}.dl-alt-btn{width:100%;padding:11px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:14px;color:#555;transition:background .15s}.dl-alt-btn:hover{background:#f5f5f5}.fp-page,.fp-modal{width:100%;display:flex;flex-direction:column}.fp-back{display:flex;align-items:center;gap:5px;font-size:12px;color:#fff6;margin-bottom:16px;align-self:flex-start;transition:color .15s}.fp-back:hover{color:#fffc}.fp-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:18px}.fp-tabs button{flex:1;padding:8px 4px;font-size:14px;color:#fff6;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.fp-tabs button.active{color:#07c160;border-bottom-color:#07c160;font-weight:600}.fp-modal .fp-tabs{border-bottom-color:var(--border)}.fp-modal .fp-tabs button{color:var(--text-secondary)}.fp-modal .fp-tabs button.active{color:var(--green);border-bottom-color:var(--green)}.fp-form{display:flex;flex-direction:column}.fp-field{display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.12);min-height:50px;transition:border-color .2s}.fp-field:focus-within{border-bottom-color:#07c160}.fp-prefix{font-size:14px;color:#fff9;padding:0 10px 0 2px;flex-shrink:0;-webkit-user-select:none;user-select:none}.fp-line{width:1px;height:16px;background:#ffffff26;margin-right:12px;flex-shrink:0}.fp-input{flex:1;font-size:14px;color:#fff;background:transparent;border:none;outline:none;padding:0;min-width:0;-webkit-appearance:none}.fp-input::placeholder{color:#ffffff47}.fp-eye{display:flex;align-items:center;padding:0 4px;flex-shrink:0}.fp-code-row{gap:8px}.fp-sms-btn{flex-shrink:0;padding:6px 12px;background:#07c16026;color:#07c160;border:1px solid rgba(7,193,96,.4);border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;transition:background .15s;height:34px}.fp-sms-btn:hover:not(:disabled){background:#07c16040}.fp-sms-btn.sent,.fp-sms-btn:disabled{background:transparent;color:#ffffff4d;border-color:#ffffff1f;cursor:not-allowed}.fp-toggle{align-self:flex-end;font-size:12px;color:#ffffff61;padding:8px 0 4px;transition:color .15s}.fp-toggle:hover{color:#ffffffb3}.fp-error{color:#ff6b6b;font-size:12px;padding:8px 0 0;margin:0}.fp-submit{margin-top:22px;width:100%;padding:13px;background:#07c160;color:#fff;border-radius:8px;font-size:15px;font-weight:600;letter-spacing:3px;transition:background .2s,transform .1s}.fp-submit:hover{background:#06ae56}.fp-submit:active{transform:scale(.99)}.fp-submit:disabled{background:#07c16066;cursor:not-allowed}.fp-modal .fp-field{border-bottom-color:var(--border)}.fp-modal .fp-field:focus-within{border-bottom-color:var(--green)}.fp-modal .fp-prefix{color:var(--text-primary)}.fp-modal .fp-line{background:var(--border)}.fp-modal .fp-input{color:var(--text-primary)}.fp-modal .fp-input::placeholder{color:var(--text-hint)}.fp-modal .fp-eye svg{fill:#aaa!important}.fp-modal .fp-sms-btn{background:#e8f8ed;color:var(--green);border-color:#b8e8cc;height:36px;font-size:13px}.fp-modal .fp-sms-btn:hover:not(:disabled){background:#d4f0e0}.fp-modal .fp-sms-btn.sent,.fp-modal .fp-sms-btn:disabled{background:#f5f5f5;color:var(--text-hint);border-color:var(--border)}.fp-modal .fp-toggle{color:var(--green)}.fp-modal .fp-toggle:hover{color:var(--green-dark)}.fp-modal .fp-error{color:#e64340}.fp-modal .fp-back{color:var(--text-secondary)}.fp-modal .fp-back:hover{color:var(--green)}@media (max-width: 480px){.dl-page{background:#fff}.dl-center{padding:60px 24px 40px;align-items:stretch;width:100%}.dl-logo{justify-content:center}.dl-qr-frame{width:200px;height:200px;align-self:center}.dl-qr-img{width:200px;height:200px}.dl-hint{text-align:center;color:var(--text-secondary)}.dl-entries{justify-content:center}.fp-input,.fp-prefix{font-size:16px}.fp-submit{font-size:17px;padding:16px}}.bottom-nav{display:none}.chat-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;color:var(--text-secondary);flex-shrink:0;margin-right:4px;transition:background .15s;background:none;border:none;cursor:pointer}.chat-back-btn:hover{background:var(--hover-bg)}.chat-back-label{display:none}@media (max-width: 768px){.sidebar{display:none}.main-layout{padding-top:env(safe-area-inset-top,0px);box-sizing:border-box}.panel-header{padding-top:12px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#f7f7f7;border-top:1px solid #d8d8d8;z-index:500}.main-layout{flex-direction:column}.main-content{flex:1;overflow:hidden;min-height:0;padding-bottom:calc(56px + env(safe-area-inset-bottom))}.main-content.main-content-in-chat{padding-bottom:0}.main-content:not(:has(~.bottom-nav)){padding-bottom:0}.chat-panel .conv-list{width:100%;border-right:none}.chat-panel .chat-area{display:none}.contact-list{width:100%;border-right:none}.contact-detail-panel{display:none}.chat-panel.chat-active{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr);height:100%;max-height:100%;min-height:0;overflow:hidden}.chat-panel.chat-active .conv-list{display:none}.chat-panel.chat-active .chat-area{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.chat-panel.chat-active .chat-window{display:grid;grid-template-rows:auto minmax(0,1fr) auto;flex:1;min-height:0;height:100%;max-height:100%;background:#ededed}.chat-panel.chat-active .chat-header{flex-shrink:0;height:auto;min-height:52px;padding:0 4px 0 0;background:#ededed;border-bottom:1px solid #c8c8c8;gap:0;justify-content:flex-start}.chat-back-btn{display:flex!important;align-items:center;gap:2px;color:#07c160!important;padding:12px 10px 12px 4px;width:auto!important;min-width:52px;border-radius:0;margin-right:0;font-size:15px;font-weight:400;background:transparent!important}.chat-back-btn svg{width:22px;height:22px;flex-shrink:0}.chat-back-label{display:inline!important;color:#07c160;font-size:15px;white-space:nowrap}.chat-panel.chat-active .chat-header-title{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;margin-right:4px}.chat-panel.chat-active .chat-name{font-size:16px;font-weight:600;color:#111}.chat-panel.chat-active .chat-member-count{font-size:11px;color:#666}.chat-panel.chat-active .chat-header-actions{flex-shrink:0;gap:0}.chat-panel.chat-active .icon-btn{width:40px;height:44px;border-radius:0;color:#333}.chat-panel.chat-active .messages-area{flex:1 1 auto;height:auto;max-height:100%;min-height:0;background:#ededed;padding:10px 12px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-panel.chat-active .wx-input-wrap{flex:0 0 auto;min-height:52px;align-self:end;background:#f7f7f7;border-top:1px solid #c8c8c8;padding-bottom:env(safe-area-inset-bottom,8px)}.conv-items,.contact-list-scroll{padding-bottom:calc(56px + env(safe-area-inset-bottom))}}.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#888;padding:8px 0 4px;transition:color .15s;position:relative}.bnav-btn.active{color:var(--green)}.bnav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.bnav-label{font-size:11px;font-weight:400}.bnav-btn.active .bnav-label{font-weight:500}.bnav-badge{position:absolute;top:-5px;right:-8px;background:#e64340;color:#fff;font-size:10px;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:1.5px solid #fff}.bnav-dot{position:absolute;top:-3px;right:-3px;width:8px;height:8px;background:#e64340;border-radius:50%;border:1.5px solid #fff}.wx-input-wrap{grid-row:3;align-self:end;background:#f7f7f7;border-top:1px solid var(--border);flex:0 0 auto;min-height:52px;max-height:42vh;overflow:visible;width:100%;position:relative;z-index:8;padding-bottom:6px}.wx-input-row{display:flex;align-items:flex-end;gap:6px;padding:8px 10px;min-height:52px}.wx-ic-btn{width:36px;height:36px;flex-shrink:0;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#555;transition:background .15s;align-self:flex-end;margin-bottom:2px}.wx-ic-btn:hover{background:#0000000f}.wx-ic-btn:disabled{opacity:.35}.wx-plus-btn{width:34px;height:34px;border-radius:50%;border:1.5px solid #bbb;color:#666}.wx-textarea{flex:1;min-width:0;min-height:36px;max-height:100px;height:36px;padding:6px 12px;font-size:15px;line-height:1.6;background:#fff;border:1px solid #e0e0e0;border-radius:6px;resize:none;outline:none;color:var(--text-primary);overflow-y:auto;word-break:break-word;transition:border-color .2s,height .1s;vertical-align:middle}.wx-textarea:focus{border-color:#c8c8c8}.wx-send-btn{height:36px;padding:0 16px;background:var(--green);color:#fff;border-radius:6px;font-size:14px;font-weight:500;flex-shrink:0;align-self:flex-end;margin-bottom:2px;transition:background .15s}.wx-send-btn:hover{background:var(--green-dark)}.wx-hold-talk{flex:1;height:36px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:15px;color:var(--text-primary);align-self:flex-end;margin-bottom:2px}.wx-hold-talk.recording{background:#ffe8e8;border-color:#e64340;color:#e64340}.wx-more-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:16px 14px 20px;background:#f7f7f7;border-top:1px solid var(--border)}.wx-more-item{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.wx-more-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001f}.bubble-card{padding:0!important;overflow:hidden;min-width:200px;max-width:240px}.card-bubble{display:flex;flex-direction:column}.card-bubble-top{display:flex;align-items:center;gap:12px;padding:12px 14px 10px}.card-bubble-info{display:flex;flex-direction:column;gap:3px;min-width:0}.card-bubble-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-bubble-dept{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-bubble-footer{font-size:11px;color:var(--text-hint);padding:6px 14px;border-top:1px solid rgba(0,0,0,.08);background:#00000006}@media (max-width: 768px){.wx-textarea{font-size:16px}.wx-more-icon{width:52px;height:52px}}.wx-call-options{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);display:flex;gap:0;background:#fff;border-radius:10px;box-shadow:0 4px 20px #00000026;overflow:hidden;z-index:50;min-width:260px}.wx-call-opt-btn{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;justify-content:center;background:#fff;border:none;padding:16px 20px;font-size:13px;color:#333;cursor:pointer;transition:background .15s}.wx-call-opt-btn+.wx-call-opt-btn{border-left:1px solid #f0f0f0}.wx-call-opt-btn:hover{background:#f5f5f5}.wx-call-opt-btn svg{color:#07c160}.toggle-switch{width:44px;height:24px;border-radius:12px;background:#ddd;position:relative;flex-shrink:0;transition:background .2s;margin-left:auto}.toggle-switch.on{background:#07c160}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:left .2s}.toggle-switch.on .toggle-knob{left:22px}.privacy-sub{background:#fafafa;border-radius:8px;margin:0 0 4px;padding:4px 0}.privacy-row{padding:10px 16px!important;border-bottom:1px solid #f0f0f0}.privacy-row:last-child{border-bottom:none}.bnav-disabled{opacity:.35;cursor:default;pointer-events:none}html.dark{--bg: #1a1a1a;--bg2: #1e1e1e;--bg3: #242424;--bg4: #2a2a2a;--sidebar-bg: #111;--panel-bg: #1e1e1e;--panel-header-bg: #1a1a1a;--chat-bg: #111;--border: #2e2e2e;--hover-bg: rgba(255,255,255,.06);--active-bg: rgba(255,255,255,.1);--text-primary: #e0e0e0;--text-secondary:#8a8a8a;--text-hint: #555;--bubble-mine: #0a5c35;--bubble-theirs: #2a2a2a;--shadow: 0 1px 4px rgba(0,0,0,.4)}html.dark body{background:var(--bg);color:var(--text-primary)}html.dark .main-layout{background:var(--sidebar-bg)}html.dark .main-content{background:var(--bg2)}html.dark .sidebar{background:var(--sidebar-bg)}html.dark .bottom-nav{background:var(--bg2);border-color:var(--border)}html.dark .bottom-nav .nav-btn{color:#666}html.dark .bottom-nav .nav-btn.active{color:var(--green)}html.dark .panel-header{background:var(--panel-header-bg);border-color:var(--border)}html.dark .search-bar{background:#2a2a2a}html.dark .search-bar input{color:var(--text-primary)}html.dark .conv-list{background:var(--bg2);border-color:var(--border)}html.dark .conv-item{border-color:var(--border)}html.dark .conv-item:hover{background:var(--hover-bg)}html.dark .conv-item.active{background:var(--active-bg)}html.dark .conv-name{color:var(--text-primary)}html.dark .conv-time,html.dark .conv-preview{color:var(--text-secondary)}html.dark .contact-list{background:var(--bg2);border-color:var(--border)}html.dark .contact-detail-panel{background:var(--bg2)}html.dark .contact-tabs{background:var(--panel-header-bg);border-color:var(--border)}html.dark .contact-tabs button{color:var(--text-secondary)}html.dark .contact-tabs button.active{color:var(--green);border-bottom-color:var(--green)}html.dark .contact-item{color:var(--text-primary)}html.dark .contact-item:hover{background:var(--hover-bg)}html.dark .contact-item.active{background:var(--active-bg)}html.dark .contact-name{color:var(--text-primary)}html.dark .dept-header{background:var(--bg3);border-color:var(--border);color:var(--text-secondary)}html.dark .friend-req-entry{border-color:var(--border)}html.dark .friend-req-entry:hover{background:var(--hover-bg)}html.dark .friend-req-entry.active{background:var(--active-bg)}html.dark .freq-label{color:var(--text-primary)}html.dark .chat-area,html.dark .chat-window{background:var(--chat-bg)}html.dark .chat-header{background:var(--bg2);border-color:var(--border);color:var(--text-primary)}html.dark .chat-header .chat-title{color:var(--text-primary)}html.dark .messages-area{background:var(--chat-bg)}html.dark .msg-name{color:var(--text-secondary)}html.dark .msg-bubble{background:var(--bubble-theirs);color:var(--text-primary)}html.dark .msg-bubble.bubble-mine{background:var(--bubble-mine);color:#e0e0e0}html.dark .msg-time{color:var(--text-hint)}html.dark .recalled-tip{color:var(--text-secondary)}html.dark .reply-quote{background:var(--bg4);border-left-color:#07c160}html.dark .reply-quote-name{color:#8ec8ff}html.dark .reply-quote-text{color:var(--text-secondary)}html.dark .reply-quote-close{color:var(--text-hint)}html.dark .msg-reply-quote{background:#ffffff17;border-left-color:#07c160;border-radius:3px}html.dark .msg-reply-name{color:#8ec8ff}html.dark .msg-reply-text{color:#ffffff9e}html.dark .wx-input-wrap{background:var(--bg2);border-color:var(--border)}html.dark .wx-textarea{background:var(--bg4);color:var(--text-primary)}html.dark .wx-more-panel{background:var(--bg2);border-color:var(--border)}html.dark .wx-toolbar-btn{color:var(--text-secondary)}html.dark .wx-toolbar-btn:hover{background:var(--hover-bg)}html.dark .wx-more-item{color:var(--text-primary)}html.dark .wx-more-item-icon{background:var(--bg4)}html.dark .profile-page{background:var(--bg)}html.dark .profile-card{background:var(--bg2)}html.dark .profile-header{background:var(--bg2);border-color:var(--border)}html.dark .profile-header h2{color:var(--text-primary)}html.dark .profile-id-label{color:var(--text-secondary)}html.dark .profile-id-value{color:var(--text-primary)}html.dark .profile-body{background:var(--bg2)}html.dark .info-row{border-color:var(--border)}html.dark .info-label{color:var(--text-secondary)}html.dark .info-value{color:var(--text-primary)}html.dark .profile-field label{color:var(--text-secondary)}html.dark .profile-field input{background:var(--bg4);color:var(--text-primary);border-color:var(--border)}html.dark .profile-settings{background:var(--bg2);border-color:var(--border)}html.dark .profile-settings h3{color:var(--text-secondary)}html.dark .invite-day-chip{background:var(--bg3);border-color:var(--border)}html.dark .invite-day-chip:hover,html.dark .invite-day-chip.active{background:#07c1601f;border-color:var(--green)}html.dark .invite-result-block{background:var(--bg3)}html.dark .settings-row{border-color:var(--border)}html.dark .settings-row:hover{background:var(--hover-bg)}html.dark .settings-label{color:var(--text-primary)}html.dark .settings-value{color:var(--text-secondary)}html.dark .privacy-sub{background:var(--bg3)}html.dark .modal-overlay{background:#000000b3}html.dark .modal-box{background:var(--bg2);border-color:var(--border)}html.dark .modal-header{background:var(--bg2);border-color:var(--border);color:var(--text-primary)}html.dark .modal-input{background:var(--bg4);color:var(--text-primary);border-color:var(--border)}html.dark .modal-close,html.dark .modal-back-btn{color:var(--text-secondary)}html.dark .detail-card{background:var(--bg2)}html.dark .detail-name{color:var(--text-primary)}html.dark .detail-position{color:var(--text-secondary)}html.dark .detail-row{border-color:var(--border)}html.dark .detail-label{color:var(--text-secondary)}html.dark .detail-value{color:var(--text-primary)}html.dark .empty-state p,html.dark .empty-list{color:var(--text-secondary)}html.dark .load-more-tip{color:#555}html.dark .freq-panel-header{background:var(--bg2);border-color:var(--border);color:var(--text-primary)}html.dark .freq-item{border-color:var(--border)}html.dark .freq-name{color:var(--text-primary)}html.dark .freq-msg{color:var(--text-secondary)}html.dark .group-manage-panel{background:var(--bg2)}html.dark .gm-header{background:var(--bg2);border-color:var(--border);color:var(--text-primary)}html.dark .gm-section-title{color:var(--text-secondary)}html.dark .gm-member-name{color:var(--text-primary)}html.dark .login-box{background:var(--bg2)}html.dark .login-logo-text{color:var(--text-primary)}html.dark .login-tabs{border-color:var(--border)}html.dark .login-tabs button{color:var(--text-secondary)}html.dark .login-input{background:var(--bg4)!important;color:var(--text-primary)!important;border-color:var(--border)!important}html.dark .invite-code-input{background:var(--bg4);color:var(--text-primary);border-color:var(--border)}html.dark .ctx-menu,html.dark .context-menu,html.dark .conv-ctx-menu{background:var(--bg2);border-color:var(--border);box-shadow:0 4px 20px #0000008c}html.dark .ctx-menu button,html.dark .context-menu button,html.dark .conv-ctx-menu button{color:var(--text-primary)}html.dark .ctx-menu button:hover,html.dark .context-menu button:hover,html.dark .conv-ctx-menu button:hover{background:var(--hover-bg)}html.dark .ctx-menu button.ctx-delete:hover{background:#ff4d4f1f}html.dark .profile-account-item{border-color:var(--border)}html.dark .profile-account-item.active{background:var(--active-bg)}html.dark .profile-account-name{color:var(--text-primary)}html.dark .profile-account-sub{color:var(--text-secondary)}html.dark .add-account-modal{background:var(--bg2)}html.dark .avatar-upload-btn{background:var(--bg4);color:var(--text-primary)}html.dark .avatar-upload-btn:hover:not(:disabled){background:#333}html.dark .avatar-color-label{color:var(--text-secondary)}html.dark .announcement-box{background:var(--bg4);border-color:var(--border)}html.dark .ann-text{color:var(--text-primary)}html.dark .workstation-inner{background:var(--bg2)}html.dark .app-item{background:var(--bg3)}html.dark .app-item:hover{background:var(--bg4)}html.dark .app-name{color:var(--text-primary)}html.dark .notice-item{background:var(--bg3);border-color:var(--border)}html.dark .notice-title{color:var(--text-primary)}html.dark .notice-time{color:var(--text-secondary)}html.dark .call-box{background:var(--bg2)}html.dark .call-name{color:var(--text-primary)}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:320px;width:320px}.toast-item{pointer-events:auto;background:#fff;border-radius:10px;box-shadow:0 4px 20px #00000029;padding:12px 12px 12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;animation:toast-in .22s cubic-bezier(.34,1.56,.64,1);border-left:3px solid var(--green);transition:box-shadow .15s,transform .15s}.toast-item:hover{box-shadow:0 6px 24px #00000038;transform:translateY(-1px)}@keyframes toast-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{flex:1;min-width:0}.toast-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-body{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-close{flex-shrink:0;color:var(--text-secondary);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .12s}.toast-close:hover{background:var(--hover-bg)}html.dark .toast-item{background:#2a2a2a;box-shadow:0 4px 20px #00000073}html.dark .toast-title{color:var(--text-primary)}html.dark .toast-body{color:var(--text-secondary)}html.dark .date-separator span{background:#ffffff14;color:var(--text-hint)}html.dark .modal-member-name{color:var(--text-primary)}html.dark .btn-modal-confirm:disabled{background:#1a5c3a;color:#666}html.dark .voice-player{background:var(--bg4)}html.dark .voice-player.mine{background:#ffffff1a}html.dark .bubble-mine .reply-quote,html.dark .bubble-mine .msg-reply-quote{background:#0000002e;border-left-color:#fff6}.avatar-edit-wrap{position:relative;cursor:pointer;flex-shrink:0}.avatar-camera-badge{position:absolute;bottom:-3px;right:-3px;width:22px;height:22px;border-radius:50%;background:#07c160;border:2px solid #fff;display:flex;align-items:center;justify-content:center}.avatar-edit-wrap:hover .avatar-camera-badge{background:#06ae56}.avatar-upload-btn{width:100%;padding:12px;background:#f5f5f5;border-radius:8px;font-size:14px;color:#333;text-align:center;margin-bottom:16px;transition:background .15s}.avatar-upload-btn:hover:not(:disabled){background:#ebebeb}.avatar-upload-btn:disabled{opacity:.5;cursor:not-allowed}.avatar-color-label{font-size:12px;color:var(--text-secondary);margin-bottom:10px}.avatar-color-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.avatar-color-swatch{width:100%;aspect-ratio:1;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:transform .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.avatar-color-swatch:hover{transform:scale(1.08)}.avatar-color-swatch.selected{box-shadow:0 0 0 3px #fff,0 0 0 5px currentColor;outline:3px solid;transform:scale(1.08)}.profile-id-row{display:flex;align-items:center;gap:6px;margin-top:6px}.profile-id-label{font-size:11px;color:#aaa}.profile-id-value{font-size:14px;font-weight:600;color:#333;letter-spacing:2px}.profile-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0;margin-left:auto}.profile-qr-img{width:64px;height:64px;border:1px solid #e8e8e8;border-radius:6px}.profile-qr-hint{font-size:11px;color:#aaa}.qr-big-box{width:300px!important}.qr-big-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-size:15px;font-weight:600}.qr-big-body{display:flex;flex-direction:column;align-items:center;padding:24px 20px;gap:12px}.qr-big-img{width:220px;height:220px}.qr-big-code{font-size:18px;font-weight:700;letter-spacing:3px;color:#333}.qr-big-tip{font-size:12px;color:#aaa;text-align:center}.add-choose-body{padding:16px;display:flex;flex-direction:column;gap:10px}.add-choose-btn{display:flex;align-items:center;gap:14px;background:#f9f9f9;border-radius:10px;padding:14px 16px;transition:background .15s;text-align:left}.add-choose-btn:hover{background:#f0f0f0}.add-choose-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.add-choose-info{flex:1;display:flex;flex-direction:column;gap:3px}.add-choose-title{font-size:15px;font-weight:500;color:#191919}.add-choose-sub{font-size:12px;color:#888}.modal-back-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;color:#666;flex-shrink:0;transition:background .15s}.modal-back-btn:hover{background:var(--hover-bg)}.scan-body{padding:0 0 16px}.scan-viewport{position:relative;width:100%;aspect-ratio:1;background:#000;overflow:hidden}.scan-video{width:100%;height:100%;object-fit:cover;display:block}.scan-frame{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.scan-corner{position:absolute;width:24px;height:24px;border-color:#07c160;border-style:solid;border-width:0}.scan-corner.tl{top:20%;left:20%;border-top-width:3px;border-left-width:3px;border-radius:2px 0 0}.scan-corner.tr{top:20%;right:20%;border-top-width:3px;border-right-width:3px;border-radius:0 2px 0 0}.scan-corner.bl{bottom:20%;left:20%;border-bottom-width:3px;border-left-width:3px;border-radius:0 0 0 2px}.scan-corner.br{bottom:20%;right:20%;border-bottom-width:3px;border-right-width:3px;border-radius:0 0 2px}.scan-line{position:absolute;left:20%;right:20%;height:2px;background:#07c160;animation:scan-sweep 2s linear infinite;top:20%}@keyframes scan-sweep{0%{top:20%}to{top:80%}}.scan-tip{text-align:center;font-size:13px;color:#888;padding:12px 16px 0}.scan-err{padding:24px 16px;text-align:center;color:#e64340;font-size:14px}.scan-success-tip{text-align:center;padding:10px;font-size:13px;color:#07c160}.modal-cancel-btn{padding:8px 20px;border-radius:6px;background:#f5f5f5;border:1px solid #ddd;color:#555;font-size:14px;cursor:pointer;transition:background .15s}.modal-cancel-btn:hover{background:#e8e8e8}.modal-danger-btn{padding:8px 20px;border-radius:6px;background:#e64340;border:none;color:#fff;font-size:14px;cursor:pointer;transition:background .15s}.modal-danger-btn:hover{background:#c0392b}.reply-quote{display:flex;align-items:center;justify-content:space-between;background:#f0f0f0;border-left:3px solid #07c160;padding:6px 10px;margin:4px 8px;border-radius:4px;font-size:13px}.reply-quote-content{flex:1;overflow:hidden}.reply-quote-name{font-weight:700;color:#576b95}.reply-quote-text{color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-quote-close{background:none;border:none;cursor:pointer;color:#999;font-size:14px;padding:0 4px}.mention-picker{background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000026;margin:0 8px 4px;max-height:180px;overflow:hidden}.mention-picker-header{font-size:12px;color:#999;padding:6px 12px 4px}.mention-picker-list{max-height:140px;overflow-y:auto}.mention-picker-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;transition:background .1s}.mention-picker-item:hover{background:#f5f5f5}.mention-picker-item span:first-of-type{font-size:14px;color:#333;flex:1}.mention-picker-dept{font-size:12px;color:#aaa}.image-message{display:flex}.image-message img{border-radius:8px;cursor:pointer;transition:opacity .15s}.image-message img:hover{opacity:.85}.file-message{display:flex;align-items:center;gap:10px;background:#f8f8f8;border:1px solid #e8e8e8;border-radius:8px;padding:10px 12px;min-width:200px;max-width:280px;cursor:pointer;transition:background .15s}.file-message:hover{background:#f0f0f0}.file-icon{font-size:24px;flex-shrink:0}.file-info{flex:1;overflow:hidden}.file-name{font-size:14px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:12px;color:#999;margin-top:2px}.msg-reply-quote{background:#0000000a;border-left:2px solid #07c160;padding:3px 8px;margin-bottom:4px;border-radius:2px;font-size:13px}.msg-reply-name{font-weight:700;color:#576b95}.msg-reply-text{color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px}.reaction-badge{display:inline-flex;align-items:center;gap:2px;background:#f0f0f0;border-radius:10px;padding:1px 6px;font-size:12px;cursor:pointer;transition:background .15s}.reaction-badge:hover{background:#e0e0e0}.reaction-badge.mine{background:#d4f9d4}.reaction-picker{display:flex;flex-wrap:wrap;gap:2px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000026;padding:8px;max-width:240px;margin-top:4px}.reaction-emoji{font-size:20px;padding:4px;border-radius:4px;background:none;border:none;cursor:pointer;transition:background .1s}.account-switcher{position:relative;margin-bottom:18px}.account-avatar-trigger{cursor:pointer;transition:opacity .2s;position:relative;display:flex;align-items:center;justify-content:center}.account-avatar-trigger:hover{opacity:.85}.account-count-badge{position:absolute;bottom:-3px;right:-3px;background:var(--green);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid var(--sidebar-bg)}.account-panel{position:absolute;left:52px;top:0;width:240px;background:#fff;border-radius:10px;box-shadow:0 4px 20px #0000002e;z-index:1000;overflow:hidden}.account-panel-header{font-size:13px;font-weight:600;color:#888;padding:12px 14px 8px;border-bottom:1px solid var(--border)}.account-panel-list{max-height:400px;overflow-y:auto}.account-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .12s;position:relative}.account-item:hover{background:var(--hover-bg)}.account-item.active{background:#f0fbf5}.account-item-info{flex:1;overflow:hidden}.account-item-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-item-sub{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-active-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;margin-right:4px}.account-remove-btn{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#bbb;flex-shrink:0;transition:background .12s,color .12s}.account-remove-btn:hover{background:#ffe0e0;color:#e64340}.account-add-btn{width:100%;display:flex;align-items:center;gap:8px;padding:11px 14px;font-size:14px;color:var(--green);border-top:1px solid var(--border);transition:background .12s}.account-add-btn:hover{background:var(--hover-bg)}.account-add-limit{margin-left:auto;font-size:11px;color:#aaa}.account-limit-tip{padding:10px 14px;font-size:12px;color:#aaa;text-align:center;border-top:1px solid var(--border)}.add-account-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;animation:overlayFadeIn .15s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.add-account-modal{width:100%;max-width:320px;max-height:90vh;overflow-y:auto;border-radius:14px;box-shadow:0 8px 40px #0000002e;background:#fff;animation:modalSlideIn .18s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.lp-modal-inner{width:100%}.lp-modal-inner .lp-box{max-width:100%;padding:0 20px 24px;border-radius:0;box-shadow:none;background:transparent}.lp-modal-header{display:flex;align-items:center;justify-content:center;position:relative;padding:22px 20px 0;margin-bottom:18px}.lp-modal-title{font-size:17px;font-weight:600;color:#191919;text-align:center}.lp-modal-close{position:absolute;right:0;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#aaa;transition:background .12s,color .12s}.lp-modal-close:hover{background:#f5f5f5;color:#555}.lp-modal-inner .lp-tabs{margin-bottom:16px}.lp-modal-inner .lp-field{border-bottom:none;background:#f5f5f5;border-radius:8px;min-height:46px;padding:0 12px;margin-bottom:10px;transition:background .15s}.lp-modal-inner .lp-field:focus-within{background:#efefef;border-color:transparent}.lp-modal-inner .lp-prefix{color:#555;font-size:14px}.lp-modal-inner .lp-divider{background:#d0d0d0;height:14px}.lp-modal-inner .lp-submit{margin-top:8px;border-radius:8px;font-size:16px;padding:13px}.lp-modal-inner .lp-error{font-size:13px;margin:2px 0 8px}.lp-modal-inner .lp-code-btn{border-radius:6px;font-size:13px;padding:8px 10px;white-space:nowrap}.lp-modal-inner .lp-demo-code{font-size:12px;margin:2px 0 8px}.profile-account-list{background:#fafafa;border-radius:8px;margin:4px 0 8px;overflow:hidden;border:1px solid var(--border)}.profile-account-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border)}.profile-account-item:last-child{border-bottom:none}.profile-account-item:hover{background:var(--hover-bg)}.profile-account-item.active{background:#f0fbf5;cursor:default}.profile-account-info{flex:1;overflow:hidden}.profile-account-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-account-sub{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-add-account-btn{width:100%;display:flex;align-items:center;gap:8px;padding:12px;font-size:14px;color:var(--green);background:none;border:none;cursor:pointer;transition:background .12s}.profile-add-account-btn:hover{background:var(--hover-bg)}@media (max-width: 480px){.lp-modal-inner .lp-box{padding:24px 20px 20px}.add-account-modal{max-width:100%;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:85vh}.add-account-overlay{align-items:flex-end}}.reaction-emoji:hover{background:#f0f0f0}.voice-player{display:flex;align-items:center;gap:8px;padding:4px 2px;cursor:pointer;min-width:110px;-webkit-user-select:none;user-select:none}.voice-play-btn{width:26px;height:26px;border-radius:50%;background:#0000001f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bubble-mine .voice-play-btn{background:#0000002e}.voice-bars{display:flex;align-items:center;gap:2px;height:20px}.voice-bar{display:block;width:3px;height:var(--h, 6px);border-radius:2px;background:currentColor;opacity:.65;transform-origin:center}.voice-player.playing .voice-bar{animation:voice-bounce .55s ease-in-out infinite alternate}@keyframes voice-bounce{0%{transform:scaleY(.35);opacity:.4}to{transform:scaleY(1.8);opacity:.9}}.voice-duration{font-size:12px;opacity:.7;flex-shrink:0;min-width:20px}.msg-read-status{font-size:10px;color:var(--green, #07c160);margin-right:4px}.msg-read-group{cursor:pointer;text-decoration:underline dotted}.msg-read-group:hover{opacity:.75}.receipts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:900}.receipts-popup{background:#fff;border-radius:12px;width:300px;max-height:420px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000002e}.receipts-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;font-size:15px;font-weight:600;border-bottom:1px solid #f0f0f0}.receipts-header button{background:none;border:none;font-size:16px;color:#999;cursor:pointer;padding:0 2px}.receipts-list{overflow-y:auto;padding:6px 0;flex:1}.receipts-loading,.receipts-empty{text-align:center;color:#aaa;padding:24px 0;font-size:13px}.receipts-item{display:flex;align-items:center;gap:10px;padding:8px 16px}.receipts-name{flex:1;font-size:14px}.receipts-time{font-size:11px;color:#aaa}.account-rail{width:54px;background:#1a1a28;display:flex;flex-direction:column;align-items:center;padding:14px 0 12px;gap:6px;flex-shrink:0;min-height:0;height:100%;z-index:20}.rail-item{position:relative;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:10px;transition:opacity .15s,transform .12s;opacity:.5;flex-shrink:0}.rail-item:hover{opacity:.85;transform:scale(1.06)}.rail-item-active{opacity:1!important}.rail-active-bar{position:absolute;left:-7px;top:50%;transform:translateY(-50%);width:3px;height:22px;background:#07c160;border-radius:0 3px 3px 0}.rail-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;background:#e64340;color:#fff;font-size:10px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #1a1a28;line-height:1}.rail-add-wrap{position:relative}.rail-add-btn{width:38px;height:38px;border-radius:10px;background:#ffffff12;color:#fff6;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;margin-top:4px}.rail-add-btn:hover{background:#07c1602e;color:#07c160}.rail-add-menu{position:absolute;left:50px;top:0;background:#fff;border-radius:10px;box-shadow:0 4px 20px #0000002e;overflow:hidden;min-width:160px;z-index:1500;animation:fadeIn .12s ease}.rail-add-menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:13px;color:var(--text-primary, #222);text-align:left;transition:background .12s}.rail-add-menu-item:hover{background:var(--hover-bg, #f5f5f5)}.rail-ctx-menu{position:fixed;z-index:2000;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000002e;overflow:hidden;min-width:130px;animation:fadeIn .1s ease}.rail-ctx-menu button{width:100%;padding:10px 14px;font-size:13px;text-align:left;transition:background .12s;color:var(--text-primary, #222)}.rail-ctx-menu button:hover{background:var(--hover-bg, #f5f5f5)}.rail-ctx-danger{color:#e64340!important}.rail-ctx-danger:hover{background:#fff5f5!important}html.dark .account-rail{background:#111118}html.dark .rail-badge{border-color:#111118}html.dark .rail-add-menu,html.dark .rail-ctx-menu{background:var(--bg2, #1e1e2e);box-shadow:0 4px 20px #00000073}html.dark .rail-add-menu-item,html.dark .rail-ctx-menu button{color:#ddd}html.dark .rail-add-menu-item:hover,html.dark .rail-ctx-menu button:hover{background:#ffffff0f}html.dark .account-switching-overlay{background:#181820}@media (max-width: 768px){.account-rail{display:none}}.account-switching-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;background:var(--bg, #fff);animation:fadeIn .15s ease}.account-switching-spinner{width:36px;height:36px;border:3px solid rgba(7,193,96,.2);border-top-color:#07c160;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.account-switching-text{font-size:14px;color:var(--text-secondary, #888)}.qr-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#0000008c;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.qr-modal-box{background:#fff;border-radius:18px;padding:32px 32px 24px;width:320px;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;box-shadow:0 16px 60px #00000038;animation:modalSlideIn .18s ease}.qr-modal-close{position:absolute;top:12px;right:14px;width:28px;height:28px;border-radius:50%;font-size:16px;color:#aaa;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.qr-modal-close:hover{background:#f0f0f0;color:#555}.qr-modal-title{font-size:17px;font-weight:600;color:#111}.qr-modal-subtitle{font-size:13px;color:#999;margin-bottom:4px}.qr-code-area{width:240px;height:240px;border:1.5px solid #eee;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background:#fafafa}.qr-code-img{width:100%;height:100%;border-radius:10px;display:block}.qr-code-dim{opacity:.25}.qr-state-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:13px;color:#888;text-align:center;padding:16px}.qr-state-success{color:#07c160}.qr-state-expired{position:relative;width:100%;height:100%}.qr-expired-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-radius:10px;font-size:13px;color:#555}.qr-refresh-btn{margin-top:4px;padding:6px 18px;background:#07c160;color:#fff;border-radius:20px;font-size:13px;transition:background .15s}.qr-refresh-btn:hover{background:#059a4c}.qr-spinner{width:32px;height:32px;border:3px solid rgba(7,193,96,.2);border-top-color:#07c160;border-radius:50%;animation:spin .7s linear infinite}.qr-countdown{font-size:12px;font-variant-numeric:tabular-nums;transition:color .3s}.qr-scan-url-row{display:flex;align-items:center;gap:8px;width:100%;background:#f5f5f5;border-radius:8px;padding:7px 10px}.qr-scan-url-text{flex:1;font-size:11px;color:#999;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-copy-btn{font-size:12px;color:#07c160;flex-shrink:0;padding:2px 8px;border-radius:4px;border:1px solid rgba(7,193,96,.4);transition:background .15s}.qr-copy-btn:hover{background:#07c16014}html.dark .qr-scan-url-row{background:#ffffff0f}html.dark .qr-scan-url-text{color:#666}.qr-modal-footer{display:flex;align-items:center;gap:6px;margin-top:4px}.qr-alt-btn{font-size:12px;color:#07c160;text-decoration:underline;background:none;border:none;cursor:pointer;padding:0}html.dark .qr-modal-box{background:var(--bg2, #1e1e2e)}html.dark .qr-modal-title{color:#eee}html.dark .qr-code-area{border-color:#ffffff1a;background:#2a2a3a}html.dark .qr-modal-close:hover{background:#ffffff14;color:#ccc}html.dark .qr-expired-overlay{background:#1e1e2ee6;color:#bbb}.qr-confirm-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,#e8f4ed,#dce8f0);padding:20px}.qr-confirm-card{background:#fff;border-radius:20px;padding:36px 32px;width:100%;max-width:360px;box-shadow:0 8px 40px #0000001f;display:flex;flex-direction:column;align-items:center;gap:16px}.qr-confirm-logo{display:flex;align-items:center;gap:10px}.qr-confirm-app-name{font-size:20px;font-weight:700;color:#07c160}.qr-confirm-title{font-size:18px;font-weight:600;color:#111}.qr-confirm-user{display:flex;align-items:center;gap:14px;width:100%;background:#f8f8f8;border-radius:12px;padding:14px 16px}.qr-confirm-user-info{flex:1;min-width:0}.qr-confirm-name{font-size:15px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qr-confirm-sub{font-size:12px;color:#999;margin-top:2px}.qr-confirm-desc{font-size:13px;color:#666;text-align:center;line-height:1.6}.qr-confirm-err{font-size:13px;color:#e64340;background:#fff5f5;border-radius:8px;padding:8px 14px;width:100%;text-align:center}.qr-confirm-btns{display:flex;gap:12px;width:100%;margin-top:4px}.qr-confirm-cancel{flex:1;padding:13px;border-radius:10px;font-size:15px;background:#f5f5f5;color:#555;border:none;cursor:pointer;transition:background .15s}.qr-confirm-cancel:hover{background:#eaeaea}.qr-confirm-ok{flex:1.5;padding:13px;border-radius:10px;font-size:15px;font-weight:600;background:#07c160;color:#fff;border:none;cursor:pointer;transition:background .15s}.qr-confirm-ok:hover{background:#059a4c}.qr-confirm-ok:disabled,.qr-confirm-cancel:disabled{opacity:.6;cursor:not-allowed}.qr-confirm-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 0}.qr-confirm-done-title{font-size:20px;font-weight:600;color:#07c160}.qr-confirm-done-desc{font-size:13px;color:#888;text-align:center}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-shine{background:linear-gradient(90deg,#ececec 25%,#f5f5f5,#ececec 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear}.msg-skeleton{padding:16px 12px}.msg-skeleton-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:14px}.msg-skeleton-row.mine{flex-direction:row-reverse}.msg-skeleton-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0}.msg-skeleton-bubble{height:38px;border-radius:12px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .1s ease}.confirm-box{background:#fff;border-radius:12px;padding:24px 28px 20px;min-width:280px;max-width:360px;box-shadow:0 8px 32px #0000002e}.confirm-msg{font-size:14px;color:#333;line-height:1.6;margin:0 0 20px}.confirm-btns{display:flex;gap:10px;justify-content:flex-end}.confirm-btn-cancel{padding:7px 18px;border-radius:6px;border:1px solid #ddd;background:#f5f5f5;color:#555;font-size:13px;cursor:pointer}.confirm-btn-cancel:hover{background:#e8e8e8}.confirm-btn-ok{padding:7px 18px;border-radius:6px;border:none;background:#e64340;color:#fff;font-size:13px;cursor:pointer;font-weight:500}.confirm-btn-ok:hover{background:#c9302c}html.dark .confirm-box{background:#2c2c2c}html.dark .confirm-msg{color:#e0e0e0}html.dark .confirm-btn-cancel{background:#3a3a3a;border-color:#555;color:#ccc}html.dark .confirm-btn-cancel:hover{background:#444}html.dark .confirm-btn-ok{background:#c9302c}html.dark .confirm-btn-ok:hover{background:#a52824}.search-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#00000059;display:flex;align-items:flex-start;justify-content:center;padding-top:60px}.search-panel{width:520px;max-width:92vw;background:#fff;border-radius:14px;box-shadow:0 8px 40px #0000002e;overflow:hidden;display:flex;flex-direction:column;max-height:75vh}html.dark .search-panel{background:#2a2a2a}.search-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.07)}html.dark .search-panel-header{border-color:#ffffff14}.search-panel-input{flex:1;border:none;outline:none;font-size:14px;background:transparent;color:inherit}.search-panel-close{background:none;border:none;font-size:16px;cursor:pointer;color:#999;padding:2px 6px}.search-panel-results{overflow-y:auto;flex:1}.search-empty{text-align:center;padding:32px 0;color:#bbb;font-size:13px}.search-result-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.05);transition:background .12s}.search-result-item:hover{background:#07c1600f}html.dark .search-result-item:hover{background:#07c1601a}html.dark .search-result-item{border-color:#ffffff0d}.search-result-conv{font-size:11px;color:#999;display:flex;justify-content:space-between;margin-bottom:2px}.search-result-time{color:#bbb}.search-result-sender{font-size:12px;font-weight:600;color:#555;margin-bottom:3px}html.dark .search-result-sender{color:#aaa}.search-result-content{font-size:13px;color:#333;line-height:1.4}html.dark .search-result-content{color:#ddd}.e2e-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:#07c160;background:#07c1601a;border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle}
