*{box-sizing:border-box}body{color:#1f2933;background:#f3f5f7;min-width:320px;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}button,input{font:inherit}button{border:0}.page{background:#f8fafc;max-width:560px;min-height:100vh;margin:0 auto}.with-tabbar{padding-bottom:72px}.topbar{z-index:3;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:8px;min-height:52px;padding:10px 14px;display:flex;position:sticky;top:0}.topbar h1{flex:1;margin:0;font-size:18px;font-weight:700}.icon-btn,.primary-btn,.ghost-btn{border-radius:8px;min-height:38px;padding:0 14px}.icon-btn{background:#eef2f7;justify-content:center;align-items:center;width:38px;height:38px;padding:0;display:inline-flex}.primary-btn{color:#fff;background:#0f766e}.ghost-btn{color:#0f766e;background:#dff7f3}.status{color:#64748b;text-align:center;padding:18px}.error{color:#b42318}.form-row{gap:8px;padding:10px 14px;display:flex}.form-row input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;flex:1;min-width:0;min-height:40px;padding:0 12px}.list{padding:8px 0}.conversation{background:#fff;border-bottom:1px solid #eef2f7;gap:12px;padding:12px 14px;display:flex}.conversation.unread .conversation-title strong{font-weight:700}.avatar-wrap{flex:none;position:relative}.unread-dot{background:#fa5151;border:2px solid #fff;border-radius:999px;width:10px;height:10px;position:absolute;top:-2px;right:-2px}.avatar{color:#fff;background:#334155;border-radius:8px;flex:none;place-items:center;width:44px;height:44px;font-weight:700;display:grid}.avatar.large{border-radius:12px;width:64px;height:64px;font-size:24px}.contact-card,.profile-card{background:#fff;border-radius:8px;align-items:center;gap:14px;margin:12px 14px;padding:14px;display:flex;box-shadow:0 1px 2px #0f172a0f}.contact-card p,.profile-card p,.profile-card h2{margin:4px 0}.contact-card p,.profile-card p{color:#64748b;font-size:14px}.bottom-tabbar{z-index:10;background:#fff;border-top:1px solid #e5e7eb;grid-template-columns:repeat(3,1fr);max-width:560px;margin:0 auto;display:grid;position:fixed;bottom:0;left:0;right:0}.tab-item{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:3px;min-height:58px;font-size:12px;text-decoration:none;display:flex}.tab-item.router-link-active{color:#07c160}.we-icon{display:block}.tab-icon{line-height:1}.conversation-main{flex:1;min-width:0}.conversation-title{align-items:center;gap:8px;margin-bottom:4px;display:flex}.conversation-title strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.tag{color:#475569;background:#e2e8f0;border-radius:6px;flex:none;padding:2px 6px;font-size:12px}.last{color:#64748b;text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.chat-page{flex-direction:column;height:100dvh;min-height:0;display:flex;overflow:hidden}.messages{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:12px;overflow:auto}.history-status{color:#94a3b8;text-align:center;background:0 0;width:100%;margin:0 0 12px;padding:6px 0;font-size:12px;display:block}.history-load{cursor:pointer}.history-load:active{color:#07c160}.message{align-items:flex-start;gap:8px;margin-bottom:12px;display:flex}.message.mine{flex-direction:row-reverse}.chat-avatar{color:#fff;background:#64748b;border-radius:6px;flex:none;place-items:center;width:38px;height:38px;font-size:13px;font-weight:700;display:grid}.mine .chat-avatar{background:#0f766e}.message-body{flex-direction:column;align-items:flex-start;max-width:min(78%,390px);display:flex}.mine .message-body{align-items:flex-end}.sender-name{color:#94a3b8;margin-bottom:3px;font-size:12px}.bubble{background:#fff;border-radius:8px;padding:9px 11px;box-shadow:0 1px 2px #0f172a14}.mine .bubble{color:#111;background:#95ec69}.bubble img{border-radius:6px;max-width:210px;display:block}.voice-bubble{min-width:86px;min-height:30px;color:inherit;background:0 0;justify-content:space-between;align-items:center;padding:0;display:flex}.voice-bubble span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.voice-bubble strong{margin-left:8px;font-weight:600}.meta{color:#94a3b8;margin-top:4px;font-size:12px}.file-input{display:none}.wechat-composer{background:#f7f7f7;border-top:1px solid #e0e0e0;flex:none}.composer-row{grid-template-columns:42px minmax(0,1fr) 42px 42px;align-items:center;gap:9px;padding:10px 12px;display:grid}.round-tool{color:#1f2933;cursor:pointer;background:#fff;border:0;border-radius:999px;place-items:center;width:38px;height:38px;font-size:22px;line-height:1;transition:transform .12s,box-shadow .12s,background .12s;display:grid;box-shadow:0 1px 3px #00000014,0 1px 1px #0000000a}.round-tool:active{background:#eef2f7;transform:scale(.92);box-shadow:0 0 1px #0000000f}.wechat-input-wrap{background:#fff;border-radius:8px;align-items:center;min-width:0;height:44px;display:flex;box-shadow:0 1px 3px #0000000f,0 1px 1px #0000000a}.wechat-input-wrap input{caret-color:#07c160;background:0 0;border:0;outline:0;flex:1;min-width:0;height:100%;padding:0 12px;font-size:17px}.input-mic{color:#9ca3af;cursor:pointer;background:0 0;border-radius:0 8px 8px 0;place-items:center;width:40px;height:100%;transition:color .15s,background .15s;display:grid}.input-mic:active{color:#0f766e;background:#f0fdf4}.wechat-voice-hold{color:#1f2933;cursor:pointer;background:#fff;border-radius:8px;height:44px;font-size:17px;font-weight:600;transition:transform .1s,background .15s,color .15s;box-shadow:0 1px 3px #0000000f,0 1px 1px #0000000a}.wechat-voice-hold:active{background:#f0fdf4;transform:scale(.98)}.wechat-voice-hold.recording{color:#fff;background:#07c160;box-shadow:0 2px 6px #07c1604d}.emoji-panel,.more-panel{background:#f1f1f1;border-top:1px solid #dedede;min-height:250px}.emoji-panel{min-height:158px}.emoji-grid{grid-template-columns:repeat(8,1fr);gap:12px 10px;padding:22px;display:grid}.emoji-grid button{background:0 0;height:34px;font-size:28px}.more-panel{gap:22px;min-height:156px;padding:24px 28px 22px;display:flex}.more-item{color:#7b7f86;background:0 0;flex-direction:column;align-items:center;gap:10px;font-size:15px;display:flex}.more-icon{color:#4b5563;background:#fff;border-radius:14px;place-items:center;width:64px;height:64px;font-size:30px;display:grid}.dialog-mask{z-index:30;background:#0f172a59;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dialog-panel{background:#fff;border-radius:8px;width:min(100%,340px);padding:18px;box-shadow:0 18px 45px #0f172a2e}.dialog-panel h2{color:#111827;margin:0 0 14px;font-size:18px}.dialog-input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;min-height:42px;padding:0 12px}.dialog-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}
