/* ============================================================
   Reeve — 质感精修层（加载于 im.css 之后）
   原则：
   · 墨色为主，人物色降为低饱和 duotone（衬线首字母 + 同色细环）
   · accent 只留给「决定」与 Reeve 的存在；其余信号一律收敛
   · 计时 / 标签统一 JetBrains Mono 微字号；数字 tabular
   · 卡片光影更扁：1px 细线 + 一层很远的环境影
   · Agent 的存在感 = 呼吸的 orb + 思考波纹 + mono 签名，而非更多颜色
   ============================================================ */

/* ---------- 画布背景：重新配置为干净的浅中性 + 极淡网格 ----------
   去掉旧版偏暗偏蓝的底色；网格压到几乎不可见，只留一点「设计板」质感。 */
body{
  background:oklch(97.4% .0025 250);
  background-image:
    linear-gradient(oklch(86% .006 250/.22) 1px,transparent 1px),
    linear-gradient(90deg,oklch(86% .006 250/.22) 1px,transparent 1px);
  background-size:38px 38px;background-position:-1px -1px;
}
body.no-grid{background-image:none}

/* 去掉品牌卡的边角彩色光晕（“背景边缘的阴影”）与外投影，改为干净细线卡 */
.dir-glass .brandzone::before{display:none}
.dir-glass .brandzone{background:var(--paper);border:1px solid var(--rule)}
/* app icon 收掉外发光，只留极轻内高光 */
.dir-glass .appicon{box-shadow:inset 0 1.5px 2px oklch(100% 0 0/.55)}


.im-av{--pav:var(--accent);width:48px;height:48px;border-radius:15px;
  background:color-mix(in oklab,var(--pav) 13%,var(--paper));
  color:color-mix(in oklab,var(--pav) 82%,var(--ink));
  font-family:var(--serif);font-weight:500;font-size:20px;
  box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--pav) 24%,transparent)}
.im-row.watch .im-av{background:color-mix(in oklab,var(--pav) 8%,var(--paper));
  color:color-mix(in oklab,var(--pav) 50%,var(--ink-2));
  box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--pav) 16%,transparent)}
.im-av-reeve{width:20px;height:20px;right:-3px;bottom:-3px;
  box-shadow:0 1px 4px -1px oklch(40% .05 var(--n-hue)/.3)}
.im-av-reeve .embermark{width:12px;height:12px}

.im-cnav-av{--pav:var(--accent);
  background:color-mix(in oklab,var(--pav) 13%,var(--paper));
  color:color-mix(in oklab,var(--pav) 82%,var(--ink));
  font-family:var(--serif);font-weight:500;
  box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--pav) 24%,transparent)}
.im-cnav.watch .im-cnav-av{background:color-mix(in oklab,var(--pav) 8%,var(--paper));
  color:color-mix(in oklab,var(--pav) 50%,var(--ink-2))}

.mb-av,.mb-d-av{--pav:var(--ink-3);
  background:color-mix(in oklab,var(--pav) 13%,var(--paper));
  color:color-mix(in oklab,var(--pav) 80%,var(--ink));
  font-family:var(--serif);font-weight:500;
  box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--pav) 22%,transparent)}
.mb-av.muted{background:color-mix(in oklab,var(--ink-4) 10%,var(--paper));color:var(--ink-3)}
.im-email-av,.im-c-inc-av{background:color-mix(in oklab,var(--accent-b) 16%,var(--paper));
  color:color-mix(in oklab,var(--accent-b) 85%,var(--ink));
  box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--accent-b) 26%,transparent)}

