/* ===== 手机壳 ===== */
.phone { width: 390px; height: 844px; margin: 24px auto; background: var(--c-bg);
  border-radius: 44px; box-shadow: 0 12px 48px rgba(0,0,0,.18); overflow: hidden;
  position: relative; display: flex; flex-direction: column; }

/* ===== 状态栏（拟真：左时间 · 右信号/wifi/电量） ===== */
.statusbar { height: 44px; display:flex; align-items:center; justify-content:space-between;
  padding: 0 24px; font-size: var(--fs-sm); color: var(--c-text); background: var(--c-surface); }
.sb-time { font-weight: var(--fw-semibold); letter-spacing:.02em; }
.sb-right { display:flex; align-items:center; gap:7px; color: var(--c-text); }
.sb-sig, .sb-wifi, .sb-batt { display:inline-block; }
.sb-sig { width:17px; height:11px;
  background:
    linear-gradient(var(--c-text),var(--c-text)) 0 100%/3px 4px no-repeat,
    linear-gradient(var(--c-text),var(--c-text)) 5px 100%/3px 7px no-repeat,
    linear-gradient(var(--c-text),var(--c-text)) 10px 100%/3px 9px no-repeat,
    linear-gradient(var(--c-text),var(--c-text)) 15px 100%/3px 11px no-repeat; }
