*{box-sizing:border-box}html,body,#app{min-height:100%}body{margin:0;background:#f3f4f3;color:#202523;font-family:Arial,Microsoft YaHei,sans-serif}button,textarea,input{font:inherit}button{-webkit-tap-highlight-color:transparent}.app-shell{position:relative;min-height:100vh;max-width:460px;margin:0 auto;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#fafafa;box-shadow:0 0 0 1px #2229260d,0 18px 55px #2229261a;overflow:hidden}.app-topbar{height:66px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #eceeed;z-index:2}.top-person{min-width:0;display:flex;align-items:center;gap:10px}.top-person h1{margin:0;color:#202523;font-size:17px;line-height:1.2;letter-spacing:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.title-row{min-width:0;display:flex;align-items:center;gap:6px}.title-output-toggle{width:25px;height:25px;display:grid;place-items:center;flex:0 0 auto;border:0;border-radius:50%;background:transparent;color:#9aa19d;cursor:pointer}.title-output-toggle.active{color:#157d47}.top-person p{margin:3px 0 0;color:#79827d;font-size:12px;line-height:1.2}.partner-avatar{position:relative;width:40px;height:40px;flex:0 0 auto;border:0;border-radius:14px;background:#edf5f1;overflow:hidden;cursor:pointer}.partner-avatar.large{width:72px;height:72px;border-radius:22px}.chat-avatar{width:38px;height:38px;border-radius:10px}.avatar-face{position:absolute;left:50%;top:35%;width:42%;height:42%;border-radius:50%;background:#f1c8ac;transform:translate(-50%,-50%)}.avatar-hair{position:absolute;left:50%;top:27%;width:52%;height:28%;border-radius:999px 999px 8px 8px;background:#39443f;transform:translate(-50%);z-index:1}.avatar-shirt{position:absolute;left:50%;bottom:-8%;width:66%;height:36%;border-radius:999px 999px 0 0;background:#6e8d80;transform:translate(-50%)}.partner-avatar.large .avatar-shirt{bottom:-5%}.owner-avatar{width:38px;height:38px;display:grid;place-items:center;flex:0 0 auto;border-radius:14px;background:#eef2f8;color:#2d3b4a;font-weight:700}.chat-panel{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;background:#f5f6f5}.messages{min-height:0;padding:16px 14px 18px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.day-line{display:flex;justify-content:center}.day-line span,.system-strip,.thinking{max-width:84%;padding:6px 10px;border-radius:7px;background:#e9ecea;color:#717a75;font-size:12px;line-height:1.45;text-align:center}.message{width:100%;display:flex;align-items:flex-start;gap:10px}.message.owner{flex-direction:row-reverse}.bubble{max-width:min(76%,330px);padding:10px 12px;border-radius:14px;background:#fff;color:#202523;line-height:1.6;box-shadow:0 1px 2px #2229260a}.message.owner .bubble{background:#e4f6de}.bubble p{margin:4px 0 0;white-space:pre-wrap;word-break:break-word}.meta{display:flex;gap:8px;align-items:center;color:#737c77;font-size:12px}.meta strong{font-weight:600}.system-strip,.thinking{align-self:center}.composer{padding:9px 10px calc(10px + env(safe-area-inset-bottom));display:grid;gap:9px;background:#fff;border-top:1px solid #eceeed}.wechat-composer{min-height:48px;display:grid;grid-template-columns:40px minmax(0,1fr);gap:8px;align-items:end}.wechat-composer.is-text{grid-template-columns:40px minmax(0,1fr) auto}.composer-icon{width:40px;height:42px;display:grid;place-items:center;border:0;border-radius:50%;background:transparent;color:#49514d;cursor:pointer}.composer-icon.active{color:#157d47}.keyboard-icon,.mic-icon,.speaker-icon{position:relative;width:25px;height:25px;display:block}.keyboard-icon:before{content:"";position:absolute;left:1px;top:5px;width:23px;height:16px;border:2px solid currentColor;border-radius:5px}.keyboard-icon:after{content:"";position:absolute;left:6px;top:11px;width:3px;height:3px;border-radius:50%;background:currentColor;box-shadow:6px 0 0 currentColor,12px 0 0 currentColor,3px 5px 0 currentColor,9px 5px 0 currentColor}.mic-icon:before{content:"";position:absolute;left:8px;top:2px;width:9px;height:15px;border:2px solid currentColor;border-radius:8px}.mic-icon:after{content:"";position:absolute;left:5px;top:12px;width:15px;height:10px;border-bottom:2px solid currentColor;border-left:2px solid currentColor;border-right:2px solid currentColor;border-radius:0 0 10px 10px}.speaker-icon:before{content:"";position:absolute;left:2px;top:9px;width:8px;height:8px;background:currentColor;clip-path:polygon(0 25%,45% 25%,100% 0,100% 100%,45% 75%,0 75%)}.speaker-icon:after{content:"";position:absolute;left:12px;top:6px;width:8px;height:12px;border-right:2px solid currentColor;border-radius:50%}.title-output-toggle:not(.active) .speaker-icon:after{left:14px;top:6px;width:2px;height:14px;border-right:2px solid currentColor;border-radius:0;transform:rotate(45deg)}.voice-pad{min-height:42px;display:grid;place-items:center;border:1px solid #eceeed;border-radius:6px;background:#fff;color:#1f2523;cursor:pointer;box-shadow:0 1px 1px #22292608}.voice-pad strong{font-size:16px;line-height:1.2;letter-spacing:0}.voice-pad.recording{background:#f1f2f1;border-color:#dfe2e0;color:#1f2523}.composer textarea,.recording-brief textarea{width:100%;resize:none;border:1px solid #e1e4e2;border-radius:10px;background:#fff;color:#202523;line-height:1.45;outline:none}.composer textarea{min-height:40px;max-height:120px;padding:9px 10px}.recording-brief textarea{min-height:74px;padding:9px 10px}.composer textarea:focus,.recording-brief textarea:focus{border-color:#9bcfb1}.plain-button,.send-button,.primary{border:0;cursor:pointer}.send-button{height:40px;padding:0 12px;border-radius:12px;white-space:nowrap}.send-button,.primary{background:#18b66a;color:#fff}.send-button:disabled,.primary:disabled{opacity:.45;cursor:not-allowed}.primary.small{height:36px;padding:0 13px;border-radius:10px}.plain-button{height:36px;padding:0 12px;border-radius:10px;background:#f0f2f1;color:#303633}.recording-brief{border:1px solid #e5e8e6;border-radius:16px;background:#fff;padding:12px;display:grid;gap:9px}.recording-brief>div:first-child{display:grid;gap:3px}.recording-brief strong{word-break:break-word}.recording-brief span,.recording-brief label{color:#69726d;font-size:12px;line-height:1.45}.recording-brief label{display:flex;gap:7px;align-items:flex-start}.recording-brief input{margin-top:2px}.recording-brief-actions{display:flex;justify-content:flex-end;gap:8px}.app-page{min-height:0;padding:14px;display:grid;align-content:start;gap:14px;overflow-y:auto;background:#fafafa}.page-hero,.partner-card,.settings-profile-card,.settings-group,.page-section,.record-item,.mini-item{border:1px solid #e6e8e6;border-radius:14px;background:#fff}.page-hero{padding:14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.page-hero h2,.partner-card h2,.page-section h3{margin:0;letter-spacing:0}.page-hero h2,.partner-card h2{font-size:18px}.page-hero p,.partner-card p,.muted,.mini-item span,.record-item span{margin:4px 0 0;color:#69726d;font-size:12px;line-height:1.5}.page-section{padding:13px;display:grid;gap:10px}.page-section h3{font-size:15px}.record-item,.mini-item{padding:11px;display:grid;gap:5px}.record-item strong,.mini-item strong{color:#202523;font-size:14px;line-height:1.4}.record-item p{margin:0;color:#303633;line-height:1.55;word-break:break-word}.partner-card{padding:16px;display:flex;align-items:center;gap:14px}.settings-profile-card{padding:16px;display:flex;align-items:center;gap:14px;border-radius:18px}.settings-profile-card h2{margin:0;font-size:20px;letter-spacing:0}.settings-profile-card p{margin:5px 0 0;color:#69726d;font-size:12px;line-height:1.5}.settings-group{display:grid;overflow:hidden;border-radius:16px}.settings-group h3{margin:0;padding:12px 14px 8px;color:#69726d;font-size:13px;font-weight:600;letter-spacing:0}.settings-row{min-height:52px;width:100%;padding:0 14px;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;border:0;border-top:1px solid #eef0ef;background:#fff;color:#202523;text-align:left;cursor:pointer}.settings-row.editable{cursor:default}.settings-row span{min-width:0;font-size:15px}.settings-row small{max-width:170px;color:#8a918d;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-row input[type=text],.settings-row input:not([type]){width:140px;border:0;outline:none;text-align:right;color:#5d6661;background:transparent}.settings-row>i{width:8px;height:8px;border-top:1.5px solid #b8bebc;border-right:1.5px solid #b8bebc;transform:rotate(45deg)}.setting-line{min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:12px}.switch{position:relative;width:48px;height:28px;flex:0 0 auto}.switch input{position:absolute;opacity:0}.switch i{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:#cbd2ce;transition:background .18s ease}.switch i:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .18s ease;box-shadow:0 1px 3px #0000002e}.switch input:checked+i{background:#18b66a}.switch input:checked+i:after{transform:translate(20px)}.setting-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.setting-actions button{min-height:38px;border:1px solid #e1e4e2;border-radius:10px;background:#f7f8f7;color:#303633;cursor:pointer}.setting-actions button.active{background:#e5f5ec;border-color:#a8d8bd;color:#157d47}.profile-list{margin:0;display:grid;gap:8px}.profile-list div{display:grid;grid-template-columns:76px minmax(0,1fr);gap:10px}.profile-list dt{color:#69726d;font-size:12px;line-height:1.45}.profile-list dd{margin:0;color:#252b28;line-height:1.45}.bottom-tabs{height:calc(58px + env(safe-area-inset-bottom));padding:5px 18px calc(5px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(3,1fr);gap:10px;background:#fffffff5;border-top:1px solid #eceeed}.bottom-tabs button{display:grid;place-items:center;align-content:center;gap:4px;border:0;border-radius:14px;background:transparent;color:#777f7a;cursor:pointer;font-size:12px}.bottom-tabs button.active{background:#f0faf5;color:#157d47}.tab-icon{position:relative;width:22px;height:22px;display:block;color:currentColor}.tab-chat:before{content:"";position:absolute;left:2px;top:4px;width:18px;height:13px;border:2px solid currentColor;border-radius:8px}.tab-chat:after{content:"";position:absolute;left:7px;bottom:2px;width:7px;height:7px;border-left:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-28deg)}.tab-memory:before{content:"";position:absolute;left:5px;top:3px;width:12px;height:16px;border:2px solid currentColor;border-radius:4px}.tab-memory:after{content:"";position:absolute;left:9px;top:8px;width:7px;height:2px;background:currentColor;box-shadow:0 5px 0 currentColor}.tab-profile:before{content:"";position:absolute;left:8px;top:3px;width:7px;height:7px;border:2px solid currentColor;border-radius:50%}.tab-profile:after{content:"";position:absolute;left:4px;bottom:2px;width:14px;height:8px;border:2px solid currentColor;border-radius:10px 10px 4px 4px}.hidden-file{display:none}button:active{transform:translateY(1px)}@media(max-width:520px){.app-shell{max-width:none;box-shadow:none}}@media(max-width:380px){.wechat-composer.is-text{grid-template-columns:38px minmax(0,1fr) auto}.send-button{padding:0 11px}.setting-actions{grid-template-columns:1fr}}@media(min-width:960px){.app-shell{min-height:calc(100vh - 32px);margin-top:16px;margin-bottom:16px;border-radius:20px}}
