  :root{
    --bg:#1a1714; --bg-2:#1f1b17;
    --glass:rgba(36,31,26,.74); --glass-2:rgba(42,36,30,.84); --glass-line:rgba(255,255,255,.07);
    --surface:#252019; --surface-2:#2e2820; --line:#3a3228; --line-soft:#322b23;
    --ink:#f0ebe2; --ink-dim:#b0a594; --ink-faint:#7a7060;
    --accent:#e0a063; --accent-2:#d98a52; --accent-soft:#e0a06316;
    --user-b1:#5a9e78;--user-b2:#4f9670;--user-t:#fff;
    --ai-b:rgba(46,40,32,.88); --ai-t:#f0ebe2;
    --ok:#7fc4a0; --danger:#c77;
    --serif:'Iowan Old Style',Georgia,'Songti SC',serif;
    --sans:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
    --mono:'SF Mono',ui-monospace,Menlo,monospace;
  }
  html[data-theme="light"]{
    --bg:#f5f0e6; --bg-2:#efe8db;
    --glass:rgba(255,253,248,.74); --glass-2:rgba(255,253,248,.86); --glass-line:rgba(120,90,50,.08);
    --surface:#fffdf8; --surface-2:#f7f1e6; --line:#e8ddc9; --line-soft:#efe7d6;
    --ink:#2c2419; --ink-dim:#6e6452; --ink-faint:#a89c84;
    --accent:#c2823c; --accent-2:#b87434; --accent-soft:#c2823c12;
    --user-b1:#6fb38c;--user-b2:#5fa57d;--user-t:#fff;
    --ai-b:rgba(255,255,255,.9); --ai-t:#2c2419;
  }
  *{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
  body{font-family:var(--sans);background:var(--bg);color:var(--ink);height:100dvh;overflow:hidden;-webkit-font-smoothing:antialiased;transition:background .35s,color .35s}
  button{font-family:inherit;color:inherit} img{display:block}
  .ic{background:none;border:none;color:var(--ink-dim);width:40px;height:40px;border-radius:12px;display:grid;place-items:center;cursor:pointer;transition:.15s;flex-shrink:0}
  .ic:hover{background:var(--surface)} .ic:active{transform:scale(.92)}
  .ic svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

  .topbar{height:calc(56px + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);display:flex;align-items:center;gap:6px;padding-left:8px;padding-right:8px;background:var(--glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--glass-line);position:relative;z-index:5}
  .top-id{flex:1;display:flex;align-items:center;gap:11px;justify-content:center;min-width:0;cursor:pointer;border-radius:12px;padding:5px 8px}
  .top-id:active{background:var(--surface)}
  .top-av{width:38px;height:38px;border-radius:50%;flex-shrink:0;background-size:cover;background-position:center;display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2))}
  .top-meta{min-width:0;line-height:1.3}
  .top-meta b{font-size:15.5px;font-weight:600;display:block;max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .top-meta small{font-size:11px;color:var(--ok);font-family:var(--mono);display:flex;align-items:center;gap:5px}
  .top-meta small::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor}
  .top-meta small.off{color:var(--ink-faint)}

  .stage{height:calc(100dvh - 56px - env(safe-area-inset-top));display:flex;flex-direction:column;position:relative}
  .bgwrap{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
  .bgwrap::after{content:'';position:absolute;inset:0;background:var(--bg);opacity:.78}
  html[data-theme="light"] .bgwrap::after{opacity:.82}
  .scroll{flex:1;overflow-y:auto;padding:20px 0 8px;position:relative;z-index:1;scroll-behavior:smooth}
  .scroll::-webkit-scrollbar{width:0}
  .thread{max-width:760px;margin:0 auto;padding:0 14px}

  .msg{display:flex;gap:10px;margin-bottom:16px;animation:rise .3s cubic-bezier(.2,.8,.3,1);align-items:flex-start}
  @keyframes rise{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:none}}
  .msg.user{flex-direction:row-reverse}
  .msg.sel{background:var(--accent-soft);border-radius:14px}
  .m-av{width:var(--av-sz,42px);height:var(--av-sz,42px);border-radius:14px;flex-shrink:0;background-size:cover;background-position:center;display:grid;place-items:center;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 2px 8px rgba(0,0,0,.18)}
  .m-av.ume{background:linear-gradient(135deg,#5a9e78,#4f9670)}
  .m-col{max-width:72%;display:flex;flex-direction:column;gap:5px;padding-top:1px}
  .msg.user .m-col{align-items:flex-end}
  .bubble-wrap{position:relative}
  .time-sep{text-align:center;margin:10px 0 14px;position:relative}
  .time-sep span{font-size:10.5px;color:var(--ink-faint);background:var(--surface);border:1px solid var(--line-soft);border-radius:20px;padding:3px 12px;letter-spacing:.5px;display:inline-block;position:relative;z-index:1}
  .sticker-img{max-width:120px;max-height:120px;border-radius:10px;display:block}
  .sticker-missing{display:inline-block;font-size:12.5px;color:var(--ink-faint);opacity:.75;padding:1px 6px;border:1px dashed var(--glass-line);border-radius:8px}
  .bubble.has-sticker{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}
  .bubble{padding:11px 15px;font-size:var(--fz,15px);line-height:1.62;white-space:pre-wrap;word-break:break-word;position:relative;box-shadow:0 2px 10px rgba(0,0,0,.14)}
  .msg.ai .bubble{background:var(--ai-b);color:var(--ai-t);border:1px solid var(--glass-line);border-radius:5px 18px 18px 18px;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%)}
  .msg.user .bubble{background:linear-gradient(135deg,var(--user-b1),var(--user-b2));color:var(--user-t);border-radius:18px 5px 18px 18px}
  .m-col .bubble~.bubble{border-radius:18px!important}
  .bubble[contenteditable=true]{outline:2px solid var(--accent);cursor:text}
  .bubble .trans{display:block;margin-top:6px;padding-top:6px;border-top:1px solid var(--glass-line);font-size:12.5px;opacity:.62;line-height:1.5}
  .bubble .raw{display:block;margin-top:7px;padding-top:7px;border-top:1px dashed var(--glass-line);font-family:var(--mono);font-size:11px;opacity:.7}
  .acts{display:none}
  /* ── 操作底部弹层 ── */
  .msg-sheet{position:fixed;bottom:0;left:0;right:0;z-index:62;background:var(--glass-2);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border-top:1px solid var(--glass-line);border-radius:22px 22px 0 0;padding:8px 18px calc(22px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .3s cubic-bezier(.2,.8,.3,1);box-shadow:0 -10px 50px rgba(0,0,0,.36)}
  .msg-sheet.show{transform:translateY(0)}
  .msg-sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--line);margin:0 auto 14px;flex-shrink:0}
  .msg-sheet-scrim{position:fixed;inset:0;z-index:61;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .25s}
  .msg-sheet-scrim.show{opacity:1;pointer-events:auto}
  .msg-sheet-title{font-size:11.5px;font-weight:600;color:var(--ink-faint);text-align:center;margin-bottom:14px;letter-spacing:.6px;text-transform:uppercase}
  .msg-sheet-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:10px}
  .msg-sheet-row.wide{grid-template-columns:repeat(2,1fr)}
  .msg-sheet-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;padding:14px 6px 12px;border-radius:16px;background:var(--surface);border:1px solid var(--line-soft);cursor:pointer;font-size:12px;font-weight:500;color:var(--ink);font-family:var(--sans);transition:.15s;width:100%;min-height:72px}
  .msg-sheet-btn:active{opacity:.72;transform:scale(.95)}
  .msg-sheet-btn.danger{color:var(--danger);background:rgba(200,100,100,.08);border-color:rgba(200,100,100,.22)}
  .msg-sheet-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
  .sheet-cancel-row{margin-top:8px}
  .msg-sheet-cancel{width:100%;padding:14px;border-radius:16px;background:var(--surface);border:1px solid var(--line-soft);font-size:15px;font-weight:600;color:var(--ink-dim);font-family:var(--sans);cursor:pointer;transition:.15s}
  .msg-sheet-cancel:active{opacity:.72}
  .act{background:none;border:none;color:var(--ink-faint);border-radius:8px;padding:4px 7px;font-size:11px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
  /* 思维链 */
  .think-wrap{margin:4px 0;border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;font-size:13px}
  .think-wrap summary{padding:7px 12px;cursor:pointer;color:var(--ink-dim);list-style:none;display:flex;align-items:center;gap:6px;user-select:none}
  .think-wrap summary::-webkit-details-marker{display:none}
  .think-wrap[open] summary{border-bottom:1px solid var(--line-soft)}
  .think-body{padding:10px 12px;color:var(--ink-faint);font-size:12px;line-height:1.65;white-space:pre-wrap;background:var(--surface)}
  /* 已读 */
  .read-receipt{display:flex;align-items:center;justify-content:flex-end;gap:4px;font-size:10.5px;color:var(--accent);opacity:.78;text-align:right;padding-right:8px;margin-top:-4px;margin-bottom:7px;animation:rcfade .4s ease}
  .read-receipt svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
  .read-receipt span{font-weight:600;letter-spacing:.3px}
  @keyframes rcfade{from{opacity:0;transform:translateY(-2px)}to{opacity:.78;transform:none}}
  /* 拍一拍提示 */
  .pat-tip{text-align:center;font-size:12px;color:var(--ink-faint);margin:8px auto;padding:5px 14px;background:var(--surface-2);border-radius:16px;width:fit-content;max-width:80%}
  /* 引用 */
  .quote-bar{background:var(--surface-2);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;padding:6px 10px;margin-bottom:6px;font-size:12px;color:var(--ink-dim);line-height:1.4;position:relative;cursor:pointer}
  .quote-bar .q-who{font-weight:600;color:var(--accent);margin-bottom:2px;font-size:11px}
  /* 拍一拍动画 */
  @keyframes tapTap{0%,100%{transform:scale(1)}25%{transform:scale(1.18) rotate(-8deg)}75%{transform:scale(1.12) rotate(6deg)}}
  .taptap-anim{animation:tapTap .5s ease}
  .taptap-tip{position:fixed;top:72px;left:50%;transform:translateX(-50%) scale(.9);background:rgba(0,0,0,.75);color:#fff;font-size:13px;border-radius:20px;padding:6px 16px;z-index:100;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s}
  .taptap-tip.show{opacity:1;transform:translateX(-50%) scale(1)}
  /* 顶部状态可点击 */
  #topStatus{cursor:pointer;transition:.15s}
  #topStatus:active{opacity:.7}
  .act:hover{background:var(--surface);color:var(--accent)} .act:active{color:var(--accent)} .act.on{color:var(--accent)}
  .act svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.9}
  .wave{display:inline-flex;gap:2px;align-items:flex-end;height:10px}
  .wave i{width:2px;background:var(--accent);border-radius:1px;animation:wv 1s infinite ease-in-out}
  .wave i:nth-child(2){animation-delay:.15s}.wave i:nth-child(3){animation-delay:.3s}.wave i:nth-child(4){animation-delay:.45s}
  @keyframes wv{0%,100%{height:3px}50%{height:10px}}
  .typing i{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ink-faint);margin:0 2px;animation:blink 1.2s infinite}
  .typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
  @keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}

  .composer{flex-shrink:0;padding:8px 14px calc(12px + env(safe-area-inset-bottom));position:relative;z-index:2}
  .field{max-width:760px;margin:0 auto;display:flex;align-items:flex-end;gap:7px;background:var(--glass-2);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--glass-line);border-radius:26px;padding:6px 6px 6px 18px;transition:border-color .15s;box-shadow:0 4px 20px rgba(0,0,0,.16)}
  .field:focus-within{border-color:var(--accent)}
  .field textarea{flex:1;background:none;border:none;color:var(--ink);font-size:15px;font-family:var(--sans);resize:none;outline:none;line-height:1.45;max-height:128px;min-height:24px;padding:8px 0}
  .send{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:.15s;box-shadow:0 2px 10px var(--accent-soft)}
  .send.reply-btn{background:var(--surface);border:1px solid var(--accent);color:var(--accent)}
  .send:disabled{opacity:.35} .send:active{transform:scale(.9)}
  .send svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .25s;z-index:30;backdrop-filter:blur(3px)}
  .scrim.show{opacity:1;pointer-events:auto}
  .drawer{position:fixed;top:0;left:0;height:100dvh;width:min(322px,84vw);background:var(--glass);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border-right:1px solid var(--glass-line);z-index:31;transform:translateX(-101%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
  .drawer.show{transform:none}
  .dr-head{padding:calc(22px + env(safe-area-inset-top)) 20px 4px;font-family:var(--serif);font-size:25px}
  .dr-sub{padding:0 20px 14px;font-size:12px;color:var(--ink-faint)}
  .dr-new{margin:0 12px 4px;display:flex;align-items:center;gap:10px;color:var(--accent);background:none;border:none;padding:12px;border-radius:13px;cursor:pointer;font-size:14.5px;font-weight:500;width:calc(100% - 24px)}
  .dr-new:hover{background:var(--accent-soft)} .dr-new svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.9}
  .dr-label{padding:14px 20px 6px;font-size:11px;color:var(--ink-faint);letter-spacing:1px;display:flex;justify-content:space-between;align-items:center}
  .dr-list{flex:1;overflow-y:auto;padding:0 10px}.dr-list::-webkit-scrollbar{width:0}
  .empty-roles{padding:30px 20px;text-align:center;color:var(--ink-faint);font-size:13px;line-height:1.7}
  .swipe-slot{position:relative;overflow:hidden;border-radius:14px;margin-bottom:4px;background:linear-gradient(90deg,#9a7050,#b5826a)}
  .swipe-item{transition:transform .2s;position:relative;z-index:2;background:var(--surface);margin-bottom:0!important;transform:translateX(0)}
  .swipe-item.active{background:var(--surface)!important;box-shadow:inset 0 0 0 1px var(--accent)}
  .swipe-del{position:absolute;right:0;top:0;bottom:0;width:80px;background:none;color:#fff;border:none;font-size:14px;cursor:pointer;z-index:1;display:grid;place-items:center;gap:3px}
  .swipe-del svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}
  .card-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;cursor:pointer;margin-bottom:4px;transition:.12s}
  .card-item:hover{background:var(--surface-2)} .card-item.active{background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--accent)}
  .ci-av{width:42px;height:42px;border-radius:13px;flex-shrink:0;background-size:cover;background-position:center;display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2))}
  .ci-meta{min-width:0;flex:1} .ci-meta b{font-size:14.5px;font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ci-meta small{font-size:11.5px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
  .ci-edit{color:var(--ink-faint);background:none;border:none;cursor:pointer;padding:8px;border-radius:9px}
  .ci-edit:hover{color:var(--accent);background:var(--surface)} .ci-edit svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
  .dr-foot{padding:10px 12px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--glass-line);display:flex;align-items:center;gap:8px}
  .dr-foot .me{flex:1;display:flex;align-items:center;gap:11px;padding:8px;border-radius:13px;cursor:pointer;min-width:0}
  .dr-foot .me:hover{background:var(--surface-2)}
  .dr-foot .me .ci-av{width:36px;height:36px;background:linear-gradient(135deg,#5a9e78,#4f9670)}
  .dr-foot .me b{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .dr-foot .me small{font-size:11px;color:var(--ink-faint)}

  /* 对话列表面板 */
  .convo-back{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;color:var(--ink-dim);font-size:13px;border-radius:10px;margin:0 12px}
  .convo-back:hover{background:var(--surface-2)}
  .convo-back svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.9}
  .convo-hero{display:flex;align-items:center;gap:12px;padding:10px 20px 6px}
  .convo-hero .ci-av{width:48px;height:48px}
  .convo-hero b{font-size:17px;font-family:var(--serif)}

  .panel{position:fixed;inset:0;background:var(--bg);z-index:40;transform:translateX(101%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
  .panel.show{transform:none}
  .pn-head{height:calc(56px + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);display:flex;align-items:center;gap:4px;padding-left:6px;padding-right:6px;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-line)}
  .pn-head b{font-family:var(--serif);font-size:19px;font-weight:500;flex:1;text-align:center}
  .pn-save{color:var(--accent);font-weight:600;font-size:14px;background:none;border:none;padding:8px 14px;cursor:pointer;min-width:56px}
  .tabs{display:flex;gap:2px;padding:9px 8px 0;overflow-x:auto;border-bottom:1px solid var(--line-soft);scrollbar-width:none;background:var(--bg)}.tabs::-webkit-scrollbar{display:none}
  .tab{background:none;border:none;color:var(--ink-dim);padding:10px 13px;font-size:13.5px;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}
  .tab.active{color:var(--accent);border-bottom-color:var(--accent)}
  .pn-body{flex:1;overflow-y:auto;padding:18px 16px calc(34px + env(safe-area-inset-bottom));width:100%;max-width:680px;margin:0 auto}
  .pane{display:none} .pane.active{display:block;animation:fade .25s} @keyframes fade{from{opacity:0}to{opacity:1}}
  .pane.active{background:var(--surface);border:1px solid var(--line-soft);border-radius:16px;padding:14px 14px;margin-bottom:12px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
  .pane.collapsed>:not(.pane-h){display:none!important}
  .pane-h .chev{margin-left:auto;transition:transform .2s;opacity:.5;display:flex}
  .pane-h .chev svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.2}
  .pane.collapsed .pane-h .chev{transform:rotate(-90deg)}
  .pane-h.foldable{cursor:pointer;margin-bottom:0;padding-bottom:2px}
  .pane.active:not(.collapsed) .pane-h.foldable{margin-bottom:14px}
  .pane.active ~ .pane.active{margin-top:26px;padding-top:22px;border-top:1px solid var(--line-soft)}
  .pane-h{font-family:var(--serif);font-size:17px;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:8px}
  .pane-h::before{content:'';width:4px;height:16px;border-radius:2px;background:var(--accent)}

  .fld{display:block;margin-top:16px} .fld:first-child{margin-top:0}
  .fld-label{font-size:12px;color:var(--ink-dim);margin-bottom:7px;display:flex;justify-content:space-between;align-items:center}
  .fld-label .hint{color:var(--ink-faint);font-weight:400}
  input[type=text],input[type=password],input[type=number],input[type=datetime-local],input:not([type]),select,textarea.ta{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:12px;padding:12px 14px;font-size:14px;font-family:var(--sans);outline:none;transition:border-color .15s}
  input:focus,select:focus,textarea.ta:focus{border-color:var(--accent)}
  textarea.ta{resize:vertical;line-height:1.6;min-height:64px}
  select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M2 4l4 4 4-4' stroke='%239aa0ad' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}

  .sec-title{font-size:11px;color:var(--accent);letter-spacing:1.2px;margin:26px 0 6px;text-transform:uppercase;font-weight:600;opacity:.85}
  /* 主题模式卡 */
  .theme-pick{display:flex;gap:12px;margin-top:10px}
  .theme-card{flex:1;background:var(--surface);border:1.5px solid var(--line);border-radius:16px;padding:12px;cursor:pointer;transition:.18s;display:flex;flex-direction:column;align-items:center;gap:9px}
  .theme-card.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .theme-card .tc-prev{width:100%;height:48px;border-radius:10px;display:flex;flex-direction:column;justify-content:center;gap:5px;padding:0 12px;overflow:hidden}
  .theme-card .tc-prev i{height:7px;border-radius:4px;display:block}
  .theme-card .tc-prev i:first-child{width:62%} .theme-card .tc-prev i:last-child{width:40%}
  .tc-prev.tc-dark{background:#1a1714} .tc-prev.tc-dark i{background:#5a9e78} .tc-prev.tc-dark i:last-child{background:#3a3228}
  .tc-prev.tc-light{background:#f5f0e6} .tc-prev.tc-light i{background:#6fb38c} .tc-prev.tc-light i:last-child{background:#e8ddc9}
  .theme-card .tc-name{font-size:13px;font-weight:600;color:var(--ink-dim)}
  .theme-card.on .tc-name{color:var(--accent)}
  /* 背景预设 */
  .bg-pick{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:10px}
  .bg-pick .bgo{aspect-ratio:1;border-radius:12px;cursor:pointer;border:2px solid transparent;background-size:cover;background-position:center;position:relative;transition:.15s;display:grid;place-items:center;font-size:11px;color:var(--ink-faint)}
  .bg-pick .bgo.on{border-color:var(--accent)}
  .bg-pick .bgo.none{background:var(--surface-2);border:1px dashed var(--line)}
  .bg-pick .bgo.img-bgo{overflow:hidden}
  .bg-pick .bgo-del{position:absolute;top:2px;right:2px;width:16px;height:16px;background:rgba(0,0,0,.55);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;line-height:1;cursor:pointer;z-index:1}
  .bg-pick .bgo.save-bgo{background:var(--surface-2);border:1px dashed var(--accent);color:var(--accent);font-size:10px;text-align:center;padding:4px}
  .row-2{display:flex;gap:10px;align-items:flex-end} .row-2>*{flex:1}
  .test-row{display:flex;gap:8px;margin-top:12px}
  .test-row button{flex:1;padding:11px;border-radius:11px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink-dim)}
  .test-row button:hover{border-color:var(--accent);color:var(--accent)}
  .test-out{font-size:12px;margin-top:10px;padding:10px 12px;border-radius:10px;display:none}
  .test-out.ok{display:block;background:#5fd2a015;color:var(--ok);border:1px solid #5fd2a040}
  .test-out.bad{display:block;background:#ff7a7a12;color:var(--danger);border:1px solid #ff7a7a40}

  .avatar-edit{display:flex;align-items:center;gap:16px;margin-bottom:6px}
  .ae-pic{width:80px;height:80px;border-radius:24px;flex-shrink:0;background-size:cover;background-position:center;display:grid;place-items:center;color:#fff;font-weight:700;font-size:30px;background:linear-gradient(135deg,var(--accent),var(--accent-2));cursor:pointer;position:relative;box-shadow:0 4px 16px rgba(0,0,0,.2)}
  .ae-pic.ume{background:linear-gradient(135deg,#5a9e78,#4f9670)}
  .ae-pic .cam{position:absolute;inset:0;border-radius:24px;background:rgba(0,0,0,.4);display:grid;place-items:center;opacity:0;transition:.15s}
  .ae-pic:hover .cam,.ae-pic:active .cam{opacity:1} .ae-pic .cam svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8}
  .ae-tip{font-size:12.5px;color:var(--ink-faint);line-height:1.6}

  .bg-edit{display:flex;gap:10px;align-items:center;margin-top:8px}
  .bg-thumb{width:56px;height:56px;border-radius:12px;background-size:cover;background-position:center;border:1px solid var(--line);flex-shrink:0;background-color:var(--surface)}

  .preset-bar{display:flex;gap:6px;align-items:center;margin:14px 0 18px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:14px;flex-wrap:nowrap}
  .preset-bar select{flex:1;min-width:0}
  .preset-bar .mini{padding:8px 10px;white-space:nowrap;flex-shrink:0}
  .mini{background:var(--surface);border:1px solid var(--line);color:var(--ink-dim);border-radius:11px;padding:11px 12px;font-size:12.5px;cursor:pointer;white-space:nowrap}
  .mini:hover{border-color:var(--accent);color:var(--accent)} .mini.danger:hover{border-color:var(--danger);color:var(--danger)}

  .inject-row{display:flex;align-items:center;gap:8px;margin-top:7px}
  .inject-row select{flex:1}
  .inject-tag{font-size:11px;color:var(--ink-faint);width:48px;flex-shrink:0}
  .depth-in{width:84px!important;flex:none!important}

  .rule-row{display:flex;gap:8px;margin-top:8px;align-items:center}
  .rule-row input{flex:1;font-family:var(--mono);font-size:12.5px}
  .rule-del{background:none;border:1px solid var(--line);color:var(--ink-faint);width:44px;height:46px;border-radius:11px;cursor:pointer;flex-shrink:0;font-size:18px}
  .rule-del:hover{border-color:var(--danger);color:var(--danger)}
  .btn-add{margin-top:11px;width:100%;background:var(--accent-soft);border:1px dashed var(--accent);color:var(--accent);padding:11px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:500}
  .btn-add:hover{background:var(--accent);color:#fff}
  .note{font-size:12px;color:var(--ink-faint);margin-top:14px;line-height:1.8}
  .note code{font-family:var(--mono);background:var(--surface);padding:2px 6px;border-radius:5px;color:var(--accent)}

  .toggle-row{display:flex;align-items:center;justify-content:space-between;margin-top:0;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
  .toggle-row+.toggle-row{margin-top:0}
  .toggle-row:last-child{border-bottom:none}
  .toggle-row .tl{font-size:14px;color:var(--ink);font-weight:500} .toggle-row .tl small{display:block;font-size:11.5px;color:var(--ink-faint);margin-top:3px;line-height:1.5;font-weight:400}
  .switch{position:relative;width:46px;height:27px;flex-shrink:0}
  .switch input{display:none}
  .switch .track{position:absolute;inset:0;background:var(--line);border-radius:27px;transition:.2s;cursor:pointer}
  .switch .track::after{content:'';position:absolute;width:21px;height:21px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
  .switch input:checked + .track{background:var(--accent)}
  .switch input:checked + .track::after{transform:translateX(19px)}

  .big-btn{width:100%;padding:15px;border-radius:14px;font-size:14.5px;font-weight:600;cursor:pointer;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;margin-top:22px;box-shadow:0 4px 16px var(--accent-soft)}
  .ghost-btn{width:100%;padding:13px;border-radius:12px;font-size:13.5px;font-weight:500;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink-dim);margin-top:10px}
  .ghost-btn:hover{border-color:var(--accent);color:var(--accent)}
  .ie-row{display:flex;gap:10px;margin-top:14px} .ie-row button{flex:1;margin-top:0}
  .seg-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:14px;padding:16px;margin-top:14px}
  .seg-card h4{font-size:13px;color:var(--ink-dim);margin-bottom:8px;font-weight:600}
  .debug-out{font-family:var(--mono);font-size:11.5px;color:var(--ink-dim);background:var(--surface);border:1px solid var(--line-soft);border-radius:11px;padding:12px;margin-top:10px;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;line-height:1.55}

  .picker{position:fixed;left:50%;bottom:0;transform:translate(-50%,101%);width:min(440px,100%);max-height:72dvh;background:var(--glass-2);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid var(--glass-line);border-bottom:none;border-radius:22px 22px 0 0;z-index:50;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}
  .picker.show{transform:translate(-50%,0)}
  .picker-head{display:flex;align-items:center;justify-content:space-between;padding:18px 14px 12px 20px;font-size:16px;font-weight:600;font-family:var(--serif)}
  .picker-list{overflow-y:auto;padding:0 10px 14px}
  .pick-item{padding:13px 14px;border-radius:12px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:10px;word-break:break-all}
  .pick-item:hover,.pick-item:active{background:var(--surface-2)} .pick-item.cur{color:var(--accent)}
  .pick-item .chk{margin-left:auto;color:var(--accent);opacity:0} .pick-item.cur .chk{opacity:1}
  .crop-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:min(380px,92vw);background:var(--bg-2);border:1px solid var(--line);border-radius:20px;z-index:52;padding:18px;opacity:0;pointer-events:none;transition:.25s;box-shadow:0 20px 60px rgba(0,0,0,.5);max-height:90dvh;overflow-y:auto}
  .crop-modal.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
  .crop-head{font-family:var(--serif);font-size:17px;font-weight:500;text-align:center;margin-bottom:14px}
  .crop-stage{position:relative;width:100%;aspect-ratio:1;border-radius:14px;overflow:hidden;background:#000;touch-action:none;cursor:move}
  .crop-stage img{position:absolute;transform-origin:0 0;user-select:none;-webkit-user-drag:none;pointer-events:none}
  .crop-mask{position:absolute;inset:0;pointer-events:none}
  .crop-hole{position:absolute;inset:8%;border:2px solid rgba(255,255,255,.85);border-radius:18px;box-shadow:0 0 0 999px rgba(0,0,0,.5)}
  .crop-ctrl{display:flex;align-items:center;gap:12px;margin-top:14px}
  .crop-ctrl input[type=range]{flex:1;accent-color:var(--accent)}
  .crop-actions{display:flex;gap:10px;margin-top:14px} .crop-actions button{flex:1}
  
  /* 表情包选择与管理网格：图二样式 */
  .sticker-grid{display:grid!important;grid-template-columns:repeat(3,1fr);gap:14px;padding:0 16px 16px;overflow-y:auto;align-content:start}
  .emoji-grid{grid-template-columns:repeat(6,1fr);gap:8px;padding:4px 16px 16px;overflow-y:auto;align-content:start;max-height:46vh}
  .emoji-grid.kaomoji{grid-template-columns:repeat(3,1fr)}
  .emoji-cell{background:var(--surface);border:1px solid var(--line-soft);border-radius:14px;padding:12px 4px;font-size:24px;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;min-height:52px}
  .emoji-cell.kao{font-size:14px;font-family:var(--mono);white-space:nowrap;overflow:hidden}
  .emoji-cell:active{background:var(--surface-2);transform:scale(.93)}
  /* AI 帮我想回复 */
  .airep-bar{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;color:var(--accent);background:var(--surface-2);border:1px dashed var(--glass-line);border-radius:12px;padding:9px 12px;margin-bottom:7px;cursor:pointer;transition:.15s}
  .airep-bar:active{transform:scale(.98);background:var(--surface)}
  .airep-sheet{position:fixed;left:50%;bottom:0;transform:translate(-50%,101%);width:min(440px,100%);max-height:76dvh;background:var(--glass-2);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid var(--glass-line);border-bottom:none;border-radius:22px 22px 0 0;z-index:55;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}
  .airep-sheet.show{transform:translate(-50%,0)}
  .airep-head{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 10px;font-size:15px;font-weight:600;font-family:var(--serif)}
  .airep-body{overflow-y:auto;padding:0 14px 16px;display:flex;flex-direction:column;gap:12px}
  .airep-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:15px;padding:12px 13px;position:relative}
  .airep-card .ac-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
  .airep-tag{font-size:12px;font-weight:700;color:#fff;background:var(--accent);border-radius:8px;padding:3px 10px}
  .airep-card .ac-re{background:none;border:none;color:var(--accent);cursor:pointer;padding:2px;display:flex}
  .airep-card .ac-re svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}
  .airep-text{font-size:14.5px;color:var(--ink);line-height:1.6;white-space:pre-wrap;cursor:pointer;border-radius:10px;padding:6px 8px;background:var(--surface-2);transition:.15s}
  .airep-text:active{transform:scale(.98)}
  .airep-hint{font-size:11.5px;color:var(--ink-faint);margin-top:6px;text-align:center}
  .slider-row{display:flex;align-items:center;gap:10px;margin-top:4px}
  .slider-row input[type=range]{flex:1;accent-color:var(--accent)}
  .slider-val{font-size:13px;color:var(--ink-faint);min-width:44px;text-align:right}
  .seg-pick{display:flex;gap:6px}
  .seg-pick button{padding:6px 14px;border-radius:10px;border:1px solid var(--line-soft);background:var(--surface);color:var(--ink);font-size:13px;cursor:pointer;transition:.15s}
  .seg-pick button.on{background:var(--accent);color:#fff;border-color:var(--accent)}
  .stk-tab{transition:.15s}
  .stk-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
  .sticker-grid .st-cell{min-width:0;border-radius:12px;cursor:pointer;background:transparent;display:flex;flex-direction:column;align-items:center;position:relative}
  .sticker-grid .st-cell .stbox{width:100%;padding-top:100%;position:relative;background:var(--surface);border-radius:12px}
  .sticker-grid .st-cell .stbox img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;padding:4px}
  .sticker-grid .st-cell .nm{font-size:11.5px;text-align:center;padding:3px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;background:rgba(0,0,0,.5);border-radius:10px;margin-top:-12px;z-index:2;max-width:90%;box-shadow:0 1px 4px rgba(0,0,0,.2)}
  
  .sticker-manage{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
  .st-mcell{position:relative;border-radius:12px;cursor:pointer;background:transparent;display:flex;flex-direction:column;align-items:center;}
  .st-mcell .stbox{width:100%;padding-top:100%;position:relative;background:var(--surface);border-radius:12px;}
  .st-mcell .stbox img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:4px}
  .st-mcell .nm{font-size:11.5px;text-align:center;padding:3px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;background:rgba(0,0,0,.5);border-radius:10px;margin-top:-12px;z-index:2;max-width:90%;box-shadow:0 1px 4px rgba(0,0,0,.2)}
  .st-mcell .rm{position:absolute;top:-4px;right:-4px;width:24px;height:24px;border-radius:50%;background:var(--danger);color:#fff;border:2px solid var(--bg);font-size:15px;cursor:pointer;line-height:1;display:grid;place-items:center;z-index:3}

  .toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:var(--glass-2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-line);color:var(--ink);padding:12px 20px;border-radius:14px;font-size:13.5px;z-index:99;opacity:0;transition:opacity .25s;pointer-events:none;box-shadow:0 8px 30px rgba(0,0,0,.4);max-width:80vw;text-align:center}
  .toast.show{opacity:1} .toast.err{border-color:var(--danger);color:var(--danger)}
  .voicebar{display:inline-flex;align-items:center;gap:9px;min-width:120px;max-width:200px;padding:10px 14px;border-radius:18px;cursor:pointer;user-select:none}
  .msg.ai .voicebar{background:var(--ai-b);border:1px solid var(--glass-line)}
  .msg.user .voicebar{background:linear-gradient(135deg,var(--user-b1),var(--user-b2));color:var(--user-t)}
  /* 语音条+翻译 合并气泡 */
  .voice-trans-box{display:inline-block;padding:6px 6px 9px;border-radius:16px;max-width:230px}
  .voice-trans-box.a{background:var(--ai-b);border:1px solid var(--glass-line)}
  .voice-trans-box.u{background:linear-gradient(135deg,var(--user-b1),var(--user-b2))}
  .voice-trans-box .voicebar{background:transparent!important;border:none!important;box-shadow:none!important;max-width:100%}
  .voice-trans-box.u .voicebar{color:var(--user-t)}
  .voice-trans-box .trans{margin:2px 9px 0;padding-top:7px;border-top:1px solid var(--glass-line);font-size:12.5px;opacity:.62;line-height:1.5}
  .voice-trans-box .voice-cap{margin:5px 9px 0;font-size:13.5px;line-height:1.5;opacity:.92;white-space:pre-wrap}
  .voice-trans-box.u .voice-cap{color:var(--user-t)}
  .voice-trans-box.a .voice-cap{color:var(--ai-t)}
  .voice-trans-box.u .trans{color:#fff;opacity:.82;border-top-color:rgba(255,255,255,.25)}
  .voicebar .vico{width:20px;height:20px;flex-shrink:0;display:grid;place-items:center}
  .voicebar .vico svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
  .voicebar .vbars{display:inline-flex;align-items:center;gap:2px;height:16px;flex:1}
  .voicebar .vbars i{width:2.5px;background:currentColor;border-radius:2px;opacity:.65}
  .voicebar.playing .vbars i{animation:vbar .9s infinite ease-in-out}
  @keyframes vbar{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
  .voicebar .vdur{font-size:12px;opacity:.85;font-family:var(--mono);flex-shrink:0}
  /* 相片记忆卡（小手机风格） */
  .memcard{width:230px;max-width:66vw;background:#fff;border-radius:18px;padding:16px 16px 14px;box-shadow:0 4px 18px rgba(0,0,0,.14);cursor:default;display:flex;flex-direction:column;min-height:300px}
  html[data-theme="dark"] .memcard{background:#fbf8f3}
  .memcard .mc-loc{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;background:#f0ece4;color:#5a5247;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:6px 11px;border-radius:20px}
  .memcard .mc-loc svg{width:13px;height:13px;stroke:#8a7e6c;fill:none;stroke-width:1.8}
  .memcard .mc-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px 6px}
  .memcard .mc-content{font-family:var(--serif);font-size:24px;line-height:1.35;color:#2c2419;font-style:italic;word-break:break-word}
  .memcard .mc-line{width:54px;height:1px;background:#c9bda8;margin-top:16px}
  .memcard .mc-date{align-self:flex-end;font-family:var(--mono);font-size:13px;letter-spacing:1px;color:#9aa0ad}
  .photocard{width:210px;max-width:64vw;border-radius:16px;overflow:hidden;background:var(--ai-b);border:1px solid var(--glass-line);box-shadow:0 3px 14px rgba(0,0,0,.18);cursor:default}
  .msg.user .photocard{background:linear-gradient(135deg,var(--user-b1),var(--user-b2))}
  .photocard .pc-top{min-height:118px;display:grid;place-items:center;padding:18px;text-align:center;background:linear-gradient(135deg,rgba(224,160,99,.16),rgba(217,138,82,.10))}
  .msg.user .photocard .pc-top{background:rgba(255,255,255,.14)}
  .photocard .pc-emoji{font-size:40px;line-height:1}
  .photocard .pc-ph{width:44px;height:44px;stroke:var(--accent);fill:none;stroke-width:1.6;opacity:.85}
  .msg.user .photocard .pc-ph{stroke:#fff;opacity:.9}
  .photocard .pc-real{width:100%;display:block}
  .photocard .pc-cap{font-size:13px;line-height:1.55;padding:10px 13px;color:var(--ai-t)}
  .msg.user .photocard .pc-cap{color:#fff}
  /* === 撤回提示 / 旁白 / 系统提示 === */
  .sys-tip{display:block;text-align:center;font-size:12px;color:var(--ink-faint);margin:8px auto;padding:4px 16px;background:rgba(0,0,0,.12);border-radius:20px;max-width:80%;line-height:1.5;width:fit-content}
  .recall-tip{background:transparent;font-size:12px;font-style:normal;color:var(--ink-faint)}
  .narr-tip{background:transparent;font-style:italic;color:var(--ink-dim);font-size:13px;letter-spacing:.01em;padding:6px 20px;border-radius:0;max-width:90%}
  /* === Emoji 表态 === */
  .react-bar{display:flex;flex-wrap:wrap;gap:4px;margin:2px 0 6px;padding:0 6px}
  .react-bar-r{justify-content:flex-end}
  .react-bar-l{justify-content:flex-start;padding-left:48px}
  .react-btn{background:var(--surface-2);border:1px solid var(--line-soft);border-radius:20px;padding:2px 8px;font-size:13px;cursor:pointer;transition:.15s;color:var(--ink)}
  .react-btn.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
  .react-btn:hover{border-color:var(--accent)}
  .react-picker-wrap{display:none;position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.4);align-items:flex-end;justify-content:center}
  .react-picker-wrap.show{display:flex}
  .react-picker-panel{background:var(--surface);border-radius:20px 20px 0 0;padding:16px;width:100%;max-width:480px}
  .react-picker-emojis{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;padding:8px 0}
  .react-pe{background:none;border:none;font-size:32px;cursor:pointer;padding:4px;border-radius:12px;transition:.15s}
  .react-pe:hover{background:var(--surface-2);transform:scale(1.2)}
  /* === 通话弹窗 === */
  .call-modal{display:none;position:fixed;inset:0;z-index:95;background:linear-gradient(180deg,#0f1623,#1a1a2e);flex-direction:column;color:#fff;padding:0}
  .call-modal.show{display:flex}
  .call-header{display:flex;flex-direction:column;align-items:center;padding:40px 20px 16px;flex-shrink:0}
  .call-av{width:80px;height:80px;border-radius:50%;background:var(--surface-2);background-size:cover;background-position:center;display:grid;place-items:center;font-size:32px;font-weight:700;color:#fff;margin-bottom:12px;box-shadow:0 0 0 4px rgba(255,255,255,.18);flex-shrink:0}
  .call-name{font-size:22px;font-weight:700;margin-bottom:4px}
  .call-status{font-size:13px;color:rgba(255,255,255,.7);min-height:20px}
  .call-bubbles{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}
  .call-bub{max-width:72%;padding:9px 13px;border-radius:16px;font-size:14px;line-height:1.5;word-break:break-word}
  .call-bub-ai{background:rgba(255,255,255,.13);color:#fff;align-self:flex-start;border-bottom-left-radius:4px}
  .call-bub-user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
  .call-input-area{display:flex;align-items:center;gap:8px;padding:10px 12px;background:rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}
  .call-input{flex:1;background:rgba(255,255,255,.12);border:none;border-radius:20px;padding:9px 14px;color:#fff;font-size:14px;outline:none}
  .call-input::placeholder{color:rgba(255,255,255,.4)}
  .call-send{width:38px;height:38px;border-radius:50%;background:var(--accent);border:none;display:grid;place-items:center;cursor:pointer;flex-shrink:0}
  .call-send svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
  .call-end-btn{width:60px;height:60px;border-radius:50%;background:#e53935;border:none;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 16px rgba(229,57,53,.5);margin:12px auto 24px;flex-shrink:0}
  .call-end-btn:active{transform:scale(0.94)}
  .call-end-btn svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:1.8}
  /* === 心声记录 === */
  .ml-item{border-bottom:1px solid var(--line-soft);padding:10px 4px;cursor:pointer}
  .ml-item:last-child{border-bottom:none}
  .ml-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
  .ml-ts{font-size:11px;color:var(--ink-faint)}
  .ml-ck{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}
  .ml-preview{font-size:13px;color:var(--ink-dim);line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ml-full{font-size:13px;color:var(--ink);line-height:1.6;padding:8px;background:var(--surface-2);border-radius:10px;margin-top:6px;white-space:pre-wrap}
  /* 转账卡（重做） */
  .wx-transfer{width:236px;max-width:68vw;border-radius:16px;overflow:hidden;cursor:default;color:#fff;background:linear-gradient(135deg,#f5a623,#e8821e);box-shadow:0 6px 20px rgba(232,130,30,.35)}
  .wx-transfer .wt-top{display:flex;align-items:center;gap:11px;padding:15px 15px 12px}
  .wx-transfer .wt-ic{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.22);display:grid;place-items:center;flex-shrink:0}
  .wx-transfer .wt-ic svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.2}
  .wx-transfer .wt-amt{font-size:23px;font-weight:800;letter-spacing:.3px}
  .wx-transfer .wt-to{font-size:11.5px;color:rgba(255,255,255,.8);margin-top:2px}
  .wx-transfer .wt-tag{margin-left:auto;font-size:11px;color:rgba(255,255,255,.85);background:rgba(255,255,255,.2);padding:3px 9px;border-radius:20px}
  .wx-transfer .wt-note{padding:0 15px 11px;font-size:12.5px;color:rgba(255,255,255,.92)}
  .wx-transfer .wt-foot{border-top:1px solid rgba(255,255,255,.2);padding:10px 15px;font-size:12px;color:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:space-between}
  .wx-transfer .wt-actions{border-top:1px solid rgba(255,255,255,.2);display:flex;gap:0}
  .wx-transfer .wt-btn{flex:1;padding:10px 0;font-size:13px;font-weight:600;border:none;cursor:pointer;background:transparent;color:#fff;letter-spacing:.3px}
  .wx-transfer .wt-btn.accept{background:rgba(255,255,255,.15)}
  .wx-transfer .wt-btn.reject{color:rgba(255,255,255,.7);border-left:1px solid rgba(255,255,255,.2)}
  .wx-transfer .wt-btn:active{opacity:.7}
  /* 位置卡（重做） */
  .wx-loc{width:236px;max-width:68vw;border-radius:16px;overflow:hidden;background:var(--surface,#fff);box-shadow:0 6px 20px rgba(0,0,0,.18);cursor:default;color:var(--ink,#1a1a1a);border:1px solid var(--line-soft,#eee)}
  .wx-loc .wl-map{height:104px;background:linear-gradient(135deg,#3a5a7a,#26415c);position:relative;display:grid;place-items:center;overflow:hidden}
  .wx-loc .wl-map::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:22px 22px}
  .wx-loc .wl-map .pin{width:36px;height:36px;border-radius:50%;background:#ff4d4f;display:grid;place-items:center;box-shadow:0 0 0 7px rgba(255,77,79,.22);position:relative;z-index:1;animation:pinpulse 2s infinite}
  @keyframes pinpulse{0%,100%{box-shadow:0 0 0 7px rgba(255,77,79,.22)}50%{box-shadow:0 0 0 11px rgba(255,77,79,.1)}}
  .wx-loc .wl-map .pin svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:2}
  .wx-loc .wl-body{padding:11px 14px}
  .wx-loc .wl-name{font-size:15px;font-weight:700}
  .wx-loc .wl-addr{font-size:12px;color:var(--ink-faint,#999);margin-top:3px}
  .wx-loc .wl-open{font-size:12px;color:var(--accent,#3a7afe);border-top:1px solid var(--line-soft,#eee);padding:9px 14px;font-weight:600}
  /* 礼物卡（重做） */
  .wx-gift{position:relative;width:212px;max-width:64vw;border-radius:18px;overflow:hidden;cursor:default;color:#fff;background:linear-gradient(150deg,#ff8fb1,#ff5e7e 55%,#ff3d6e);box-shadow:0 8px 24px rgba(255,61,110,.38);padding:18px 16px 0;text-align:center}
  .wx-gift .g-ribbon{position:absolute;top:0;left:50%;transform:translateX(-50%);width:30px;height:100%;background:rgba(255,255,255,.16)}
  .wx-gift .g-shine{position:absolute;top:-40%;left:-30%;width:80%;height:180%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.28),transparent);transform:rotate(18deg)}
  .wx-gift .g-ic{position:relative;width:56px;height:56px;margin:2px auto 10px;border-radius:16px;background:rgba(255,255,255,.22);display:grid;place-items:center}
  .wx-gift .g-ic svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.8}
  .wx-gift .g-body{position:relative}
  .wx-gift .g-label{font-size:11px;letter-spacing:1px;color:rgba(255,255,255,.85)}
  .wx-gift .g-name{font-size:16px;font-weight:800;margin-top:3px;word-break:break-word}
  .wx-gift .g-note{font-size:12px;color:rgba(255,255,255,.9);margin-top:5px;line-height:1.4}
  .wx-gift .g-foot{position:relative;margin:14px -16px 0;padding:9px 0;font-size:12px;font-weight:600;background:rgba(255,255,255,.16);border-top:1px solid rgba(255,255,255,.22)}
  /* 加号弹窗图标 */
  .wx-pop .wx-pop-ic{width:54px;height:54px;border-radius:16px;margin:0 auto 4px;display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.18)}
  .wx-pop .wx-pop-ic svg{width:27px;height:27px;stroke:#fff;fill:none;stroke-width:2}
  .wx-pop .wx-pop-ic.transfer{background:linear-gradient(135deg,#f5a623,#e8821e)}
  .wx-pop .wx-pop-ic.location{background:linear-gradient(135deg,#3a7afe,#2c5fd6)}
  .wx-pop .wx-pop-ic.gift{background:linear-gradient(135deg,#ff8fb1,#ff3d6e)}
  .wx-pop .comp-title{margin-top:8px}
  .stat-dot{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-faint);margin-top:8px}
  .stat-dot::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--ink-faint)}
  .stat-dot.on{color:var(--ok)} .stat-dot.on::before{background:var(--ok);box-shadow:0 0 6px var(--ok)}
  .stat-dot.bad{color:var(--danger)} .stat-dot.bad::before{background:var(--danger)}
  .plus-menu{position:fixed;left:50%;bottom:0;transform:translate(-50%,101%);width:min(440px,100%);background:var(--glass-2);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid var(--glass-line);border-bottom:none;border-radius:22px 22px 0 0;z-index:50;transition:transform .3s cubic-bezier(.4,0,.2,1);padding:18px 16px calc(20px + env(safe-area-inset-bottom))}
  .plus-menu.show{transform:translate(-50%,0)}
  .plus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:6px}
  .plus-cell{display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;color:var(--ink-dim);font-size:12px}
  .plus-cell .pc-ic{width:56px;height:56px;border-radius:18px;background:var(--surface);display:grid;place-items:center;border:1px solid var(--line)}
  .plus-cell:active .pc-ic{transform:scale(.93)} .plus-cell .pc-ic svg{width:25px;height:25px;stroke:var(--accent);fill:none;stroke-width:1.8}

  /* 多选模式 */
  .sel-bar{position:fixed;left:0;right:0;bottom:0;padding:10px 12px calc(12px + env(safe-area-inset-bottom));background:var(--glass-2);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-top:1px solid var(--glass-line);z-index:25;display:none;justify-content:space-around;align-items:center;box-shadow:0 -4px 20px rgba(0,0,0,.18)}
  .sel-bar.show{display:flex}
  .sel-act{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;color:var(--ink-dim);font-size:11px;cursor:pointer;padding:4px 8px}
  .sel-act:active{transform:scale(.9)} .sel-act.danger{color:var(--danger)}
  .sel-act svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
  .sel-top{position:fixed;top:calc(env(safe-area-inset-top));left:0;right:0;height:56px;display:none;align-items:center;justify-content:space-between;padding:0 14px;background:var(--glass-2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:26;border-bottom:1px solid var(--glass-line)}
  .sel-top.show{display:flex}
  .sel-top b{font-size:15px}
  .sel-top button{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;padding:8px}
  .msg-check{position:absolute;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;border:2px solid var(--ink-faint);display:none;place-items:center;flex-shrink:0}
  .selmode .msg-check{display:grid}
  .msg-check.on{background:var(--accent);border-color:var(--accent)}
  .msg-check svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:3;opacity:0}
  .msg-check.on svg{opacity:1}

  /* 陪伴系统弹窗 & 心声弹窗公用 */
  .companion{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:min(360px,90vw);background:var(--glass-2);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid var(--glass-line);border-radius:24px;z-index:52;padding:26px 22px 22px;opacity:0;pointer-events:none;transition:.25s;box-shadow:0 20px 60px rgba(0,0,0,.45);text-align:center}
  .companion.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
  .comp-title{font-family:var(--serif);font-size:20px;margin-bottom:16px}
  .comp-avs{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:8px}
  .comp-avs .a{width:72px;height:72px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--surface);display:grid;place-items:center;color:#fff;font-weight:700;font-size:26px}
  .comp-avs .pulse{color:var(--accent);font-size:22px}
  .comp-date{font-size:13px;color:var(--ink-dim);margin:14px 0 18px;letter-spacing:.5px}
  .comp-stat{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:10px}
  .comp-stat .l{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-dim)}
  .comp-stat .l svg{width:18px;height:18px;stroke:var(--ink-dim);fill:none;stroke-width:1.8}
  .comp-stat .v{font-size:20px;font-weight:700;color:var(--accent)} .comp-stat .v small{font-size:12px;color:var(--ink-faint);font-weight:400;margin-left:3px}

  /* 世界书 / 正则 卡片 */
  .wb-card{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-soft);border-radius:13px;padding:10px 12px;margin-bottom:8px}
  .wb-card .sw{flex-shrink:0}
  .wb-card .wb-main{flex:1;min-width:0;cursor:pointer}
  .wb-card .wb-main b{font-size:14px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .wb-card .wb-main small{font-size:11px;color:var(--ink-faint);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
  .wb-card .wb-tags{display:flex;gap:5px;margin-top:4px;flex-wrap:wrap}
  .wb-tag{font-size:10px;padding:1px 7px;border-radius:8px;background:var(--accent-soft);color:var(--accent);white-space:nowrap}
  .wb-tag.gray{background:var(--line-soft);color:var(--ink-faint)}
  .wb-tag.kw{background:#5fb88a22;color:var(--ok)}
  .wb-card .wb-del{flex-shrink:0;background:none;border:1px solid var(--line);color:var(--ink-faint);width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:16px;display:grid;place-items:center}
  .wb-card .wb-del:hover{border-color:var(--danger);color:var(--danger)}
  .wb-empty{padding:24px;text-align:center;color:var(--ink-faint);font-size:13px;line-height:1.7}
  .wb-bind-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:11px;cursor:pointer;border:1px solid var(--line-soft);margin-bottom:7px}
  .wb-bind-item.on{background:var(--accent-soft);border-color:var(--accent)}
  .wb-bind-item .ck{width:22px;height:22px;border-radius:6px;border:2px solid var(--ink-faint);flex-shrink:0;display:grid;place-items:center;color:#fff}
  .wb-bind-item.on .ck{background:var(--accent);border-color:var(--accent)}
  .wb-bind-item .ck svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:3;opacity:0}
  .wb-bind-item.on .ck svg{opacity:1}
  .wb-bind-item .nm{flex:1;min-width:0}.wb-bind-item .nm b{font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .wb-bind-item .nm small{font-size:11px;color:var(--ink-faint)}
  .greet-edit-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:12px;padding:10px;margin-bottom:8px}
  .greet-edit-card .gc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
  .greet-edit-card .gc-top b{font-size:12px;color:var(--ink-faint)}
  .greet-edit-card textarea{min-height:70px}