.sb-wifi { width:16px; height:11px; border-radius:50% 50% 0 0;
  border:2px solid var(--c-text); border-bottom:0; opacity:.9;
  -webkit-mask: radial-gradient(circle at 50% 100%, #000 2px, transparent 2.5px); }
.sb-batt { width:23px; height:12px; border:1px solid var(--c-text); border-radius:3px; position:relative;
  background: linear-gradient(var(--c-text),var(--c-text)) 1px center/15px 8px no-repeat; }
.sb-batt::after { content:""; position:absolute; right:-3px; top:3px; width:2px; height:6px;
  background:var(--c-text); border-radius:0 2px 2px 0; }

/* ===== 顶部应用栏（标题 + 上下文返回） ===== */
.appbar { height: 48px; flex:none; background: var(--c-surface); border-bottom: 1px solid var(--c-line);
  display:flex; align-items:center; position:relative; }
.appbar-title { flex:1; text-align:center; font-size: var(--fs-lg); font-weight: var(--fw-semibold);
  color: var(--c-text); padding: 0 56px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.appbar-back { position:absolute; left:4px; top:0; bottom:0; width:48px; border:0; background:none;
  display:flex; align-items:center; justify-content:center; cursor:pointer; color: var(--c-text);
  font-size:26px; line-height:1; padding:0; }
.appbar-back svg { width:24px; height:24px; }
.appbar-back[hidden] { display:none; }
.appbar-action { position:absolute; right:4px; top:0; bottom:0; display:flex; align-items:center;
  padding:0 12px; }
.appbar-action:empty { display:none; }

#view { flex: 1; overflow-y: auto; padding: 8px var(--pad) 88px; }

/* ===== 空状态 ===== */
.empty { display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding: 64px 32px; min-height: 56vh; }
.empty .empty-ico { width:56px; height:56px; border-radius:16px; background:var(--c-fill);
  display:flex; align-items:center; justify-content:center; color:var(--c-text-mute); margin-bottom:14px; }
.empty .empty-ico svg { width:30px; height:30px; }
.empty .empty-t { font-size:var(--fs-lg); font-weight:var(--fw-semibold); }
.empty .empty-s { color:var(--c-text-sub); font-size:var(--fs-sm); margin-top:6px; max-width:260px; }
.empty .btn { width:auto; padding:11px 22px; margin-top:18px; }

/* ===== 底部导航 ===== */
.tabbar { position:absolute; bottom:0; left:0; right:0; height:64px; background:var(--c-surface);
  border-top:1px solid var(--c-line); display:flex; }
.tabbar a { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px; font-size:var(--fs-xs); color:var(--c-text-mute); text-decoration:none; }
.tabbar a.active { color: var(--c-primary); font-weight:var(--fw-medium); }
.tabbar .ico { display:flex; width:22px; height:22px; }
.tabbar .ico svg { width:22px; height:22px; }

/* ===== 卡片：边框为主，阴影极淡 ===== */
.card { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:var(--pad); margin:var(--gap) 0; }
.card.flat { box-shadow:none; }
.card.soft { background:var(--c-fill); border-color:transparent; box-shadow:none; }

/* ===== 标题层次（靠字号/字重/间距，不靠色块） ===== */
.title { font-size:var(--fs-lg); font-weight:var(--fw-semibold); margin:20px 0 8px; }
.title:first-child { margin-top:4px; }
.section-title { display:flex; align-items:baseline; justify-content:space-between;
  font-size:var(--fs-lg); font-weight:var(--fw-semibold); margin:20px 0 4px; }
.section-title .meta { font-size:var(--fs-sm); font-weight:var(--fw-regular); color:var(--c-text-mute); }
.sub { color:var(--c-text-sub); font-size:var(--fs-sm); }
.muted { color:var(--c-text-mute); }
.eyebrow { font-size:var(--fs-xs); color:var(--c-text-mute); font-weight:var(--fw-medium);
  letter-spacing:.04em; }

/* ===== 按钮 ===== */
.btn { display:block; width:100%; border:0; border-radius:var(--radius); padding:13px;
  font-size:var(--fs-md); font-weight:var(--fw-semibold); color:#fff; background:var(--c-primary);
  cursor:pointer; transition:background .15s; }
.btn:active { background:var(--c-primary-dark); }
.btn-ghost { background:var(--c-fill); color:var(--c-primary); }
.btn-text { background:none; color:var(--c-primary); font-weight:var(--fw-medium); padding:10px; }
.btn:disabled { opacity:.45; cursor:default; }

/* ===== 通用行 ===== */
.row { display:flex; align-items:center; gap:var(--gap); }
.between { display:flex; align-items:center; justify-content:space-between; gap:var(--gap); }

/* ===== 列表行：替代"每条一张浮卡" ===== */
.list { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius);
  overflow:hidden; margin:8px 0; }
.list-row { display:flex; align-items:center; gap:12px; padding:13px var(--pad);
  border-top:1px solid var(--c-line); text-decoration:none; color:var(--c-text); }
.list-row:first-child { border-top:0; }
.list-row .grow { flex:1; min-width:0; }
.list-row .rname { font-weight:var(--fw-medium); font-size:var(--fs-md); }
.list-row .rmeta { color:var(--c-text-sub); font-size:var(--fs-sm); margin-top:2px; }
.list-row .chev { color:var(--c-text-mute); flex:none; }
.list-row.tap { cursor:pointer; }
.list-row.tap:active { background:var(--c-fill); }

/* ===== 数字强调 ===== */
.amount { color:var(--c-money); font-weight:var(--fw-semibold); }
.hero-num { font-size:var(--fs-hero); font-weight:var(--fw-semibold); letter-spacing:-.01em; }
.trust { color:var(--c-trust); font-weight:var(--fw-medium); }
.credit { color:var(--c-credit); font-weight:var(--fw-medium); }

/* ===== 徽章（小面积语义色，纯文字） ===== */
.badge { display:inline-block; font-size:var(--fs-xs); padding:2px 8px; border-radius:var(--radius-pill);
  background:var(--c-fill); color:var(--c-text-sub); font-weight:var(--fw-medium); }
.badge-money { background:var(--c-money-soft); color:var(--c-money); }
.badge-trust { background:var(--c-trust-soft); color:var(--c-trust); }
.badge-credit { background:var(--c-credit-soft); color:var(--c-credit); }
.badge-primary { background:var(--c-primary-soft); color:var(--c-primary); }

/* ===== 缩略图 ===== */
.thumb { width:56px; height:56px; border-radius:var(--radius-sm); object-fit:cover;
  background:var(--c-fill); flex:none; }

a { color: var(--c-primary); text-decoration: none; }

/* ===== 进度条 ===== */
.progress { height:6px; border-radius:var(--radius-pill); background:var(--c-line); overflow:hidden; }
.progress > i { display:block; height:100%; border-radius:var(--radius-pill); background:var(--c-primary); }

/* ===== 动效（保留克制的入场/数字弹入） ===== */
@keyframes pop { 0%{transform:scale(.7);opacity:0} 60%{transform:scale(1.08)} 100%{transform:scale(1);opacity:1} }
.pop { animation: pop .4s ease; }
@keyframes rise { from{transform:translateY(6px);opacity:0} to{transform:translateY(0);opacity:1} }
.rise { animation: rise .3s ease both; }

/* ===== 红点 / 角标 ===== */
.dot { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px;
  padding:0 5px; border-radius:var(--radius-pill); background:var(--c-danger); color:#fff;
  font-size:11px; font-weight:var(--fw-semibold); vertical-align:middle; }
.tabbar a { position:relative; }
.tabbar .tab-dot { position:absolute; top:6px; left:calc(50% + 6px); min-width:16px; height:16px;
  padding:0 4px; border-radius:var(--radius-pill); background:var(--c-danger); color:#fff;
  font-size:10px; font-weight:var(--fw-semibold); display:flex; align-items:center; justify-content:center; }

/* ===== AI 区块：中性浅灰，不再渐变 ===== */
.ai-box { background:var(--c-fill); border:1px solid var(--c-line); border-radius:var(--radius);
  padding:12px 14px; margin:8px 0; }
.ai-head { display:flex; align-items:center; gap:6px; font-weight:var(--fw-semibold);
  color:var(--c-text); font-size:var(--fs-md); }
.ai-chain { margin:8px 0 0; padding:0; list-style:none; }
.ai-chain li { position:relative; padding:3px 0 3px 16px; font-size:var(--fs-sm); color:var(--c-text-sub); }
.ai-chain li::before { content:""; position:absolute; left:2px; top:10px; width:5px; height:5px;
  border-radius:50%; background:var(--c-primary); }
.conf-bar { height:6px; border-radius:var(--radius-pill); background:var(--c-line); overflow:hidden; margin-top:4px; }
.conf-bar > i { display:block; height:6px; border-radius:var(--radius-pill); background:var(--c-primary); }

/* ===== chip ===== */
.chip { display:inline-block; font-size:var(--fs-xs); padding:4px 10px; border-radius:var(--radius-pill);
  background:var(--c-fill); color:var(--c-text-sub); margin:2px 4px 2px 0; }
.chip.on { background:var(--c-primary); color:#fff; }

/* ===== 诚实体验标签（可勾选） ===== */
.tag-chip { display:inline-block; font-size:var(--fs-sm); padding:4px 11px; border-radius:var(--radius-pill);
  margin:3px 4px 3px 0; cursor:pointer; background:var(--c-fill); color:var(--c-text-sub);
  user-select:none; border:1px solid transparent; }
.tag-chip.sel[data-tag="pro"] { background:var(--c-trust-soft); color:var(--c-trust); }
.tag-chip.sel[data-tag="con"] { background:var(--c-money-soft); color:var(--c-money); }
.tag-chip:not(.sel) { opacity:.5; }

/* ===== AI 活动日志 ===== */
.ailog-item { display:flex; gap:10px; padding:10px 0; border-top:1px solid var(--c-line); }
.ailog-item:first-child { border-top:0; }
.ailog-dot { flex:none; width:7px; height:7px; border-radius:50%; background:var(--c-primary); margin-top:6px; }
.ailog-time { font-size:var(--fs-xs); color:var(--c-text-mute); margin-top:2px; }

/* ===== 选品池 grid ===== */
.tabs-row { display:flex; gap:6px; overflow-x:auto; padding:4px 0; }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.pcard { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius); overflow:hidden; }
.pcard img { width:100%; height:96px; object-fit:cover; background:var(--c-fill); display:block; }
.pcard .pc-body { padding:8px 10px; }

/* ===== 信任凭证行 ===== */
.trust-cred { display:flex; flex-wrap:wrap; gap:6px; margin:6px 0; }
.trust-cred .cred { font-size:var(--fs-xs); color:var(--c-trust); background:var(--c-trust-soft);
  padding:2px 8px; border-radius:var(--radius-pill); }
.trust-cred .cred.price { color:var(--c-money); background:var(--c-money-soft); }

/* ===== 评价维度 chip：好/一般/差 ===== */
.dim-chip { display:inline-block; font-size:var(--fs-xs); padding:3px 9px; border-radius:var(--radius-pill);
  margin:2px 4px 2px 0; border:1px solid var(--c-line); color:var(--c-text-sub); }
.dim-chip.good { color:var(--c-trust); background:var(--c-trust-soft); border-color:transparent; }
.dim-chip.mid  { color:var(--c-text-sub); background:var(--c-fill); border-color:transparent; }
.dim-chip.bad  { color:var(--c-money); background:var(--c-money-soft); border-color:transparent; }

/* ===== 进货门槛裁决三态 ===== */
.gate { border-radius:var(--radius-sm); padding:10px 12px; margin:6px 0; border:1px solid var(--c-line); }
.gate .v { font-weight:var(--fw-semibold); font-size:var(--fs-sm); }
.gate.recommend { background:var(--c-trust-soft); border-color:transparent; }
.gate.recommend .v { color:var(--c-trust); }
.gate.hold { background:var(--c-money-soft); border-color:transparent; }
.gate.hold .v { color:var(--c-money); }
.gate.block { background:var(--c-danger-soft); border-color:transparent; }
.gate.block .v { color:var(--c-danger); }
.gate .reason { font-size:var(--fs-xs); color:var(--c-text-sub); margin-top:4px; }

/* ===== 上架处置面板 ===== */
.dispose { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius);
  padding:12px; margin-top:8px; }
.dispose .opt { display:block; width:100%; text-align:left; border:1px solid var(--c-line);
  background:var(--c-surface); border-radius:var(--radius-sm); padding:10px; margin:6px 0;
  cursor:pointer; font-size:var(--fs-sm); }
.dispose .opt.on { border-color:var(--c-primary); background:var(--c-primary-soft); font-weight:var(--fw-medium); }
.dispose .targets { margin-top:8px; }
.dispose .tg { display:inline-block; font-size:var(--fs-xs); padding:4px 10px; border-radius:var(--radius-pill);
  border:1px solid var(--c-line); margin:2px 4px 2px 0; cursor:pointer; }
.dispose .tg.on { border-color:var(--c-primary); background:var(--c-primary-soft); color:var(--c-primary); }

/* ===== 轻提示 toast ===== */
.toast { position:absolute; left:50%; bottom:96px; transform:translateX(-50%);
  background:rgba(15,23,42,.92); color:#fff; padding:10px 16px; border-radius:var(--radius-pill);
  font-size:var(--fs-sm); opacity:0; transition:opacity .2s; pointer-events:none;
  max-width:80%; text-align:center; z-index:20; }
.toast.show { opacity:1; }

/* ===== 分段控件（视角切换） ===== */
.seg { display:flex; background:var(--c-fill); border-radius:var(--radius-pill); padding:3px; margin:8px 0; }
.seg a { flex:1; text-align:center; padding:7px 0; border-radius:var(--radius-pill); font-size:var(--fs-sm);
  color:var(--c-text-sub); }
.seg a.on { background:var(--c-surface); color:var(--c-primary); font-weight:var(--fw-semibold);
  box-shadow:var(--shadow); }
.seg-n { display:inline-block; min-width:16px; height:16px; padding:0 4px; border-radius:var(--radius-pill);
  background:var(--c-primary); color:#fff; font-size:11px; line-height:16px; text-align:center; vertical-align:middle; }
.sig-dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:6px; vertical-align:middle; }

/* ===== 搜索栏 ===== */
.searchbar { display:flex; gap:8px; align-items:center; margin:8px 0; }
.searchbar input { flex:1; border:1px solid var(--c-line); border-radius:var(--radius-pill);
  padding:9px 14px; font-size:var(--fs-md); background:var(--c-surface); outline:none; color:var(--c-text); }
.searchbar input:focus { border-color:var(--c-primary); }
.searchbar .btn { width:auto; padding:9px 16px; }

/* ===== 访客·店铺门面 ===== */
.shopfront { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:18px var(--pad) 14px; margin:8px 0; }
.sf-head { display:flex; align-items:center; gap:13px; }
.sf-avatar { width:52px; height:52px; border-radius:50%; flex:none; display:flex; align-items:center;
  justify-content:center; font-size:21px; font-weight:var(--fw-semibold); color:#fff; background:var(--c-primary); }
.sf-id { flex:1; min-width:0; }
.sf-name { font-size:var(--fs-lg); font-weight:var(--fw-semibold); display:flex; align-items:center; gap:6px; }
.sf-promise { color:var(--c-text-sub); font-size:var(--fs-sm); margin-top:3px; line-height:1.4; }
.sf-promise b { color:var(--c-trust); font-weight:var(--fw-medium); }
.sf-stats { display:flex; margin-top:14px; border-top:1px solid var(--c-line); padding-top:12px; }
.sf-stat { flex:1; text-align:center; position:relative; }
.sf-stat + .sf-stat::before { content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  height:24px; width:1px; background:var(--c-line); }
.sf-stat .n { font-size:18px; font-weight:var(--fw-semibold); color:var(--c-text); letter-spacing:-.01em; }
.sf-stat .n.t { color:var(--c-trust); }
.sf-stat .l { font-size:var(--fs-xs); color:var(--c-text-mute); margin-top:3px; }

/* ===== 访客·诚实好物卡 ===== */
.good { background:var(--c-surface); border:1px solid var(--c-line); border-radius:var(--radius);
  box-shadow:var(--shadow); overflow:hidden; margin:10px 0; cursor:pointer; transition:box-shadow .15s,transform .1s; }
.good:active { box-shadow:var(--shadow-pop); transform:translateY(-1px); }
.good .g-top { display:flex; gap:12px; padding:12px 12px 0; }
.good .g-img { width:72px; height:72px; border-radius:var(--radius-sm); object-fit:cover; flex:none; background:var(--c-fill); }
.good .g-main { flex:1; min-width:0; }
.good .g-name { font-size:var(--fs-md); font-weight:var(--fw-semibold); display:flex; align-items:center;
  gap:6px; flex-wrap:wrap; }
.good .g-meta { font-size:var(--fs-xs); color:var(--c-text-mute); margin-top:4px; }
.good .g-meta b { color:var(--c-trust); font-weight:var(--fw-medium); }
.good .g-quote { background:var(--c-fill); border-radius:var(--radius-sm); padding:9px 12px; margin:10px 12px 0;
  font-size:var(--fs-sm); color:var(--c-text-sub); line-height:1.5; }
.good .g-quote::before { content:"“"; color:var(--c-text-mute); font-size:18px; margin-right:2px; vertical-align:-3px; }
.good .g-tags { padding:10px 12px 0; }
.good .g-row { text-align:left; }
.dim-rows .dim-chip, .good .g-row .dim-chip { margin-top:0; margin-bottom:0; }
.dim-rows > div + div, .good .g-row + .g-row { margin-top:2px; }
.good .g-foot { display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:11px 12px; margin-top:10px; border-top:1px solid var(--c-line); }
.good .g-price { font-size:var(--fs-xs); color:var(--c-money); }
.good .g-price b { font-size:var(--fs-md); font-weight:var(--fw-semibold); }
.good .g-was { color:var(--c-text-mute); font-size:var(--fs-xs); font-weight:var(--fw-regular); margin-left:6px; }
.good .g-int { border:0; background:var(--c-primary-soft); color:var(--c-primary); font-weight:var(--fw-semibold);
  font-size:var(--fs-sm); padding:8px 16px; border-radius:var(--radius-pill); cursor:pointer; flex:none; }
.good .g-int:active { background:var(--c-primary); color:#fff; }

/* ===== 商品详情·价格透明 / 诚实callout ===== */
.honest-note { font-size:var(--fs-sm); color:var(--c-trust); background:var(--c-trust-soft);
  border-radius:var(--radius-sm); padding:9px 12px; margin-top:8px; }
.price-clear { display:flex; align-items:flex-start; justify-content:space-between; }
.price-clear .pc-now { font-size:22px; font-weight:var(--fw-semibold); color:var(--c-money); letter-spacing:-.01em; }
.price-clear .pc-was { font-size:18px; font-weight:var(--fw-semibold); color:var(--c-text-sub); letter-spacing:-.01em; }
.price-clear .pc-lbl { font-size:var(--fs-xs); color:var(--c-text-mute); margin-top:3px; }
.price-clear .pc-note { font-size:var(--fs-xs); color:var(--c-text-mute); }
.quote-block { background:var(--c-fill); border-left:3px solid var(--c-primary); border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:10px 13px; margin-top:10px; font-size:var(--fs-sm); color:var(--c-text-sub); line-height:1.55; }
.quote-block .qb-by { display:block; margin-top:6px; font-size:var(--fs-xs); color:var(--c-text-mute); }

/* ===== AI 合伙人对话气泡 ===== */
.chat { display:flex; flex-direction:column; gap:10px; margin:8px 0; }
.chat .bubble { max-width:82%; padding:10px 13px; border-radius:14px; font-size:var(--fs-sm); line-height:1.5; }
.chat .bubble.ai { align-self:flex-start; background:var(--c-surface); border:1px solid var(--c-line);
  border-bottom-left-radius:4px; }
.chat .bubble.me { align-self:flex-end; background:var(--c-primary); color:#fff; border-bottom-right-radius:4px; }
.chat .asks { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.chat .ask { border:1px solid var(--c-primary); color:var(--c-primary); background:var(--c-surface);
  border-radius:var(--radius-pill); padding:7px 13px; font-size:var(--fs-sm); cursor:pointer; }