/* ---------- 会话列表：更安静的信号系统 ---------- */
.im-row{padding:10px 18px;gap:13px}
.im-row::after{left:79px;background:color-mix(in oklab,var(--rule) 72%,transparent)}
.im-row-name{font-size:15.5px;letter-spacing:-.015em}
.im-row-time{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.06em;color:var(--ink-4)}
.im-row.unread .im-row-time{color:var(--accent-2)}
.im-row-prev .pv{font-size:13px}
.im-badge{min-width:18px;height:18px;font-size:10px;font-weight:600;box-shadow:none}
.im-sum-dot{width:5px;height:5px}
.im-sum-tx{font-size:10.5px}
.im-row-sum[data-lv="now"] .im-sum-dot{box-shadow:none;background:#f2604f}
.im-row-sum[data-lv="now"] .im-sum-tx{color:color-mix(in oklab,#e0483a 74%,var(--ink));font-weight:500}
.im-row-sum[data-lv="soon"] .im-sum-tx{color:color-mix(in oklab,#b0701f 72%,var(--ink));font-weight:500}

/* identity 行收一点 */
.im-id-name{font-size:18.5px;letter-spacing:-.028em}
.im-search{height:36px;border-radius:12px}
.im-search-ph{font-size:13px}

/* ---------- Agent 存在感：首页状态线（呼吸 orb + 思考波纹） ---------- */
.im-agent{flex-shrink:0;display:flex;align-items:center;gap:9px;margin:0 18px 2px;padding:5px 2px 10px;position:relative}
.im-agent::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:1px;
  background:linear-gradient(90deg,var(--rule) 0%,color-mix(in oklab,var(--rule) 40%,transparent) 70%,transparent)}
.im-agent-orb{width:21px;height:21px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  color:var(--accent);background:var(--paper);box-shadow:inset 0 0 0 1px var(--rule)}
.im-agent-tx{flex:1;min-width:0;font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.06em;
  color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.im-agent-tx b{color:var(--accent-2);font-weight:600}
.im-agent-wave{display:flex;align-items:center;gap:2.5px;height:12px;flex-shrink:0;padding-right:2px}
.im-agent-wave i{width:2px;height:4px;border-radius:2px;background:var(--accent);opacity:.7}
@media (prefers-reduced-motion: no-preference){
  .im-agent-orb{animation:agentBreath 4.4s ease-in-out infinite}
  .im-agent-wave i{animation:agentWave 1.9s ease-in-out infinite}
  .im-agent-wave i:nth-child(2){animation-delay:.22s}
  .im-agent-wave i:nth-child(3){animation-delay:.44s}
}
@keyframes agentBreath{
  0%,100%{box-shadow:inset 0 0 0 1px var(--rule),0 0 0 0 color-mix(in oklab,var(--accent) 22%,transparent)}
  50%{box-shadow:inset 0 0 0 1px var(--accent-line),0 0 0 5px color-mix(in oklab,var(--accent) 0%,transparent)}}
@keyframes agentWave{0%,100%{height:4px;opacity:.45}50%{height:11px;opacity:.9}}

/* ---------- 会话内：Reeve 用衬线说话（编辑部声线） ---------- */
.im-msg.reeve .im-bubble{font-family:var(--serif);font-weight:400;font-size:13.5px;line-height:1.58;color:var(--ink);
  border-color:color-mix(in oklab,var(--rule) 85%,transparent)}
.im-msg.reeve.auto .im-bubble::before{font-size:7.5px;letter-spacing:.14em;color:var(--ink-4)}
.im-msg.me .im-bubble{font-weight:500;box-shadow:0 3px 9px -5px color-mix(in oklab,var(--accent) 55%,transparent)}
.im-typing-dots i{width:5px;height:5px}

/* 决定卡：扁一点、稳一点；标题进衬线 */
.im-card{border-radius:18px;border-bottom-left-radius:7px;
  box-shadow:0 1px 1px oklch(40% .05 var(--n-hue)/.05),0 16px 38px -28px oklch(40% .05 var(--n-hue)/.55)}
.im-card-head{gap:7px;margin-bottom:10px}
.im-card-kicker{background:transparent;border:none;padding:0;border-radius:0;
  font-size:8px;letter-spacing:.18em;color:var(--accent-2)}
.im-card.done .im-card-kicker{background:transparent;border:none;color:var(--ink-4)}
.im-card-title{font-family:var(--serif);font-weight:500;font-size:15.5px;letter-spacing:-.016em;line-height:1.38}
.im-card-why li{padding-left:14px;font-size:11.5px}
.im-card-why li::before{left:0;top:8px;width:7px;height:1px;border-radius:0;
  background:color-mix(in oklab,var(--accent) 55%,transparent)}
.im-draft-why li{padding-left:14px}
.im-draft-why li::before{left:0;top:8px;width:7px;height:1px;border-radius:0;
  background:color-mix(in oklab,var(--accent) 55%,transparent)}
.im-card-draft{border-radius:11px}
.im-card-draft-tag{font-size:8px;letter-spacing:.14em}
.im-card-foot{font-size:11px}

/* 来信块 / 邮件块：细一点的缘 */
.im-email-card{border-left-width:2px}
.im-mail{border-radius:14px;box-shadow:0 1px 1px oklch(40% .05 var(--n-hue)/.04),0 10px 26px -22px oklch(40% .05 var(--n-hue)/.5)}
.im-mail.out{border-left-width:2px}
.im-c-inc{border-radius:11px}

/* 日期 / 系统线：去掉药丸，改为细线夹注 */
.im-sysline{display:flex;align-items:center;gap:10px;background:transparent;border:none;padding:6px 0 2px;
  font-size:8.5px;letter-spacing:.18em;color:var(--ink-4)}
.im-sysline::before,.im-sysline::after{content:"";width:30px;height:1px;background:var(--rule)}
.im-sysline.sent{background:var(--accent-soft);border:1px solid var(--accent-line);padding:4px 12px;gap:7px;letter-spacing:.02em}
.im-sysline.sent::before,.im-sysline.sent::after{display:none}
.im-more-hint{border-style:solid;border-color:color-mix(in oklab,var(--rule) 70%,transparent);font-size:8.5px;letter-spacing:.1em}

/* composer / chips */
.im-chip{font-size:11px;padding:6px 12px}
.im-send{width:32px;height:32px;font-size:15px}
.im-card-chip{font-size:10.5px}

/* ---------- tabbar：更细的字距与更轻的选中态 ---------- */
.im-tab-lb{font-size:9.5px;letter-spacing:.01em}
.style-glass .im-tab.on:not(.im-tab-new)::before{background:color-mix(in oklab,var(--accent) 10%,transparent)}
.im-tab-newbtn{width:34px;height:34px}
.im-tab-dot{min-width:15px;height:15px;font-size:9.5px}

/* ---------- 邮箱：分段控件改墨色（accent 只留给决定） ---------- */
.mb-folder.on,.mb-segbtn.on{background:var(--ink);color:var(--screen-bg,#fff)}
.mb-folder.on .mb-folder-n{background:oklch(100% 0 0/.2)}
.mb-time,.mb-d-time{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em}
.mb-from{font-size:14.5px}
.mb-dot{width:7px;height:7px}
.mb-fab{border-radius:17px;box-shadow:0 8px 22px -8px color-mix(in oklab,var(--accent) 60%,transparent),inset 0 1px 0 oklch(100% 0 0/.3)}

/* ---------- 数字一律 tabular ---------- */
.im-row-time,.im-badge,.im-agent-tx,.mb-time,.im-email-time,.nt-vtime{font-variant-numeric:tabular-nums}

/* ============================================================
   架构重构 · 顶部抽屉栏 + 右上角头像 + 底部常驻悬浮输入 + 重命名
   ============================================================ */

/* ---------- 统一顶栏：☰ 抽屉 · 居中标题 · 右上头像（→个人页） ---------- */
.im-topbar{flex-shrink:0;display:grid;grid-template-columns:38px 1fr 38px;align-items:center;gap:8px;
  margin:4px 11px 8px;padding:6px 8px;border-radius:21px;position:relative;overflow:hidden}
.im-tb-btn{width:38px;height:38px;border-radius:999px;border:none;background:none;cursor:pointer;display:grid;place-items:center;color:var(--ink-2);padding:0;-webkit-tap-highlight-color:transparent}
.im-tb-btn:active{background:var(--paper-2)}
.im-tb-title{text-align:center;font-family:var(--ui);font-size:16px;font-weight:600;letter-spacing:-.022em;color:var(--ink)}
.im-tb-ava{width:38px;height:38px;border-radius:999px;border:none;background:none;padding:0;cursor:pointer;display:grid;place-items:center;-webkit-tap-highlight-color:transparent;justify-self:end}
.im-tb-ava:active{opacity:.7}
.im-tb-ava .avatar{width:33px;height:33px;font-size:14px}
.style-glass .im-topbar{
  background:linear-gradient(180deg,oklch(100% 0 0/.6),oklch(100% 0 0/.3));
  backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);
  border:1px solid oklch(100% 0 0/.7);
  box-shadow:inset 0 1.5px 0 oklch(100% 0 0/.95),inset 0 -8px 14px oklch(100% 0 0/.16),0 8px 22px -12px oklch(40% .05 var(--n-hue)/.4)}
.style-glass .im-topbar::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(125deg,oklch(100% 0 0/.5),transparent 46%)}
.style-glass .im-topbar>*{position:relative;z-index:1}

/* ---------- 左侧抽屉栏：主导航（消息/邮箱/文档库）+ 身份 ---------- */
.im-drawer{position:absolute;inset:0;z-index:10;pointer-events:none}
.im-drawer-scrim{position:absolute;inset:0;background:oklch(22% .02 var(--n-hue)/.32);
  backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);opacity:0;transition:opacity .3s ease}
.im-drawer.open{pointer-events:auto}
.im-drawer.open .im-drawer-scrim{opacity:1}
.im-drawer-panel{position:absolute;left:0;top:0;bottom:0;width:78%;max-width:268px;display:flex;flex-direction:column;
  padding:52px 12px 14px;transform:translateX(-102%);transition:transform .34s cubic-bezier(.32,.72,0,1);
  background:linear-gradient(180deg,oklch(99.4% .004 var(--n-hue)),oklch(97.4% .008 var(--n-hue)));
  border-right:1px solid var(--rule);box-shadow:none}
.im-drawer.open .im-drawer-panel{transform:translateX(0);box-shadow:18px 0 50px -22px oklch(30% 0 0/.28)}
.style-glass .im-drawer-panel{background:linear-gradient(180deg,oklch(100% 0 0/.86),oklch(99% .006 var(--n-hue)/.92));
  backdrop-filter:blur(34px) saturate(190%);-webkit-backdrop-filter:blur(34px) saturate(190%);border-right:1px solid oklch(100% 0 0/.6)}
.im-drawer-id{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:none;cursor:pointer;
  padding:8px 8px 14px;margin-bottom:6px;border-bottom:1px solid var(--rule);-webkit-tap-highlight-color:transparent}
.im-drawer-id:active{opacity:.7}
.im-drawer-av .avatar{width:42px;height:42px;font-size:18px;border-radius:13px}
.im-drawer-id-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.im-drawer-id-tx b{font-family:var(--ui);font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.im-drawer-id-tx span{font-family:var(--ui);font-size:11.5px;color:var(--ink-3);letter-spacing:-.004em}
.im-drawer-chev{flex-shrink:0;font-size:19px;color:var(--ink-4);font-weight:300}
.im-drawer-chev.sm{font-size:16px}
.im-drawer-nav{display:flex;flex-direction:column;gap:4px;padding-top:10px}
.im-drawer-item{display:flex;align-items:center;gap:13px;width:100%;text-align:left;border:none;background:none;cursor:pointer;
  padding:11px 11px;border-radius:14px;font-family:inherit;transition:background .14s;-webkit-tap-highlight-color:transparent}
.im-drawer-item:active{background:var(--paper-2)}
.im-drawer-item.on{background:var(--accent-soft)}
.im-drawer-ic{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;color:var(--ink-2);
  background:var(--paper-2);box-shadow:inset 0 0 0 1px var(--rule)}
.im-drawer-item.on .im-drawer-ic{color:var(--accent-2);background:var(--paper);box-shadow:inset 0 0 0 1px var(--accent-line)}
.im-drawer-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.im-drawer-tx b{font-family:var(--ui);font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-.012em}
.im-drawer-item.on .im-drawer-tx b{color:var(--accent-2)}
.im-drawer-tx span{font-family:var(--ui);font-size:11px;color:var(--ink-4);letter-spacing:-.004em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.im-drawer-n{flex-shrink:0;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--accent);color:#fff;
  font-family:var(--ui);font-size:11px;font-weight:700;display:grid;place-items:center;font-variant-numeric:tabular-nums}
.im-drawer-foot{margin-top:auto;display:flex;align-items:center;gap:8px;padding:12px 10px 2px;border-top:1px solid var(--rule);
  font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.06em;color:var(--ink-3)}
.im-drawer-orb{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;color:var(--accent);background:var(--paper);box-shadow:inset 0 0 0 1px var(--rule)}

/* ---------- 底部常驻悬浮输入：直接输入新内容 · 可收起 ---------- */
.im-hc{position:absolute;left:14px;right:14px;bottom:15px;z-index:7;display:flex;flex-direction:column;align-items:stretch;gap:7px;
  transition:transform .46s cubic-bezier(.32,.72,0,1),opacity .34s ease}
.im-hc.down{transform:translateY(calc(100% + 34px));opacity:0;pointer-events:none}
.im-hc-collapse{align-self:center;width:38px;height:20px;border:none;border-radius:999px;cursor:pointer;display:grid;place-items:center;
  color:var(--ink-3);background:linear-gradient(180deg,oklch(100% 0 0/.7),oklch(100% 0 0/.45));
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 12px -6px oklch(40% .05 var(--n-hue)/.4),inset 0 1px 0 oklch(100% 0 0/.8)}
.im-hc-collapse:active{transform:scale(.94)}
.im-hc-bar{display:flex;align-items:center;gap:8px;padding:7px 7px 7px 8px;border-radius:999px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,oklch(100% 0 0/.66),oklch(100% 0 0/.42));
  backdrop-filter:blur(26px) saturate(185%);-webkit-backdrop-filter:blur(26px) saturate(185%);
  border:1px solid oklch(100% 0 0/.74);
  box-shadow:inset 0 1.5px 0 oklch(100% 0 0/.94),0 14px 34px -14px oklch(40% .05 var(--n-hue)/.5)}
.im-hc-bar::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(125deg,oklch(100% 0 0/.5),transparent 42%)}
.im-hc-bar>*{position:relative;z-index:1}
.im-hc-tool{width:34px;height:34px;border-radius:999px;border:none;background:none;cursor:pointer;display:grid;place-items:center;color:var(--ink-3);flex-shrink:0}
.im-hc-tool:active{background:var(--paper-2)}
.im-hc-input{flex:1;min-width:0;border:none;outline:none;background:none;font-family:var(--ui);font-size:13.5px;color:var(--ink);letter-spacing:-.004em}
.im-hc-input::placeholder{color:var(--ink-3)}
.im-hc-mic,.im-hc-send{width:36px;height:36px;border-radius:999px;border:none;cursor:pointer;flex-shrink:0;display:grid;place-items:center;transition:transform .1s}
.im-hc-mic{background:none;color:var(--ink-2)}
.im-hc-mic:active{transform:scale(.92);background:var(--paper-2)}
.im-hc-send{color:#fff;background:linear-gradient(155deg,color-mix(in oklab,var(--accent) 86%,#fff),var(--accent));
  box-shadow:0 5px 13px -5px color-mix(in oklab,var(--accent) 64%,transparent),inset 0 1px 0 oklch(100% 0 0/.45)}
.im-hc-send:active{transform:scale(.9)}
/* collapsed → recall pill（从底部滑入/滑出，与输入条互补动画） */
.im-hc-fab{position:absolute;left:50%;bottom:16px;z-index:6;display:inline-flex;align-items:center;gap:8px;
  border:none;cursor:pointer;padding:10px 17px;border-radius:999px;white-space:nowrap;
  font-family:var(--ui);font-size:12.5px;font-weight:600;letter-spacing:-.006em;color:var(--accent-2);
  background:linear-gradient(180deg,oklch(100% 0 0/.68),oklch(100% 0 0/.44));
  backdrop-filter:blur(24px) saturate(185%);-webkit-backdrop-filter:blur(24px) saturate(185%);
  border:1px solid oklch(100% 0 0/.72);box-shadow:inset 0 1.5px 0 oklch(100% 0 0/.92),0 12px 30px -12px oklch(40% .05 var(--n-hue)/.46);
  transform:translate(-50%,calc(100% + 22px));opacity:0;pointer-events:none;
  transition:transform .46s cubic-bezier(.32,.72,0,1),opacity .3s ease}
.im-hc-fab.show{transform:translate(-50%,0);opacity:1;pointer-events:auto}
.im-hc-fab .embermark{color:var(--accent)}
.im-hc-fab.show:active{transform:translate(-50%,0) scale(.95)}

/* in-place 聆听模式（点麦克风进入，不再上调卡片） */
.im-hc-bar.voice{padding:6px 7px 6px 7px;gap:10px}
.im-hc-kb{width:36px;height:36px;flex-shrink:0;border-radius:999px;border:none;cursor:pointer;display:grid;place-items:center;color:var(--ink-2);background:none}
.im-hc-kb:active{transform:scale(.92);background:var(--paper-2)}
.im-hc-wavewrap{flex:1;min-width:0;height:36px;border-radius:999px;display:flex;align-items:center;gap:10px;padding:0 14px;
  background:var(--accent-soft);border:1px solid var(--accent-line)}
.im-hc-rec{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:hcRec 1.3s ease-in-out infinite}
@keyframes hcRec{0%,100%{opacity:1}50%{opacity:.3}}
.im-hc-wave{flex:1;min-width:0;display:flex;align-items:center;gap:2.5px;height:20px;overflow:hidden}
.im-hc-wave i{flex:1;min-width:2px;max-width:4px;border-radius:2px;background:var(--accent);opacity:.85;height:24%}
@media (prefers-reduced-motion: no-preference){.im-hc-wave i{height:18%;animation:hcWave 1s ease-in-out infinite}}
@keyframes hcWave{0%,100%{height:18%}50%{height:92%}}
.im-hc-vtime{flex-shrink:0;font-family:var(--mono);font-size:11.5px;font-weight:600;color:var(--accent-2);letter-spacing:.02em;font-variant-numeric:tabular-nums}

/* ---------- 会话重命名（点标题即改） ---------- */
.im-cnav-name.as-btn{display:inline-flex;align-items:center;gap:6px;max-width:100%;border:none;background:none;cursor:pointer;padding:0;font-family:inherit;-webkit-tap-highlight-color:transparent}
.im-cnav-name.as-btn .ttl{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.im-cnav-name.as-btn .rn-ic{flex-shrink:0;font-size:10px;color:var(--ink-4);opacity:.7}
.im-cnav-name.as-btn:active .rn-ic{opacity:1;color:var(--accent-2)}
.im-cnav-rename{width:100%;border:none;outline:none;background:var(--paper-2);border-radius:8px;padding:3px 8px;
  font-family:var(--ui);font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-.018em;box-shadow:inset 0 0 0 1px var(--accent-line)}

/* ---------- 深色（仅 hero 交互机）下抽屉/顶栏/悬浮输入 ---------- */
.dark-im .im-hero-phone .im-topbar,
.dark-im .im-hero-phone .im-hc-bar,
.dark-im .im-hero-phone .im-hc-collapse,
.dark-im .im-hero-phone .im-hc-fab{
  background:var(--dglass);border:1px solid var(--dglass-brd);
  box-shadow:inset 0 1px 0 oklch(100% 0 0/.12),0 14px 34px -18px oklch(6% .02 var(--n-hue)/.85)}
.dark-im .im-hero-phone .im-drawer-panel{background:linear-gradient(180deg,oklch(24% .024 var(--n-hue)/.96),oklch(20% .026 var(--n-hue)/.97));
  backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border-right:1px solid oklch(100% 0 0/.1)}
.dark-im .im-hero-phone .im-drawer-ic{background:oklch(100% 0 0/.06)}
.dark-im .im-hero-phone .im-drawer-orb{background:oklch(100% 0 0/.06)}

/* ---------- 深色（仅 hero 交互机）下的微调 ---------- */
.dark-im .im-hero-phone .im-agent-orb{background:oklch(100% 0 0/.06)}

/* ⓿ 纯色背景：彻底删掉「呼吸」mesh 与渐变，换成单一纯色，消除边缘青边（登录页保留 vivid mesh） */
body:not(.dark-im) .style-glass .phone-screen:not(.login-bg){background:oklch(98.6% .002 var(--n-hue))}
body:not(.dark-im) .style-glass .push-over{background:oklch(98.6% .002 var(--n-hue))}
body:not(.dark-im) .style-glass .phone-screen:not(.login-bg) .screen-mesh{display:none}

/* ① 去掉消息屏上「边缘的阴影」：顶栏/搜索/会话栏的浮动投影压成 1px 细线 */
.style-glass .im-topbar{box-shadow:inset 0 1px 0 oklch(100% 0 0/.72)}
.style-glass .im-search{box-shadow:inset 0 1px 0 oklch(100% 0 0/.6)}
.style-glass .im-cnav{box-shadow:inset 0 1px 0 oklch(100% 0 0/.72)}
.style-glass .im-id{box-shadow:inset 0 1px 0 oklch(100% 0 0/.72)}
.dark-im .im-hero-phone .im-topbar,
.dark-im .im-hero-phone .im-cnav{box-shadow:inset 0 1px 0 oklch(100% 0 0/.1)}

/* ①b 去掉手机本体投在画布上的「彩色边缘阴影」(device drop-shadow 带蓝青色调)，
   只留 1px 中性描边 + 顶部内高光，手机贴合画布、四周无色晕 */
.phone-screen{box-shadow:inset 0 1px 0 oklch(100% 0 0/.5);border-color:oklch(88% 0 0)}
.dark-im .im-hero-phone .phone-screen{border-color:oklch(40% 0 0)}

/* ② Reeve 头像收到「消息顶部」一次，不再逐条挤占卡片宽度 */
.im-msg.reeve .im-msg-av,
.im-cardmsg-av,
.im-draftmsg-av,
.im-typing-av{display:none}
.im-cardmsg,.im-draftmsg{gap:0}
.im-msg.reeve{max-width:93%}
/* thread 顶部的 Reeve 标识 —— IM 式：左上头像 + 名字 */
.im-thread-lead{align-self:flex-start;display:inline-flex;align-items:center;gap:9px;margin:0 0 12px 2px;flex-shrink:0}
.im-thread-lead-av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;color:var(--accent);
  background:var(--screen-bg,#fff);box-shadow:inset 0 0 0 1px var(--accent-line),0 1px 4px -1px oklch(40% .05 var(--n-hue)/.2)}
.im-thread-lead-name{font-family:var(--ui);font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.012em}
.style-glass .im-thread-lead-av{background:color-mix(in oklab,#fff 75%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.dark-im .im-hero-phone .im-thread-lead-av{background:oklch(100% 0 0/.08)}

/* ③ 滑动批准 — 精致重做 v2：单一焦点
   · 拨片 = 唯一的 accent 实心圆（决定点），轨道近白、只留一圈素描边
   · 静止时没有任何填充光晕；只有拖动中才涌出淡色水洗跟随
   · 文案用 iOS slide-to-unlock 式的流光 shimmer，不再用游离的箭头
   · 滑到底颜色反转：轨道漫成 accent，拨片变白 + 蓝勾 */
.slide{height:46px;border-radius:999px;
  background:color-mix(in oklab,var(--accent) 4.5%,var(--paper));
  border:1px solid color-mix(in oklab,var(--accent-line) 55%,transparent);
  box-shadow:inset 0 1px 2px oklch(40% .05 var(--n-hue)/.05)}
.slide-fill{min-width:0;border-radius:999px;opacity:0;
  background:color-mix(in oklab,var(--accent) 13%,transparent);
  transition:width .4s cubic-bezier(.22,1,.36,1),opacity .25s ease}
.slide.dragging .slide-fill{opacity:1;transition:opacity .12s ease}
.slide.done .slide-fill{opacity:1;background:linear-gradient(90deg,color-mix(in oklab,var(--accent) 86%,#fff),var(--accent))}
.slide-thumb{left:4px;top:4px;width:38px;height:38px;
  background:linear-gradient(180deg,color-mix(in oklab,var(--accent) 86%,#fff),var(--accent));
  box-shadow:0 2px 7px -2px color-mix(in oklab,var(--accent) 48%,transparent),inset 0 1px 0 oklch(100% 0 0/.4)}
.slide-thumb-ic{color:#fff;display:grid;place-items:center;font-size:0}
.slide-thumb-ic svg{display:block}
.slide-thumb.ok{background:#fff;box-shadow:0 2px 8px -3px oklch(0% 0 0/.3)}
.slide-thumb.ok .slide-thumb-ic{color:var(--accent)}
.slide-label{left:50px;right:14px;font-size:12.5px;font-weight:500;letter-spacing:.07em}
.slide-label-tx{background:linear-gradient(100deg,var(--accent-2) 32%,color-mix(in oklab,#fff 72%,var(--accent-2)) 50%,var(--accent-2) 68%);
  background-size:230% 100%;-webkit-background-clip:text;background-clip:text;color:transparent}
@media (prefers-reduced-motion: no-preference){.slide-label-tx{animation:slideShine 2.8s linear infinite}}
@keyframes slideShine{from{background-position:135% 0}to{background-position:-135% 0}}
.slide-donetx{font-size:12.5px;font-weight:600;letter-spacing:.04em}
.dark-im .im-hero-phone .im-agent::after{background:linear-gradient(90deg,oklch(100% 0 0/.12),transparent)}
.dark-im .im-hero-phone .mb-folder.on,.dark-im .im-hero-phone .mb-segbtn.on{background:var(--ink);color:oklch(22% .024 var(--n-hue))}
.dark-im .im-hero-phone .im-av,.dark-im .im-hero-phone .im-cnav-av{
  background:color-mix(in oklab,var(--pav) 24%,var(--paper));
  color:color-mix(in oklab,var(--pav) 55%,var(--ink))}

/* ============================================================
   ③ 底部输入栏抬到 home-indicator(safe area) 之上 + ④ 草稿编辑半屏 sheet
   ============================================================ */

/* safe area：home indicator 在 bottom:8px·高5px，screen-body 预留 22px。
   悬浮输入条/胶囊抬到 ~30px，会话内输入条底部留白加大，均不再压住指示条 */
.im-hc{bottom:30px}
.im-hc-fab{bottom:30px}
.im-foot{padding-bottom:26px}
.style-glass .im-list.has-tabbar{padding-bottom:104px}

/* 草稿编辑半屏 sheet —— 从底部滑出，直接改草稿、就地发送 */
.ds-mask{position:absolute;inset:0;z-index:34;display:flex;flex-direction:column;justify-content:flex-end;
  background:oklch(20% .02 var(--n-hue)/.36);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:imFade .2s ease both}
.ds-sheet{display:flex;flex-direction:column;height:66%;min-height:0;border-radius:24px 24px 0 0;
  background:var(--paper);padding:8px 16px 26px;
  box-shadow:0 -18px 50px -22px oklch(30% .03 var(--n-hue)/.42);animation:dsUp .32s cubic-bezier(.32,.72,0,1) both}
@keyframes dsUp{from{transform:translateY(100%)}to{transform:none}}
.ds-grab{width:38px;height:5px;border-radius:3px;background:var(--rule-2);margin:2px auto 12px;flex-shrink:0}
.ds-head{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:11px}
.ds-head-tx{min-width:0}
.ds-title{display:block;font-family:var(--ui);font-size:16.5px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.ds-sub{display:block;font-family:var(--ui);font-size:11px;color:var(--ink-3);margin-top:2px;letter-spacing:-.004em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ds-x{flex-shrink:0;width:30px;height:30px;border-radius:999px;border:none;background:var(--paper-2);color:var(--ink-3);cursor:pointer;font-size:13px;display:grid;place-items:center}
.ds-x:active{opacity:.7}
.ds-tag{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;margin-bottom:8px;
  font-family:var(--mono);font-size:8.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2)}
.ds-tag .embermark{color:var(--accent)}
.ds-field{flex:1;min-height:0;width:100%;box-sizing:border-box;resize:none;border:1px solid var(--rule);border-radius:15px;padding:14px 15px;
  font-family:var(--serif);font-weight:300;font-size:14.5px;line-height:1.62;color:var(--ink);background:var(--paper-2);outline:none;letter-spacing:-.006em}
.ds-field:focus{border-color:var(--accent-line);background:var(--paper)}
.ds-foot{flex-shrink:0;display:flex;gap:10px;margin-top:13px}
.ds-save{flex:0 0 auto;padding:0 20px;height:48px;border-radius:14px;border:1px solid var(--rule);background:var(--paper);
  font-family:var(--ui);font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.008em;cursor:pointer}
.ds-send{flex:1;height:48px;border-radius:14px;border:none;background:var(--accent);color:#fff;cursor:pointer;
  font-family:var(--ui);font-size:14.5px;font-weight:600;letter-spacing:-.008em;display:flex;align-items:center;justify-content:center;gap:7px}
.ds-send-ic{font-size:16px;font-weight:700}
.ds-save:active,.ds-send:active{opacity:.85}
.style-glass .ds-sheet{background:color-mix(in oklab,#fff 88%,transparent);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%)}
.dark-im .im-hero-phone .ds-sheet{background:color-mix(in oklab,var(--paper) 92%,transparent)}
.dark-im .im-hero-phone .ds-field{background:oklch(100% 0 0/.05)}

/* ============================================================
   多子 Agent · 保险专家（Folio）—— Reeve 代言、后台协办
   ============================================================ */
.specmark{color:var(--accent-b)}

/* ① 会话卡片上的「保险专家协办」标记（Reeve 口吻产出，专家只挂标） */
.im-card-assist{display:flex;flex-direction:column;gap:5px;margin:-2px 0 11px;padding:9px 11px;border-radius:11px;
  background:color-mix(in oklab,var(--accent-b) 6%,var(--paper));
  border:1px solid color-mix(in oklab,var(--accent-b) 20%,transparent)}
.im-card-assist-tag{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  font-family:var(--mono);font-size:8px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:color-mix(in oklab,var(--accent-b) 78%,var(--ink))}
.im-card-assist-tag .specmark{flex-shrink:0}
.im-card-assist-note{font-family:var(--ui);font-size:11.5px;line-height:1.5;letter-spacing:-.006em;
  color:color-mix(in oklab,var(--accent-b) 30%,var(--ink-2))}
.dark-im .im-hero-phone .im-card-assist{background:color-mix(in oklab,var(--accent-b) 12%,transparent);border-color:color-mix(in oklab,var(--accent-b) 28%,transparent)}

/* ② 冷启动扫描结果里的推荐卡（非阻断 · 竖向布局，窄屏友好） */
.gl-specwrap{margin-top:10px}
.gl-spec-card{padding:13px 14px 14px;border-radius:16px;
  background:color-mix(in oklab,var(--accent-b) 7%,oklch(100% 0 0/.6));
  border:1px solid color-mix(in oklab,var(--accent-b) 26%,transparent);
  box-shadow:0 10px 26px -18px color-mix(in oklab,var(--accent-b) 60%,transparent);transition:opacity .3s ease}
.gl-spec-top{display:flex;align-items:center;gap:10px}
.gl-spec-mk{width:36px;height:36px;flex-shrink:0;border-radius:11px;display:grid;place-items:center;
  background:oklch(100% 0 0/.7);box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--accent-b) 26%,transparent)}
.gl-spec-hd{flex:1;min-width:0}
.gl-spec-h{font-family:var(--ui);font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-.014em}
.gl-spec-h b{color:color-mix(in oklab,var(--accent-b) 72%,var(--ink))}
.gl-spec-kicker{font-family:var(--mono);font-size:8px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-top:3px}
.gl-spec-sub{font-family:var(--ui);font-size:11.5px;line-height:1.55;color:var(--ink-3);letter-spacing:-.004em;margin-top:10px}
.gl-spec-btns{display:flex;gap:9px;margin-top:12px}
.gl-spec-skip{flex:0 0 auto;border:1px solid var(--rule);background:var(--paper);cursor:pointer;padding:9px 16px;border-radius:11px;font-family:var(--ui);font-size:12.5px;font-weight:600;color:var(--ink-2)}
.gl-spec-skip:active{opacity:.7}
.gl-spec-in{flex:1;border:none;cursor:pointer;padding:9px 15px;border-radius:11px;font-family:var(--ui);font-size:13px;font-weight:600;color:#fff;
  background:var(--accent-b);box-shadow:0 5px 12px -4px color-mix(in oklab,var(--accent-b) 70%,transparent)}
.gl-spec-in:active{transform:scale(.97)}
.gl-spec-state{flex-shrink:0;width:24px;height:24px;border-radius:999px;display:grid;place-items:center;font-size:12px;font-weight:700}
.gl-spec-state.in{color:#fff;background:var(--accent-b)}
.gl-spec-state.skip{color:var(--ink-4);background:oklch(100% 0 0/.5)}
.gl-spec-card.skip{opacity:.62}

/* ③ 个人页「专家」一行 —— 列表 + 开关 + 一句它能做什么 */
.pf-spec{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:15px;
  background:var(--paper);border:1px solid var(--rule)}
.pf-spec-mk{width:40px;height:40px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;
  background:color-mix(in oklab,var(--accent-b) 8%,var(--paper));box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--accent-b) 24%,transparent)}
.pf-spec-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.pf-spec-tx b{font-family:var(--ui);font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-.014em}
.pf-spec-tx span{font-family:var(--ui);font-size:11.5px;line-height:1.5;color:var(--ink-3);letter-spacing:-.004em}
.pf-spec-tg{flex-shrink:0;width:44px;height:26px;border-radius:999px;border:none;cursor:pointer;padding:0;position:relative;
  background:var(--rule-2);transition:background .2s ease}
.pf-spec-tg i{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;
  box-shadow:0 1px 3px oklch(40% .05 var(--n-hue)/.3);transition:transform .22s cubic-bezier(.32,.72,0,1)}
.pf-spec-tg.on{background:var(--accent-b)}
.pf-spec-tg.on i{transform:translateX(18px)}
.dark-im .im-hero-phone .pf-spec,.dark-im .pf-spec{background:oklch(100% 0 0/.04)}
