*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d1117;--bg2:#131922;--bg3:#1a2233;
  --border:rgba(255,255,255,0.07);--border2:rgba(230,126,34,0.3);
  --accent:#e67e22;--accent2:#f39c12;
  --green:#26a69a;--red:#ef5350;--blue:#6495ed;--teacher:#c9a84c;
  --text:#e6edf3;--text2:#8b949e;--text3:#6f7b8a;--text-muted:#97a2b0;--text-faint:#727e8d;
  --win:#26a69a;--loss:#ef5350;
  --missed-trade:#9b6dff;
  --font-mono:'SF Mono','Fira Code','Consolas',monospace;
  --font-base:'Microsoft YaHei','PingFang SC',sans-serif;
  /* 金质升级引导 token (深色默认). 独立命名 --tjgold-* 避免与既有 --teacher 等冲突 */
  --tjgold-1:#f3d690;--tjgold-2:#d4a04a;
  --tjgold-grad:linear-gradient(135deg,#f3d690 0%,#d4a04a 100%);
  --tjgold-soft:rgba(240,205,132,0.10);
  --tjgold-edge:rgba(240,205,132,0.45);
  --tjgold-ink:#3a2a08;--tjgold-ink-strong:#241902;
}
/* ── 浅色主题：冷灰白底 + 保留橙主色，与深色版同一套语义 token ── */
html[data-theme="light"]{
  --bg:#f4f6fa;
  --bg2:#ffffff;
  --bg3:#eef1f7;
  --chart-chrome:#e2e7f0;
  --border:rgba(15,23,42,0.1);
  --border2:rgba(211,84,0,0.32);
  --accent:#d35400;
  --accent2:#e67e22;
  --green:#148f7b;
  --red:#c62828;
  --blue:#3d6ab0;
  --teacher:#a67c1f;
  --text:#161b22;
  --text2:#4a5563;
  --text3:#788090;
  --text-muted:#5a6573;--text-faint:#7a8694;
  --win:var(--green);
  --loss:var(--red);
  --missed-trade:#7c4dff;
  /* 金质升级引导 token (浅色覆盖) */
  --tjgold-1:#e8b964;--tjgold-2:#b97f25;
  --tjgold-grad:linear-gradient(135deg,#f0cd84 0%,#d49b3f 100%);
  --tjgold-soft:rgba(212,151,63,0.12);
  --tjgold-edge:rgba(212,151,63,0.55);
  --tjgold-ink:#5a3d12;--tjgold-ink-strong:#3a2708;
}
html[data-theme="light"] .chart-area{background:var(--chart-chrome);}
html[data-theme="light"] .tbox-pnl{background:rgba(255,255,255,0.97);box-shadow:0 2px 14px rgba(15,23,42,0.08);color:var(--text);}
html[data-theme="light"] .pnl-card{background:rgba(255,255,255,0.97);box-shadow:0 4px 22px rgba(15,23,42,0.1);}
html[data-theme="light"] .pnl-sub{color:var(--text2);}
html[data-theme="light"] #login-screen{background:linear-gradient(145deg,#f0f4fc 0%,#e6ecf6 55%,#eef2f8 100%);}
html[data-theme="light"] .login-wrap{background:#ffffff;border-color:rgba(211,84,0,0.22);box-shadow:0 12px 40px rgba(15,23,42,0.08);}
html[data-theme="light"] .login-title{color:var(--text);}
html[data-theme="light"] .login-input{background:#fafbfe;border-color:rgba(15,23,42,0.12);}
html[data-theme="light"] .st-ov-ex-tooltip{background:rgba(255,255,255,0.98);border:1px solid rgba(15,23,42,0.1);box-shadow:0 8px 28px rgba(15,23,42,0.12);}
html[data-theme="light"] .st-erow:hover{background:rgba(15,23,42,0.04);}
html[data-theme="light"] .st-ov-tt-swatch{border-color:rgba(15,23,42,0.15)!important;}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font-base);height:100vh;overflow:hidden;min-width:0}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:2px}
/* ★ 6.6 M1: 落地页文档级滚动条放大、更明显(仅落地页 body.lp-scroll, 不影响 app 内细滚动条) */
body.lp-scroll::-webkit-scrollbar{width:12px}
body.lp-scroll::-webkit-scrollbar-track{background:transparent}
body.lp-scroll::-webkit-scrollbar-thumb{background:var(--text3);border-radius:6px;border:3px solid var(--bg)}
body.lp-scroll::-webkit-scrollbar-thumb:hover{background:var(--text2)}
/* 2026-06-02: 个人中心滚动条加宽加亮(用户要求更明显) */
#page-account ::-webkit-scrollbar{width:11px;height:11px}
#page-account ::-webkit-scrollbar-thumb{background:var(--text3);border-radius:6px;border:2px solid var(--bg)}
#page-account ::-webkit-scrollbar-thumb:hover{background:var(--text2)}

/* ── LOGIN ─────────────────────────────────────────────── */
#login-screen{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(10,14,20,0.95) 0%,rgba(20,30,45,0.95) 100%)}
.login-wrap{width:380px;background:rgba(20,28,42,0.9);border:1px solid rgba(230,126,34,0.2);border-radius:16px;overflow:hidden}
.login-top{padding:40px 40px 32px;border-bottom:1px solid var(--border);position:relative}
.login-badge{display:inline-flex;align-items:center;gap:6px;font-size: 10px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;font-family:var(--font-mono);opacity:.7;margin-bottom:16px}
.login-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
.login-title{font-size: 28px;font-weight:700;color:#f0e8dc;letter-spacing:-.5px;margin-bottom:4px}
.login-sub{font-size: 11px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;font-family:var(--font-mono)}
.login-body{padding:28px 40px 0}
.login-field{margin-bottom:14px}
.login-label{display:block;font-size: 9px;letter-spacing:1.5px;color:var(--text3);text-transform:uppercase;font-family:var(--font-mono);margin-bottom:6px}
.login-input{width:100%;padding:10px 14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:8px;color:var(--text);font-size: 13px;font-family:var(--font-mono);outline:none;transition:border-color .15s}
.login-input:focus{border-color:var(--accent)}
.login-footer{padding:20px 40px 32px}
.login-btn{width:100%;padding:12px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size: 11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;font-family:var(--font-mono);cursor:pointer;transition:background .15s}
.login-btn:hover{background:#d06a16}
.login-btn:disabled{opacity:.4;cursor:not-allowed}
#login-error{font-size: 11px;color:var(--red);text-align:center;margin-top:10px;display:none}

/* ── APP SHELL ──────────────────────────────────────────── */
#app{display:none;height:100vh;flex-direction:column;min-width:0}

/* ── TOPNAV (2026-05-21 UI 改版,替换原 SIDEBAR) ───────────── */
#topnav{
  display:flex;align-items:stretch;height:52px;
  background:var(--bg2);border-bottom:1px solid var(--border);
  font-family:'Space Grotesk','Microsoft YaHei','PingFang SC',sans-serif;
  padding:0 16px;flex-shrink:0;position:relative;z-index:1000;
  gap:6px;
}

/* 品牌区 */
/* 2026-05-21 (修): padding 左右对称, 让 logo 在 "格子" 内居中. */
.tn-brand{display:flex;align-items:center;gap:10px;padding:0 24px 0 18px;cursor:pointer;user-select:none}
.tn-brand-logo{width:26px;height:26px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.tn-brand-text{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.4px;white-space:nowrap;line-height:1}
.tn-brand-text b{color:var(--accent);font-weight:700}
/* 2026-05-21 (修): .tn-brand-dot 已从 HTML 删除(视觉突兀),保留 CSS 块以防回滚需要 */
.tn-brand-dot{display:none}

/* 品牌与导航的分隔线 */
.tn-divider{width:1px;background:var(--border);margin:12px 6px 12px 0;flex-shrink:0}

/* 主导航容器 — gap 给导航项之间留呼吸 */
/* 2026-05-21 (修): gap 2→8, 加大标签之间间距. */
.tn-nav{display:flex;align-items:stretch;gap:8px}
.tn-nav-admin{border-left:1px dashed rgba(201,168,76,0.18);padding-left:14px;margin-left:auto}

/* 通用导航项(沿用 .nav-item 名,样式重写) */
#topnav .nav-item{
  display:flex;align-items:center;gap:6px;
  padding:0 14px;font-size:13px;color:var(--text2);
  cursor:pointer;font-weight:500;letter-spacing:0.2px;
  position:relative;border:none;border-radius:0;margin:0;
  white-space:nowrap;transition:color .15s;
  user-select:none;
}
#topnav .nav-item:hover{color:var(--text);background:transparent}

/* 2026-05-30: nav 标签中英可切换 — 默认中文; html.lang-en 切英文. 同时只显一种(单行).
   语言开关见 tnToggleLang (app.js), 镜像 tnToggleTheme; 持久化 localStorage 'tj-lang'. */
#topnav .nav-label-en{display:none}
html.lang-en #topnav .nav-label-zh{display:none}
html.lang-en #topnav .nav-label-en{display:inline}

/* 当前页高亮 — 渐变发光横线
   ★ 2026-05-21 (修): 必须 display:block !important.
   理由: feature-locked-t2/-t3 用 ::after 写锁标,admin/满足档位时
   `body.role-admin .feature-locked-t2::after { display:none }` 会把
   ::after 整个隐藏掉. 该规则 specificity (0,0,2,2) 低于本规则
   (0,1,2,1), 但本规则原先没显式设 display, 导致 display:none 这条
   属性单独从 feature-locked 那条胜出 — 结果挂了 feature-locked 的
   nav (播报/答疑/Report/Persona) active 时永远没下划线. */
#topnav .nav-item.active{color:var(--accent);background:transparent;border:none}
#topnav .nav-item.active::after{
  content:'';display:block !important;position:absolute;left:0;right:0;bottom:-1px;
  width:auto;height:2px;margin-left:0;
  background:linear-gradient(90deg,transparent,var(--accent) 30%,var(--accent) 70%,transparent);
  pointer-events:none;
}

/* Admin 导航区文字颜色: 金色 */
#topnav .tn-nav-admin .nav-item{color:var(--teacher);font-size:12px;padding:0 14px}
#topnav .tn-nav-admin .nav-item:hover{color:#dcc068}
#topnav .tn-nav-admin .nav-item.active{color:var(--teacher)}
/* 2026-05-21 (修): admin-only 在顶栏 nav 里强制 display:flex.
   根因: `body.role-admin .admin-only { display: revert !important }` 把元素
   还原成 <div> 默认的 block, 把 #topnav .nav-item 的 display:flex 抹掉,
   导致 nav-item 失去 flex 容器特性, align-items:center 失效, 文字按 inline
   顶部对齐 — Settings/管理后台 看上去比左侧 Replay/播报 偏上一截.
   修法: ID specificity + !important 双重保险, 强制 flex. */
body.role-admin #topnav .nav-item.admin-only{display:flex !important}
/* 下拉菜单内的 admin-only 调试入口同样问题, 同样修法: */
body.role-admin #topnav .tn-menu .tn-menu-item.admin-only{display:flex !important}
#topnav .tn-nav-admin .nav-item.active::after{
  background:linear-gradient(90deg,transparent,var(--teacher) 30%,var(--teacher) 70%,transparent);
}

/* 答疑红色数字 / 其它 nav 角标 */
/* 2026-05-21 (修): 数字文字未居中. 根因: mono 字体 "4" 字形左偏 + 非对称 padding.
   修法: 圆/胶囊形, height/min-width 16px, 双向 padding 0 4px (对称),
   字体改用 system, 让数字字形自然居中. flex justify-content:center 兜底. */
#topnav .nav-item-badge{
  display:inline-flex;align-items:center;justify-content:center;
  box-sizing:border-box;
  min-width:16px;height:16px;padding:0 4px;
  background:var(--accent);color:#fff;font-size:10px;font-weight:700;
  border-radius:8px;line-height:1;text-align:center;
  font-family:'Space Grotesk','Microsoft YaHei',sans-serif;
}

/* 建设中 SOON 标签 */
#topnav .nav-item-soon{color:var(--text3);cursor:not-allowed}
#topnav .nav-item-soon:hover{color:var(--text3)}
.tn-soon-tag{
  font-size:9px;color:var(--text3);background:rgba(255,255,255,0.04);
  padding:2px 6px;border-radius:3px;font-family:var(--font-mono);
  letter-spacing:0.8px;font-weight:600;
}

/* 用户区 */
.tn-user{
  margin-left:14px;display:flex;align-items:center;gap:10px;
  padding:0 14px;cursor:pointer;position:relative;
  border-left:1px solid var(--border);
}
.tn-user:hover{background:rgba(255,255,255,0.02)}
.tn-avatar{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--teacher));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:11px;font-weight:700;font-family:var(--font-mono);flex-shrink:0;
}
/* 2026-05-21 (修): 原来是竖排两行(名字 + ADMIN), 显得拥挤且和导航项格格不入.
   改成横排: 名字 + 紧凑 pill. 视觉密度跟导航项对齐. */
.tn-user-meta{display:flex;flex-direction:row;align-items:center;gap:8px;min-width:0}
.tn-user-name{font-size:13px;color:var(--text);font-weight:500;white-space:nowrap;max-width:9em;overflow:hidden;text-overflow:ellipsis}
.tn-user-tier{
  font-size:10px;letter-spacing:0.8px;font-family:var(--font-mono);
  font-weight:600;color:var(--text3);text-transform:uppercase;white-space:nowrap;
  padding:2px 7px;border-radius:3px;background:rgba(255,255,255,0.04);
  line-height:1.2;
}
.tn-user-caret{color:var(--text3);flex-shrink:0;transition:transform .15s}

/* UX-10 (窗口 X+3): 顶栏升级入口 pill. 默认隐藏, 仅 T1/T2 显示 (CSS 按 body tier class 门控).
   T0 付费入口走 account 页 (UX-4 另做); T3/admin 已最高级不显示 (无规则=默认隐藏). */
/* 2026-06-01: 改金质（与升级弹窗金卡 UI 统一）——满金渐变 + 深字高对比，像一枚"开通会员"金徽。
   位置不变：DOM 里在 admin 导航(管理后台)之后、用户区之前，对普通会员即落在管理后台同一横向区域。 */
.tn-upgrade-pill{
  display:none;align-items:center;align-self:center;margin-left:10px;
  padding:4px 14px;border-radius:7px;cursor:pointer;
  font-size:13px;font-weight:700;letter-spacing:0.2px;line-height:1.3;white-space:nowrap;
  color:var(--tjgold-ink-strong);background:var(--tjgold-grad);
  border:1px solid transparent;
  transition:filter .15s,box-shadow .15s;
  animation:tnUpgBreath 3s ease-in-out infinite;
}
.tn-upgrade-pill:hover{filter:brightness(1.08)}
/* 呼吸光晕: 金色外发光缓慢明暗呼吸 (3s 一轮), 低调抓眼. */
@keyframes tnUpgBreath{
  0%,100%{box-shadow:0 0 0 0 rgba(240,205,132,0)}
  50%{box-shadow:0 0 11px 1px rgba(240,205,132,0.50)}
}
@media (prefers-reduced-motion: reduce){
  .tn-upgrade-pill{animation:none}
}
/* 2026-05-31: T0 也显示升级入口（T0 现在能看到带锁功能，需显式升级口）。
   仍隐藏 T3(最高可买)/admin。T0 点击走 tjModal.openUpgrade → floor=T1 起。 */
body.tier-0 .tn-upgrade-pill,
body.tier-1 .tn-upgrade-pill,
body.tier-2 .tn-upgrade-pill{display:inline-flex}
/* #1(2026-06-08): T3 月付也显示升级 pill(可转年付);T3 年付无 billing-month class → 仍隐藏(避免"看得到点不了")。
   依赖 permissions.js applyRoleToBodyClass 据活跃订阅 billing_interval 设的 body.billing-month。 */
body.tier-3.billing-month .tn-upgrade-pill{display:inline-flex}
/* 2026-05-31 修复(质检D): 试用中(含 Stripe $1.99 试用)隐藏升级 pill，
   因 tjOpenUpgrade 对试用态拦截，避免「pill 可见但点了被 toast 挡回」的 UX 割裂。
   优先级高于上面的 tier-N 显示规则(同 specificity，靠后覆盖)。 */
body.is-trial .tn-upgrade-pill{display:none !important}

/* 版本名颜色映射 (body class 驱动,视觉调试入口也用同一组).
   2026-05-21 (修): 拉开档位颜色区分度.
   tier-1 灰描边灰底 / tier-2 橙描边橙底 / tier-3 金描边金渐变底 / admin 金实底黑字. */
body.tier-1 .tn-user-tier{
  color:#a8b1c0;background:rgba(120,128,144,0.10);
  border:1px solid rgba(120,128,144,0.30);
}
body.tier-2 .tn-user-tier{
  color:var(--accent);background:rgba(230,126,34,0.12);
  border:1px solid rgba(230,126,34,0.45);
}
body.tier-3 .tn-user-tier{
  color:var(--teacher);
  background:linear-gradient(90deg,rgba(230,126,34,0.18),rgba(201,168,76,0.22));
  border:1px solid rgba(201,168,76,0.55);
}
body.role-admin .tn-user-tier{
  color:#1a1408;background:var(--teacher);
  border:1px solid var(--teacher);font-weight:700;
}

/* 用户下拉菜单 */
.tn-menu{
  display:none;position:absolute;top:calc(100% + 6px);right:0;
  min-width:240px;background:var(--bg2);
  border:1px solid var(--border);border-radius:10px;
  box-shadow:0 8px 28px rgba(0,0,0,0.4);
  padding:6px;z-index:1010;
}
.tn-user.open .tn-menu{display:block}
.tn-user.open .tn-user-caret{transform:rotate(180deg)}
.tn-menu-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;font-size:13px;color:var(--text2);
  border-radius:6px;cursor:pointer;transition:all .12s;
  user-select:none;
}
.tn-menu-item:hover{background:var(--bg3);color:var(--text)}
.tn-menu-item svg{flex-shrink:0;opacity:0.7}
/* nav-account 同时挂 .tn-menu-item .nav-item (后者供 switchPage 的 active 清理命中).
   #topnav .nav-item 的 padding/border-radius 会覆盖 .tn-menu-item 的, 这里强制还原: */
#topnav .tn-menu .nav-item{padding:9px 12px;border-radius:6px;gap:10px}
#topnav .tn-menu .nav-item:hover{background:var(--bg3);color:var(--text)}
/* 顶栏的 active 横线在菜单内不适用,隐藏: */
#topnav .tn-menu .nav-item.active::after{display:none}
#topnav .tn-menu .nav-item.active{color:var(--text2)}
.tn-menu-item-row{cursor:default}
.tn-menu-item-row:hover{background:transparent;color:var(--text2)}
.tn-menu-grow{flex:1}
.tn-menu-item-danger{color:var(--text2)}
.tn-menu-item-danger:hover{color:var(--red);background:rgba(239,83,80,0.06)}
.tn-menu-sep{height:1px;background:var(--border);margin:4px 6px}
.tn-menu-tag{
  margin-left:auto;font-size:9px;letter-spacing:1.2px;font-family:var(--font-mono);
  font-weight:600;color:var(--teacher);background:rgba(201,168,76,0.1);
  padding:2px 6px;border-radius:3px;
}

/* 主题开关 (从 sidebar 迁移过来,样式微调适配下拉菜单容器) */
.tj-theme-switch{position:relative;display:inline-block;width:32px;height:18px;flex-shrink:0;cursor:pointer;margin-left:auto}
.tj-theme-switch input{opacity:0;width:0;height:0;position:absolute}
.tj-theme-slider{position:absolute;inset:0;background:var(--bg3);border:1px solid var(--border);border-radius:999px;transition:background .2s,border-color .2s}
.tj-theme-slider::before{content:'';position:absolute;height:12px;width:12px;left:2px;top:2px;background:var(--text3);border-radius:50%;transition:transform .2s,background .2s}
.tj-theme-switch input:checked + .tj-theme-slider{background:rgba(211,84,0,0.15);border-color:rgba(211,84,0,0.35)}
.tj-theme-switch input:checked + .tj-theme-slider::before{transform:translateX(13px);background:var(--accent)}

/* Admin 调试: 模拟版本视角面板 */
.tn-tier-debug{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:9000;display:flex;align-items:center;justify-content:center}
.tn-tier-debug-card{
  width:360px;background:var(--bg2);border:1px solid var(--border);
  border-radius:12px;padding:18px;box-shadow:0 12px 40px rgba(0,0,0,0.5);
}
.tn-tier-debug-h{font-size:13px;color:var(--text);font-weight:600;margin-bottom:14px}
.tn-tier-debug-list{display:flex;flex-direction:column;gap:8px}
.tn-tier-debug-list label{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:12px;color:var(--text2)}
.tn-tier-debug-list label:hover{background:var(--bg3)}
.tn-tier-debug-list input[type=radio]{flex-shrink:0;accent-color:var(--accent)}
.tn-tier-pill{font-family:var(--font-mono);font-weight:600;letter-spacing:1px;font-size:11px}
.tn-tier-pill.tn-tier-1{color:#788090}
.tn-tier-pill.tn-tier-2{color:var(--accent)}
.tn-tier-pill.tn-tier-3{background:linear-gradient(90deg,var(--accent),var(--teacher));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.tn-tier-pill.tn-tier-admin{color:var(--teacher)}
.tn-tier-debug-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.tn-tier-debug-hint{font-size:11px;color:var(--text3);font-family:var(--font-base);letter-spacing:0.5px}
.tn-tier-debug-close{background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer}
.tn-tier-debug-close:hover{color:var(--text);border-color:var(--accent)}

/* ── MAIN ────────────────────────────────────────────────── */
#main{flex:1;overflow:hidden;display:flex;flex-direction:column;min-width:0}
.page{display:none;flex:1;flex-direction:column;overflow:hidden}
.page.active{display:flex}

/* ── PAGE HEADER ─────────────────────────────────────────── */
.page-header{padding:16px 24px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg2)}
.page-header-left{display:flex;align-items:center;gap:12px}
.page-title{font-size: 18px;font-weight:700;color:var(--text)}
.save-status{font-size: 10px;font-family:var(--font-mono);color:var(--text3);display:flex;align-items:center;gap:5px}
.save-dot{width:5px;height:5px;border-radius:50%;background:var(--text3)}
.save-dot.saved{background:var(--win)}
.save-dot.saving{background:var(--accent);animation:pulse 1s infinite}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{padding:7px 14px;border-radius:7px;border:none;font-size: 12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;font-family:inherit;letter-spacing:.5px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#d06a16}
.btn-secondary{background:transparent;color:var(--text2);border:1px solid var(--border)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:transparent;color:var(--text3);border:none;padding:5px 8px}
.btn-ghost:hover{color:var(--text)}
.btn-sm{padding:5px 10px;font-size: 11px}
.btn-danger{background:rgba(239,83,80,0.12);color:var(--red);border:1px solid rgba(239,83,80,0.2)}
.btn-danger:hover{background:rgba(239,83,80,0.22)}
.btn-reset{padding:5px 10px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size: 11px;font-weight:700;cursor:pointer;transition:background .2s;font-family:var(--font-mono)}
.btn-reset:hover{background:#d06a16}

/* ── DAILY LOG LAYOUT ────────────────────────────────────── */
#page-daily{overflow:hidden}
.daily-layout{display:flex;flex:1;overflow:hidden}

/* LEFT COLUMN — scrolls vertically as image grows */
.left-col{width:66%;min-width:200px;max-width:85%;border-right:none;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:var(--bg);flex-shrink:0}

/* Drag resizer */
.col-resizer{width:5px;background:var(--border);cursor:col-resize;flex-shrink:0;transition:background .15s;position:relative;z-index:5}
.col-resizer:hover,.col-resizer.dragging{background:var(--accent)}

/* Annotator toolbar */
.ann-toolbar{display:flex;align-items:center;gap:2px;padding:6px 10px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.ann-btn{display:flex;align-items:center;gap:5px;padding:3.75px 7.5px;border-radius:6px;font-size: 11px;color:var(--text2);cursor:pointer;background:transparent;border:none;transition:all .15s;font-family:var(--font-mono);white-space:nowrap}
.ann-btn:hover{background:var(--bg3);color:var(--text)}
.ann-btn.ai-btn{color:var(--accent)}
.ann-btn.ai-btn:hover{background:rgba(230,126,34,0.1)}
.ann-sep{width:1px;height:14px;background:var(--border);margin:0 3px}
.ann-dd{position:relative;display:inline-block}
.ann-dd-menu{display:none;position:absolute;top:calc(100% + 3px);left:0;background:var(--bg2);border:1px solid var(--border);border-radius:7px;overflow:hidden;z-index:9999;min-width:160px;box-shadow:0 8px 20px rgba(0,0,0,.6)}
.ann-dd-menu.open{display:block}
.ann-dd-item{padding:8px 13px;font-size: 11px;font-family:var(--font-mono);color:var(--text2);cursor:pointer;white-space:nowrap;transition:background .1s}
.ann-dd-item:hover{background:var(--bg3);color:var(--blue)}

/* Scale bar */
.scale-bar{display:flex;align-items:center;gap:4px;padding:5px 10px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.scale-lbl{font-size: 9px;color:var(--text3);letter-spacing:1px;font-family:var(--font-mono);margin-right:2px}
.scale-btn{padding:2px 7px;border-radius:4px;background:var(--bg3);color:var(--text3);font-size: 9px;cursor:pointer;border:1px solid transparent;font-family:var(--font-mono);transition:all .15s}
.scale-btn.active{background:rgba(230,126,34,0.12);color:var(--accent);border-color:rgba(230,126,34,0.3)}

/* Chart area — height = image height, no fixed constraint */
.chart-area{position:relative;background:#0a0f16;user-select:none;flex-shrink:0}
#ss-wrap{overflow-x:auto;overflow-y:hidden;position:relative;cursor:crosshair;width:100%}
#ss-wrap.panning{cursor:grabbing}
#baseImg{display:block;max-width:none}
.ss-placeholder{width:100%;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;border:2px dashed var(--border);transition:all .2s}
.ss-placeholder:hover{border-color:var(--accent);background:rgba(230,126,34,0.03)}
.ss-ph-icon{font-size: 28px;opacity:.3}
.ss-ph-text{font-size: 12px;color:var(--text3)}
.ss-ph-sub{font-size: 10px;color:var(--text3);opacity:.6}

/* Annotator overlay — now lives inside #img-container */
#ov > *{pointer-events:auto}

/* Trade boxes */
.tbox{position:absolute;border-radius:8px;cursor:crosshair}
.tbox:hover{cursor:move}
.tbox.win{border:2px solid rgba(38,166,154,0.7);background:rgba(38,166,154,0.07)}
.tbox.loss{border:2px solid rgba(239,83,80,0.7);background:rgba(239,83,80,0.07)}
.tbox.neutral{border:2px solid rgba(74,85,104,0.7);background:rgba(74,85,104,0.05)}
.tbox-lbl{position:absolute;padding:calc(4px * var(--pin-scale)) calc(4px * var(--pin-scale));border-radius:6px;font-size:calc(21px * var(--pin-scale));font-weight:700;font-family:var(--font-mono);white-space:nowrap;cursor:crosshair;z-index:2}
.tbox-lbl:hover{cursor:grab}
.tbox-lbl:active{cursor:grabbing}
.tbox-lbl.win{background:rgba(38,166,154,0.12);border:1.5px solid #26a69a;color:#26a69a}
.tbox-lbl.loss{background:rgba(239,83,80,0.12);border:1.5px solid #ef5350;color:#ef5350}
.tbox-lbl.neutral{background:rgba(74,85,104,0.12);border:1.5px solid #4a5568;color:#8b949e}
.tbox-pnl{position:absolute;padding:calc(4px * var(--pin-scale)) calc(4px * var(--pin-scale));border-radius:6px;background:rgba(13,17,23,0.88);font-size:calc(15px * var(--pin-scale));font-weight:700;font-family:var(--font-mono);white-space:nowrap;cursor:crosshair;z-index:2}
.tbox-pnl:hover{cursor:grab}
.tbox-pnl:active{cursor:grabbing}
.rh{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;border-radius:0 0 6px 0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,0.18) 40%)}

/* % pills */
.ppill{position:absolute;cursor:crosshair;padding:calc(1px * var(--pin-scale)) calc(4px * var(--pin-scale));border-radius:4px;font-family:var(--font-mono);font-size:calc(9px * var(--pin-scale));font-weight:700;white-space:nowrap}
.ppill:hover{cursor:grab}
.ppill:active{cursor:grabbing}
.ppill.tp{background:rgba(239,83,80,0.15);border:1px solid rgba(239,83,80,0.4);color:#ef5350}
.ppill.add{background:rgba(38,166,154,0.15);border:1px solid rgba(38,166,154,0.4);color:#26a69a}

/* T pin — scales with zoom via --pin-scale (1 = 50% zoom) */
:root{--pin-scale:1}
.tpin{position:absolute;cursor:crosshair;display:flex;flex-direction:column;align-items:center}
.tpin:hover{cursor:grab}
.tpin:active{cursor:grabbing}
.tpin-circle{width:calc(18px * var(--pin-scale));height:calc(18px * var(--pin-scale));border-radius:50%;background:rgba(201,168,76,0.15);border:1.5px solid var(--teacher);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:calc(9px * var(--pin-scale));font-weight:700;color:var(--teacher);flex-shrink:0}
.tpin-stem{width:2px;height:calc(37px * var(--pin-scale));background:rgba(201,168,76,0.5)}
.tpin-dot{width:calc(3px * var(--pin-scale));height:calc(3px * var(--pin-scale));border-radius:50%;background:var(--teacher);flex-shrink:0}
.tpin:hover .tpin-circle{background:rgba(201,168,76,0.3)}

/* M pin — scales with zoom */
.mpin{position:absolute;cursor:crosshair;display:flex;flex-direction:column;align-items:center}
.mpin:hover{cursor:grab}
.mpin:active{cursor:grabbing}
.mpin-circle{width:calc(18px * var(--pin-scale));height:calc(18px * var(--pin-scale));border-radius:50%;background:rgba(155,109,255,0.15);border:1.5px solid var(--missed-trade);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:calc(8px * var(--pin-scale));font-weight:700;color:var(--missed-trade);flex-shrink:0}
.mpin-stem{width:2px;height:calc(37px * var(--pin-scale));background:rgba(155,109,255,0.5)}
.mpin-dot{width:calc(3px * var(--pin-scale));height:calc(3px * var(--pin-scale));border-radius:50%;background:var(--missed-trade);flex-shrink:0}
.mpin:hover .mpin-circle{background:rgba(155,109,255,0.3)}

/* Day P&L card on chart */
.pnl-card{position:absolute;cursor:crosshair;background:rgba(13,17,23,0.92);border-radius:10px;padding:12px 28px;text-align:center;min-width:140px;transform:translate(-50%,-50%)}
.pnl-card:hover{cursor:grab}
.pnl-card:active{cursor:grabbing}
.pnl-card.pos{border:1.5px solid rgba(38,166,154,0.55)}
.pnl-card.neg{border:1.5px solid rgba(239,83,80,0.55)}
.pnl-sub{font-size: 11px;color:rgba(139,148,158,0.7);font-family:var(--font-mono);letter-spacing:3px;margin-bottom:4px;display:block}
.pnl-val{font-size: 28px;font-weight:700;font-family:var(--font-mono);display:block;line-height:1.2}
.pnl-card.pos .pnl-val{color:var(--green)}
.pnl-card.neg .pnl-val{color:var(--red)}

/* Notes section */
.notes-section{border-top:1px solid var(--border);background:var(--bg2);padding:10px 12px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}
/* 左栏滚到底时的底边留白：高度同 .right-body padding-bottom；独立块，不增大 notes 高度挤压上方 Chart */
.left-col-scroll-tail{flex:0 0 auto;height:56px;min-height:56px;width:100%;flex-shrink:0;pointer-events:none}
/* 右栏滚到底时的底边留白：
   .right-body 自身有 padding-bottom:12px；spacer 44px + padding 12px = 56px，
   与左栏 .left-col-scroll-tail (56px, 无 padding) 视觉对齐。 */
.right-body-scroll-tail{flex:0 0 auto;height:44px;min-height:44px;width:100%;flex-shrink:0;pointer-events:none}
.note-item{display:flex;flex-direction:column;gap:3px}
.note-lbl{font-size: 11px;letter-spacing:1.5px;color:var(--text3);text-transform:uppercase;font-family:var(--font-mono)}
.note-select{width:100%;padding:5px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size: 13px;font-family:inherit;outline:none;cursor:pointer;appearance:none;transition:border-color .15s}
.note-select:focus{border-color:var(--accent)}
.note-textarea{width:100%;padding:5px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size: 12px;font-family:inherit;resize:none;outline:none;min-height:40px;overflow:hidden;transition:border-color .15s;line-height:1.5}
#day-other{min-height:calc(40px + 12px * 1.5)}
.note-textarea:focus{border-color:var(--accent)}
.note-textarea::placeholder{color:var(--text3)}

/* Step 5: Deep Review button (Market Env row) — chip-like, 3 states */
.dr-btn{border:1px solid var(--text3);background:rgba(0,0,0,0.15);color:var(--text2);font-size: 10px;font-family:var(--font-base);letter-spacing:.5px;padding:3px 9px;border-radius:4px;cursor:pointer;white-space:nowrap;line-height:1.3;transition:all .15s;user-select:none}
.dr-btn:hover{border-color:var(--accent);color:var(--accent)}
.dr-btn.dr-btn--suggest{border-color:var(--accent);color:var(--accent);background:rgba(230,126,34,0.08)}
.dr-btn.dr-btn--suggest:hover{background:rgba(230,126,34,0.18)}
.dr-btn.dr-btn--done{border-color:var(--blue);color:var(--blue);background:rgba(100,149,237,0.1)}
.dr-btn.dr-btn--done:hover{background:rgba(100,149,237,0.2)}
.dr-btn:disabled{opacity:.5;cursor:not-allowed}
.dr-btn:disabled:hover{border-color:var(--text3);color:var(--text2);background:rgba(0,0,0,0.15)}

/* RIGHT COLUMN */
.right-col{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);min-width:0}
.right-header{padding:12px 18px 10px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}
.right-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.right-title{font-size: 17px;font-weight:700;color:var(--text)}
.right-actions{display:flex;gap:6px;align-items:center}
.date-nav{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.date-nav-btn{width:26px;height:26px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size: 14px;transition:all .15s}
.date-nav-btn:hover{border-color:var(--accent);color:var(--accent)}
#day-date-display{flex:1;text-align:center;font-size: 16px;font-family:var(--font-mono);color:var(--text);font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}
#day-date-display:hover{background:var(--bg3)}

/* Stats grid */
.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:8px 10px}
.stat-lbl{font-size: 11px;letter-spacing:1px;color:var(--text2);text-transform:uppercase;font-family:var(--font-mono);margin-bottom:3px}
.stat-val{font-size: 18px;font-weight:700;font-family:var(--font-mono);color:var(--text)}
.stat-val.pos{color:var(--win)}
.stat-val.neg{color:var(--loss)}
.stat-val.acc{color:var(--accent)}
.stat-val.muted{color:var(--text2)}

/* Right body */
.right-body{flex:1;overflow-y:auto;padding:12px 18px;display:flex;flex-direction:column;gap:10px}

/* ── Right-col Tab Switch (Log / Review) ──────────────────── */
.right-tab-bar{display:flex;align-items:center;gap:0;border-bottom:1px solid var(--border);padding:0 18px;flex-shrink:0;background:var(--bg2)}
.right-tab-btn{padding:8px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text2);font-size:11px;font-family:var(--font-mono);cursor:pointer;letter-spacing:.4px;transition:all .15s;white-space:nowrap}
.right-tab-btn:hover{color:var(--text)}
.right-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}

/* Review tab 内部布局 */
#review-tab-body{display:none;flex:1;flex-direction:column;min-height:0;overflow:hidden}
#review-tab-body.visible{display:flex}
#market-tab-body{display:none;flex:1;flex-direction:column;min-height:0;overflow:hidden}
#market-tab-body.visible{display:flex}
/* log-tab-body 按内容高度，flex-shrink:0 避免被 .right-body 的 flex 算法压缩
   导致内部子元素溢出 box（之前 spacer 漂浮在内容中段就是这个原因）。 */
#log-tab-body{display:flex;flex:0 0 auto;flex-direction:column;gap:10px;min-height:0}
#log-tab-body.hidden{display:none}

/* Review tab 内容区滚动容器 */
#rt-content{flex:1;overflow-y:auto;padding:12px 0 40px}
/* 工具栏 */
#rt-toolbar{display:flex;align-items:center;gap:8px;padding:10px 0 8px;flex-shrink:0;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:10px}
/* Follow-up 输入区 */
#rt-followup-bar{flex-shrink:0;padding:8px 0 0;border-top:1px solid var(--border);margin-top:8px;display:flex;gap:6px;align-items:flex-end}
#rt-followup-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11px;padding:7px 10px;resize:none;font-family:inherit;min-height:32px;max-height:80px;overflow-y:auto}
#rt-followup-input:focus{outline:none;border-color:var(--accent)}
/* 空状态 */
#rt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:16px;color:var(--text3);font-family:var(--font-base);font-size:11px;text-align:center}

/* 可折叠模块 (RT Tab Review 内容) */
.dr-section{margin:8px 0;border:1px solid var(--border);border-radius:8px;background:var(--bg2);overflow:hidden}
.dr-section--preamble{border:none;background:transparent;margin:0 0 12px 0}
.dr-section--preamble .dr-section-body{padding:0}
.dr-section-summary{padding:10px 14px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text);user-select:none;list-style:none;display:flex;align-items:center;gap:8px;transition:background .12s}
.dr-section-summary::-webkit-details-marker{display:none}
.dr-section-summary::before{content:'▸';display:inline-block;color:var(--text3);font-size:10px;transition:transform .15s;flex-shrink:0}
.dr-section[open] > .dr-section-summary::before{transform:rotate(90deg)}
.dr-section-summary:hover{background:var(--bg3)}
.dr-section-body{padding:0 16px 12px;font-size:12px;line-height:1.7;color:var(--text)}
.dr-section-body h3{margin:14px 0 6px;font-size:12px;color:var(--text);font-weight:600}
.dr-section-body h4{margin:10px 0 4px;font-size:11px;color:var(--text2);font-weight:600}
.dr-section-body p{margin:6px 0}
.dr-section-body ul,.dr-section-body ol{margin:6px 0;padding-left:20px}
.dr-section-body li{margin:3px 0}
.dr-section-body code{background:var(--bg3);padding:1px 5px;border-radius:3px;font-family:var(--font-mono);font-size:11px}
.dr-section-body strong{color:var(--text);font-weight:600}


/* Trade cards */
.trade-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}
.trade-card.win{border-left:3px solid var(--win)}
.trade-card.loss{border-left:3px solid var(--loss)}
.trade-card.breakeven{border-left:3px solid var(--text3)}
.trade-card-header{display:flex;align-items:center;padding:12px 16px;background:var(--bg3);border-bottom:1px solid var(--border);gap:10px;cursor:pointer;user-select:none}
.trade-number{width:26px;height:26px;border-radius:6px;font-size: 11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);flex-shrink:0}
.trade-number.win{background:rgba(38,166,154,0.12);border:1px solid rgba(38,166,154,0.3);color:var(--green)}
.trade-number.loss{background:rgba(239,83,80,0.12);border:1px solid rgba(239,83,80,0.3);color:var(--red)}
.trade-number.neutral{background:rgba(230,126,34,0.12);border:1px solid rgba(230,126,34,0.25);color:var(--accent)}
.trade-header-info{flex:1}
.trade-header-title{font-size: 13px;font-weight:600;color:var(--text)}
.trade-header-sub{font-size: 10px;color:var(--text2);font-family:var(--font-mono);margin-top:1px}
.trade-result-badge{padding:3px 10px;border-radius:16px;font-size: 11px;font-weight:600;font-family:var(--font-mono)}
.trade-result-badge.win{background:rgba(38,166,154,0.12);color:var(--win)}
.trade-result-badge.loss{background:rgba(239,83,80,0.12);color:var(--loss)}
.trade-result-badge.neutral{background:var(--bg3);color:var(--text3)}
.trade-pnl{font-size: 15px;font-weight:700;font-family:var(--font-mono);flex-shrink:0}
.trade-pnl.positive{color:var(--win)}
.trade-pnl.negative{color:var(--loss)}
.trade-expand-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;transition:transform .2s,color .15s;flex-shrink:0}
.trade-expand-btn.open{transform:rotate(180deg);color:var(--accent)}
.trade-card-body{display:none;padding:14px 16px}
.trade-card-body.open{display:block}
.trade-card.is-verified-lock .trade-card-body{background:linear-gradient(to bottom, rgba(120,130,150,0.08), rgba(120,130,150,0.06))}
.trade-card.is-verified-lock .trade-form-grid .form-label,
.trade-card.is-verified-lock .entries-label{color:rgba(203,213,225,0.78)}
.trade-card.is-verified-lock .field-textarea{background:rgba(255,255,255,0.02);border-color:rgba(148,163,184,0.28)}
.trade-card.is-verified-lock .error-tag,
.trade-card.is-verified-lock .early-tag{opacity:.74;filter:saturate(.68) brightness(.9)}
.trade-card.is-verified-lock .error-tag.selected,
.trade-card.is-verified-lock .early-tag.selected{opacity:.9;filter:saturate(.82) brightness(.95)}
.right-body.day-verified-lock #market-env-tags .menv-tag{opacity:.76;filter:saturate(.72) brightness(.92)}
.right-body.day-verified-lock .notes-section .note-lbl{color:rgba(203,213,225,0.82)}
.right-body.day-verified-lock .notes-section .note-textarea{opacity:.74;background:rgba(255,255,255,0.02);border-color:rgba(148,163,184,0.28)}
.left-col.day-verified-lock #market-env-tags .menv-tag{opacity:.76;filter:saturate(.72) brightness(.92)}
.left-col.day-verified-lock .notes-section .note-lbl{color:rgba(203,213,225,0.82)}
.left-col.day-verified-lock .notes-section .note-textarea{opacity:.74;background:rgba(255,255,255,0.02);border-color:rgba(148,163,184,0.28)}

/* Missing trade（漏单）卡片 */
.missed-trade-card{background:var(--bg2);border:1px solid rgba(155,109,255,0.25);border-left:3px solid var(--missed-trade);border-radius:10px;overflow:hidden;transition:border-color .15s}
.missed-trade-card-header{display:flex;align-items:center;padding:12px 16px;background:var(--bg3);border-bottom:1px solid var(--border);gap:10px;cursor:pointer;user-select:none}
.missed-trade-card-header:hover{background:rgba(155,109,255,0.05)}
.missed-trade-num{width:26px;height:26px;border-radius:6px;font-size: 11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);flex-shrink:0;background:rgba(155,109,255,0.12);border:1px solid rgba(155,109,255,0.3);color:var(--missed-trade)}
.missed-trade-header-info{flex:1}
.missed-trade-header-title{font-size: 12px;font-weight:700;color:var(--missed-trade)}
.missed-trade-header-sub{font-size: 10px;color:var(--text2);font-family:var(--font-mono);margin-top:1px}
.missed-trade-pill{padding:3px 10px;border-radius:16px;font-size: 10px;font-weight:600;font-family:var(--font-mono);background:rgba(155,109,255,0.1);border:1px solid rgba(155,109,255,0.25);color:var(--missed-trade);flex-shrink:0}
.missed-trade-expand-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;transition:transform .2s,color .15s;flex-shrink:0}
.missed-trade-expand-btn.open{transform:rotate(180deg);color:var(--missed-trade)}
.missed-trade-card-body{display:none;padding:14px 16px;flex-direction:column;gap:12px}
.missed-trade-card-body.open{display:flex}
.dir-toggle{display:flex;gap:6px}
.dir-btn{flex:1;padding:5px 0;border-radius:6px;font-size: 11px;font-weight:600;font-family:var(--font-mono);border:1px solid var(--border);background:transparent;color:var(--text3);cursor:pointer;transition:all .15s}
.dir-btn.long.active{background:rgba(38,166,154,0.12);border-color:rgba(38,166,154,0.4);color:var(--green)}
.dir-btn.short.active{background:rgba(239,83,80,0.12);border-color:rgba(239,83,80,0.4);color:var(--red)}
.dir-btn:not(.active):hover{border-color:var(--text2);color:var(--text2)}

/* Entries table */
.entries-section{margin-bottom:12px}
.entries-label{font-size: 11px;letter-spacing:1.5px;color:var(--text3);text-transform:uppercase;font-family:var(--font-mono);margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.entries-table{width:100%;border-collapse:collapse;table-layout:fixed}
/* Column % sum 100% (defaults match admin-tuned vars). */
.entries-col-type{width:var(--ec-t,17%)}
.entries-col-time{width:var(--ec-m,22%)}
.entries-col-price{width:var(--ec-p,17%)}
.entries-col-shares{width:var(--ec-s,18%)}
.entries-col-pct{width:var(--ec-c,19%)}
.entries-col-action{width:var(--ec-a,7%)}
.entries-table th{font-size: 11px;letter-spacing:1px;color:var(--text3);font-family:var(--font-mono);text-transform:uppercase;padding:4px 6px;text-align:left;border-bottom:1px solid var(--border)}
.entries-table td{padding:4px 4px;vertical-align:middle}
/* Price: left band — align with Type/Time flow */
.entries-table th:nth-child(3),
.entries-table td:nth-child(3){text-align:left;font-variant-numeric:tabular-nums}
.entries-table th:nth-child(4),
.entries-table td:nth-child(4){white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;padding-right:var(--ec-pr-sh,16px)}
/* %: right band — badges sit in open area before delete */
.entries-table th:nth-child(5),
.entries-table td:nth-child(5){padding-left:var(--ec-pl-pct,12px);text-align:center}
.entries-table th:nth-child(6),
.entries-table td:nth-child(6){text-align:center;padding-left:0;padding-right:0}
.entries-table tr:not(:last-child) td{border-bottom:1px solid rgba(255,255,255,0.03)}
.entry-type-badge{font-size: 9px;font-family:var(--font-mono);padding:2px 6px;border-radius:4px;font-weight:600}
.entry-type-badge.entry{background:rgba(38,166,154,0.12);color:var(--win)}
.entry-type-badge.exit{background:rgba(239,83,80,0.12);color:var(--loss)}
.entry-type-badge.teacher{background:rgba(100,149,237,0.12);color:#6495ed}
.entry-remove{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px 4px;border-radius:4px;font-size: 13px;transition:color .15s}
.entry-remove:hover{color:var(--red)}
.cell-editable{cursor:pointer;padding:2px 5px;border-radius:3px;transition:background .1s}
.cell-editable:hover{background:var(--bg3);outline:1px solid var(--border)}
.pct-badge{font-size: 9px;font-family:var(--font-mono);padding:2px 6px;border-radius:3px;font-weight:700;background:rgba(239,83,80,0.1);color:#ef5350;border:1px solid rgba(239,83,80,0.2)}
.pct-badge.add{background:rgba(38,166,154,0.1);color:#26a69a;border:1px solid rgba(38,166,154,0.2)}
.add-entry-toggle{font-size: 10px;color:var(--text3);cursor:pointer;padding:4px 6px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;transition:color .15s;font-family:var(--font-mono);margin-top:4px}
.add-entry-toggle:hover{color:var(--accent)}
.add-entry-row{display:none;gap:5px;margin-top:6px;flex-wrap:wrap}
.add-entry-row.open{display:flex}
.add-entry-row .form-input{flex:1;min-width:60px}

/* Trade form */
.trade-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.form-field{display:flex;flex-direction:column;gap:4px}
.form-label{font-size: 10px;letter-spacing:1px;color:var(--text2);text-transform:uppercase;font-family:var(--font-base)}
.form-input{padding:6px 9px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size: 12px;font-family:inherit;outline:none;transition:border-color .15s;width:100%}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--text3)}
.form-input.auto-val{color:var(--text2);background:rgba(255,255,255,0.02)}
.field-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%234a5568' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}
.field-select:focus{border-color:var(--accent)}
.field-textarea{width:100%;padding:7px 9px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size: 12px;font-family:inherit;resize:none;outline:none;overflow:hidden;transition:border-color .15s;line-height:1.5;min-height:52px}
.field-textarea:focus{border-color:var(--accent)}
.field-textarea::placeholder{color:var(--text3)}

/* Error & early-exit tags */
.error-tags-container{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.error-tag{padding:4px 10px;border-radius:16px;font-size: 10px;font-family:var(--font-mono);cursor:pointer;border:1px solid var(--border);color:var(--text3);transition:all .15s;user-select:none}
.error-tag:hover{border-color:var(--accent);color:var(--accent)}
.error-tag.selected{background:rgba(230,126,34,0.1);border-color:rgba(230,126,34,0.35);color:var(--accent)}
.error-tag.perfect:hover{border-color:var(--green);color:var(--green)}
.error-tag.perfect.selected{background:rgba(38,166,154,0.1);border-color:rgba(38,166,154,0.35);color:var(--green)}
.early-tag{padding:4px 10px;border-radius:16px;font-size: 10px;font-family:var(--font-mono);cursor:pointer;border:1px solid var(--border);color:var(--text3);transition:all .15s;user-select:none}
.early-tag:hover{border-color:var(--accent);color:var(--accent)}
.early-tag.selected{background:rgba(230,126,34,0.1);border-color:rgba(230,126,34,0.35);color:var(--accent)}
/* Early Exit - Profit Missed 的 R 输入框（inline，跟在标签后面；高度必须和 .early-tag 完全一致） */
.early-r-wrap{display:inline-flex;align-items:center;gap:3px;padding:4px 8px;border-radius:16px;background:rgba(239,83,80,0.08);border:1px solid rgba(239,83,80,0.3);font-family:var(--font-mono);font-size:10px;line-height:1;color:var(--red);user-select:none;box-sizing:border-box;vertical-align:middle}
.early-r-wrap .early-r-lbl{font-size:9px;opacity:.65;letter-spacing:0;text-transform:uppercase;line-height:1}
.early-r-wrap .early-r-unit{font-size:10px;opacity:.8;line-height:1}
.early-r-input{width:26px;height:14px;line-height:1;padding:0;margin:0;background:transparent;border:none;outline:none;color:var(--red);font-family:var(--font-mono);font-size:11px;text-align:right;-moz-appearance:textfield;box-sizing:border-box}
.early-r-input::-webkit-outer-spin-button,.early-r-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.early-r-input:focus{color:var(--red)}
/* Market env tags */
.menv-tag{padding:4px 10px;border-radius:16px;font-size: 10px;font-family:var(--font-base);cursor:pointer;border:1px solid var(--border);color:var(--text3);transition:all .15s;user-select:none}
.menv-tag:hover{border-color:var(--green);color:var(--green)}
.menv-tag.selected{background:rgba(38,166,154,0.1);border-color:rgba(38,166,154,0.35);color:var(--green)}
/* Green-tagged error/early tags - 未选中时保持暗灰，只在选中或hover时显示灰绿色 */
.error-tag.green-tag:hover{border-color:var(--green);color:var(--green)}
.error-tag.green-tag.selected{background:rgba(38,166,154,0.1);border-color:rgba(38,166,154,0.35);color:var(--green)}
.early-tag.green-tag:hover{border-color:var(--green);color:var(--green)}
.early-tag.green-tag.selected{background:rgba(38,166,154,0.1);border-color:rgba(38,166,154,0.35);color:var(--green)}
/* Settings draggable items */
.settings-tag-draggable{cursor:grab;display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;font-size: 10px;font-family:var(--font-mono);color:var(--text2);user-select:none}
.settings-tag-draggable:active{cursor:grabbing}
.settings-tag-draggable.drag-over{border-color:var(--accent)}
.menv-color-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);border:1.5px solid var(--accent);flex-shrink:0;cursor:pointer;transition:all .15s;padding:5px;box-sizing:content-box}
.menv-color-dot.green{background:var(--green);border-color:var(--green)}

/* Result badge */
.result-auto{padding:3px 10px;border-radius:16px;font-size: 10px;font-weight:700;font-family:var(--font-mono);display:inline-block}
.result-auto.win{background:rgba(38,166,154,0.12);color:var(--green)}
.result-auto.loss{background:rgba(239,83,80,0.12);color:var(--red)}
.result-auto.neutral{background:rgba(74,85,104,0.1);color:var(--text3)}

/* Trade card footer */
.trade-card-footer{display:flex;justify-content:flex-end;gap:6px;padding-top:12px;margin-top:12px;border-top:1px solid var(--border)}

/* Add trade */
.add-trade-btn{border:2px dashed var(--border);border-radius:10px;padding:16px;text-align:center;cursor:pointer;color:var(--text3);font-size: 12px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.add-trade-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(230,126,34,0.03)}

/* AI result panel */
.ai-result{background:rgba(230,126,34,0.05);border:1px solid rgba(230,126,34,0.2);border-radius:8px;padding:10px;margin-bottom:12px;display:none}
.ai-result.show{display:block}
.ai-result-header{font-size: 9px;letter-spacing:1.5px;color:var(--accent);text-transform:uppercase;font-family:var(--font-mono);margin-bottom:6px}
.ai-result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.ai-result-label{font-size: 9px;color:var(--text3);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;margin-bottom:2px}
.ai-result-value{font-size: 12px;color:var(--text);font-family:var(--font-mono);font-weight:600}
.ai-analyzing{display:flex;align-items:center;gap:8px;font-size: 11px;color:var(--accent);font-family:var(--font-mono)}
.ai-analyzing-dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent);margin:0 1px;animation:dot-bounce 1.2s ease-in-out infinite}
.ai-analyzing-dots span:nth-child(2){animation-delay:.2s}
.ai-analyzing-dots span:nth-child(3){animation-delay:.4s}
@keyframes dot-bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}}

/* Teacher comparison section */
.teacher-section{background:var(--bg2);border:1px solid rgba(100,149,237,0.15);border-radius:10px;padding:14px 16px}
.teacher-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.teacher-section-title{font-size: 11px;font-weight:700;color:var(--teacher);letter-spacing:1px;text-transform:uppercase;font-family:var(--font-mono)}
.teacher-sync-rate{font-size: 13px;font-weight:700;font-family:var(--font-mono);color:var(--teacher)}
.teacher-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.teacher-row:last-child{border-bottom:none}
.teacher-trade-lbl{font-size: 11px;color:var(--text2);font-family:var(--font-mono)}
.sync-badge{padding:2px 8px;border-radius:4px;font-size: 9px;font-weight:700;font-family:var(--font-mono)}
.sync-y{background:rgba(38,166,154,0.12);color:var(--green)}
.sync-n{background:rgba(239,83,80,0.12);color:var(--red)}

/* ── STATS FILTER BUTTONS ───────────────────────────────── */
.st-filter-btn{padding:2px 8px;border-radius:5px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size: 11px;font-family:var(--font-mono);cursor:pointer;transition:all .15s}
.st-filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.st-filter-btn.active{background:rgba(230,126,34,0.12);border-color:rgba(230,126,34,0.4);color:var(--accent)}
.st-filter-btn.green.active{background:rgba(38,166,154,0.12);border-color:rgba(38,166,154,0.4);color:var(--green)}
.st-filter-btn.orange.active{background:rgba(230,126,34,0.12);border-color:rgba(230,126,34,0.4);color:var(--accent)}

/* ── CUSTOM CALENDAR ─────────────────────────────────────── */
#cal-popup{display:none;position:fixed;z-index:9000;background:var(--bg2);
  border:1px solid var(--border);border-radius:12px;padding:16px;width:268px;
  box-shadow:0 20px 60px rgba(0,0,0,.8);user-select:none}
#cal-popup.open{display:block}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-title{font-size: 13px;font-weight:700;color:var(--text);font-family:var(--font-base)}
.cal-nav{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px 8px;
  border-radius:5px;font-size: 16px;line-height:1;transition:all .15s}
.cal-nav:hover{background:var(--bg3);color:var(--accent)}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.cal-wd{text-align:center;font-size: 9px;letter-spacing:1px;color:var(--text3);
  font-family:var(--font-mono);padding:3px 0;text-transform:uppercase}
.cal-wd.weekend{color:rgba(74,85,104,0.5)}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-day{display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:5px 2px 4px;border-radius:7px;cursor:pointer;transition:all .15s;border:1px solid transparent}
.cal-day:hover:not(.weekend):not(.other-month){background:var(--bg3);border-color:var(--border)}
.cal-day.today{border-color:rgba(230,126,34,0.4);background:rgba(230,126,34,0.06)}
.cal-day.selected{background:rgba(230,126,34,0.15);border-color:var(--accent)}
.cal-day.weekend{cursor:default;opacity:0.35}
.cal-day.other-month{cursor:default;opacity:0.2}
.cal-day-num{font-size: 12px;font-family:var(--font-mono);color:var(--text);line-height:1}
.cal-day.weekend .cal-day-num{color:var(--text3)}
.cal-day.selected .cal-day-num{color:var(--accent);font-weight:700}
.cal-day.today .cal-day-num{color:var(--accent)}
.cal-dot{width:4px;height:4px;border-radius:50%;background:var(--text3);opacity:0.25;transition:all .2s}
.cal-dot.has-data{background:var(--accent);opacity:1;box-shadow:0 0 4px rgba(230,126,34,0.6)}

.page-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.page-placeholder-icon{font-size: 48px;opacity:.2}
.page-placeholder-text{font-size: 14px;color:var(--text3)}
.page-placeholder-sub{font-size: 11px;color:var(--text3);opacity:.6}

/* Settings */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;padding:12px 24px 60px;overflow-y:auto;overflow-x:hidden;flex:1;align-content:start;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}
/* Settings tab bar（hybrid：顶部 tab 切换模块） */
#settings-tabbar{max-width:1400px;width:100%;margin:0 auto;padding:14px 24px 0;box-sizing:border-box;display:flex;align-items:center;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:4px}
.settings-tabbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;width:100%}
.settings-tab{position:relative;padding:8px 16px;background:transparent;border:none;color:var(--text2);font-size:12px;font-family:var(--font-mono);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;letter-spacing:.3px}
.settings-tab:hover{color:var(--text)}
.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.settings-tab-badge{display:inline-block;margin-left:4px;padding:1px 6px;font-size:9px;background:var(--accent);color:var(--bg);border-radius:9px;font-weight:700;line-height:1.3;vertical-align:middle}
.settings-tab-desc{margin-left:auto;font-size:10px;color:var(--text3);font-family:var(--font-mono);padding:6px 8px;opacity:.7}
.settings-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;min-width:0;overflow-wrap:anywhere;word-break:break-word}
.settings-card textarea,.settings-card input[type="text"]{max-width:100%;box-sizing:border-box;line-height:1.5}
.settings-card textarea{min-height:56px;font-family:var(--font-mono)}
/* 长列表内部滚动，避免把整张卡片撑得过高 */
.settings-card > div[id^="stl-"]{max-height:280px;overflow-y:auto;padding-right:4px}
.settings-card > div[id^="stl-"]::-webkit-scrollbar{width:6px}
.settings-card > div[id^="stl-"]::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.settings-card-title{font-size: 12px;font-weight:600;color:var(--text);margin-bottom:3px}
.settings-card-sub{font-size: 10px;color:var(--text3);margin-bottom:12px}
.settings-tag-list{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.settings-tag{padding:4px 10px;border-radius:16px;background:var(--bg3);border:1px solid var(--border);font-size: 10px;color:var(--text2);display:flex;align-items:center;gap:5px;font-family:var(--font-mono)}
.settings-tag-remove{background:none;border:none;color:var(--text3);cursor:pointer;font-size: 13px;line-height:1;padding:0;transition:color .15s}
.settings-tag-remove:hover{color:var(--red)}
.settings-add-row{display:flex;gap:6px}
.settings-add-input{flex:1;padding:6px 9px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size: 11px;outline:none;font-family:inherit;transition:border-color .15s}
.settings-add-input:focus{border-color:var(--accent)}

/* Toast */
#toast-container{position:fixed;top:20px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:6px;z-index:99999;pointer-events:none}
.toast{padding:9px 14px;border-radius:7px;font-size: 11px;font-family:var(--font-base);border:1px solid;animation:toastIn .3s ease;pointer-events:auto}
.toast.success{background:rgba(38,166,154,0.12);border-color:rgba(38,166,154,0.3);color:var(--win)}
.toast.error{background:rgba(239,83,80,0.12);border-color:rgba(239,83,80,0.3);color:var(--red)}
.toast.info{background:rgba(230,126,34,0.12);border-color:rgba(230,126,34,0.3);color:var(--accent)}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* Loading */
#loading{position:fixed;inset:0;z-index:8888;background:var(--bg);display:none;align-items:center;justify-content:center}
.loading-ring{width:32px;height:32px;border-radius:50%;border:3px solid var(--bg3);border-top-color:var(--accent);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.divider{height:1px;background:var(--border);margin:4px 0}


/* ── TEACHER COMPARISON CSS ──────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d1117;--bg2:#131922;--bg3:#1a2233;
  --border:rgba(255,255,255,0.07);
  --accent:#e67e22;--green:#26a69a;--red:#ef5350;--blue:#6495ed;
  --text:#e6edf3;--text2:#8b949e;--text3:#6f7b8a;--text-muted:#97a2b0;--text-faint:#727e8d;
  --font-mono:'SF Mono','Fira Code','Consolas',monospace;
  --font-base:'Microsoft YaHei','PingFang SC',sans-serif;
}

/* 2026-05-21 (修): 此处原有一条 body{padding:20px} (teacher comparison 老模块的残留),
   不带作用域, 给全局 body 加了 20px 内边距, 导致主程序 #app 三方向露出黑边. 已删除. */

.container{max-width:1300px;margin:0 auto}

h1{font-size: 20px;font-weight:700;margin-bottom:20px}

.section{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:10px;padding:20px;
}

.header-row{
  display:grid;grid-template-columns:1fr auto;
  align-items:center;margin-bottom:20px;gap:40px;padding-bottom:20px;border-bottom:1px solid var(--border)
}

.header-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

.section-title{
  font-size: 13px;font-weight:700;color:var(--teacher);
  letter-spacing:1px;text-transform:uppercase;
  font-family:var(--font-mono);display:flex;align-items:center;gap:6px;white-space:nowrap
}

/* 2026-05-24: 删除 .section-title::before — 项目内无 .section-title 类使用 (死代码). */

.teacher-input-row{display:flex;align-items:center;gap:8px;flex-shrink:0}

.time-picker-trigger{
  padding:6px 20px;background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;color:var(--text);font-family:var(--font-mono);
  font-size: 12px;cursor:pointer;transition:border .2s;min-width:65px;text-align:center
}

.time-picker-trigger:hover{border-color:var(--accent)}

.btn{
  padding:8px 12px;background:var(--text3);color:#fff;border:none;
  border-radius:6px;font-size: 11px;font-weight:700;cursor:pointer;
  transition:background .2s;font-family:var(--font-mono);white-space:nowrap
}

.btn:hover{background:var(--text2)}

.btn-reset{
  padding:8px 12px;background:var(--accent);color:#fff;border:none;
  border-radius:6px;font-size: 11px;font-weight:700;cursor:pointer;
  transition:background .2s;font-family:var(--font-mono);white-space:nowrap
}

.btn-reset:hover{background:#d06a16}

.header-right{
  font-size: 14px;font-weight:700;color:var(--teacher);font-family:var(--font-mono);text-align:right
}

.sync-rate-number{color:var(--accent);font-size: 16px}

/* TIME PICKER MODAL */
.time-picker-modal{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.7);align-items:center;justify-content:center
}

.time-picker-modal.open{display:flex}

.time-picker-content{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:12px;padding:16px;width:280px;box-shadow:0 20px 60px rgba(0,0,0,0.8)
}

.time-picker-header{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:20px
}

.time-picker-close{
  background:none;border:none;color:var(--text3);cursor:pointer;font-size: 20px;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center
}

.time-picker-close:hover{color:var(--text)}

.time-picker-display{
  display:flex;align-items:center;justify-content:center;gap:4px;
  font-size: 42px;font-weight:700;color:var(--text);font-family:var(--font-mono);margin-bottom:16px
}

.time-picker-wheels{
  display:grid;grid-template-columns:1fr auto 1fr;gap:12px;margin-bottom:20px
}

.time-wheel{
  display:flex;flex-direction:column;align-items:center;gap:8px
}

.wheel-label{
  font-size: 10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-family:var(--font-mono)
}

.wheel{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:var(--bg3);border-radius:8px;padding:8px;height:140px;overflow-y:scroll;scrollbar-width:none
}

.wheel::-webkit-scrollbar{display:none}

.wheel-item{
  padding:8px 12px;font-size: 16px;color:var(--text2);font-family:var(--font-mono);
  cursor:pointer;border-radius:4px;white-space:nowrap;transition:all .2s
}

.wheel-item:hover{background:rgba(230,126,34,0.2);color:var(--accent)}

.wheel-item.active{
  background:var(--accent);color:#fff;font-weight:700;transform:scale(1.1)
}

.time-picker-footer{
  display:flex;gap:8px
}

.time-picker-btn{
  flex:1;padding:10px;border:none;border-radius:6px;
  font-size: 12px;font-weight:700;cursor:pointer;font-family:var(--font-mono);
  transition:all .2s
}

.time-picker-btn-confirm{
  background:var(--accent);color:#fff
}

.time-picker-btn-confirm:hover{background:#d06a16}

.time-picker-btn-cancel{
  background:var(--bg3);color:var(--text2);border:1px solid var(--border)
}

.time-picker-btn-cancel:hover{border-color:var(--text2);color:var(--text)}

/* COMPARISON TABLE */
.comparison-table{
  display:flex;flex-direction:column;gap:6px;overflow-x:visible;padding-bottom:2px;width:100%
}

.table-header{
  display:grid;
  grid-template-columns:minmax(44px,.95fr) minmax(52px,1.05fr) minmax(10px,.3fr) minmax(44px,.95fr) minmax(52px,1.05fr) minmax(44px,.85fr) minmax(72px,1.1fr);
  gap:10px;padding:10px 12px;background:var(--bg3);border-radius:6px;
  font-size: 9px;font-weight:700;color:var(--text3);
  letter-spacing:1px;text-transform:uppercase;font-family:var(--font-mono);
  box-sizing:border-box;width:100%;
}

.trade-row{
  display:grid;
  grid-template-columns:minmax(44px,.95fr) minmax(52px,1.05fr) minmax(10px,.3fr) minmax(44px,.95fr) minmax(52px,1.05fr) minmax(44px,.85fr) minmax(72px,1.1fr);
  gap:10px;padding:10px 12px;background:var(--bg3);border-radius:6px;
  border-left:3px solid transparent;align-items:center;box-sizing:border-box;width:100%;
}

.trade-row.sync{border-left-color:var(--green);background:rgba(38,166,154,0.06)}
.trade-row.miss{border-left-color:var(--red);background:rgba(239,83,80,0.06)}
.trade-row.pending{border-left-color:var(--text3)}
.trade-row.after{border-left-color:var(--text3);background:rgba(139,148,158,0.04);opacity:.7}

.col-label{font-weight:700;color:var(--teacher);font-family:var(--font-mono);font-size: 11px}
.col-time{color:var(--text);font-family:var(--font-mono);font-size: 11px}
.col-detail{font-size: 10px;color:var(--text2);font-family:var(--font-mono)}
.col-empty{color:var(--text3);font-size: 10px}

.divider{width:1px;background:var(--border);height:16px;margin:0;justify-self:center}

.sync-control{display:flex;gap:3px}

.sync-btn{
  padding:4px 6px;border:1px solid var(--border);background:transparent;
  border-radius:4px;color:var(--text3);font-size: 10px;font-weight:600;
  cursor:pointer;transition:all .2s;font-family:var(--font-mono);min-width:24px;text-align:center
}

.sync-btn:hover{background:var(--bg)}
.sync-btn.active{border-color:var(--accent);background:rgba(230,126,34,0.2);color:var(--accent)}

.empty-state{text-align:center;padding:20px;color:var(--text3);font-size: 12px}

.demo-controls{
  margin-top:20px;padding:12px;background:var(--bg3);border-radius:6px;display:flex;gap:8px
}

.demo-controls button{font-size: 10px}

/* ── STATS PAGE ─────────────────────────────────────────── */
#page-stats{overflow:hidden;display:none;flex-direction:column;--st-pad:10px;--st-section-gap:var(--st-pad)}
#page-stats.active{display:flex}
/* Statistics：统一左右内边距 + 居中内容列（与上下间距同一节奏） */
.stats-innerCol{
  width:100%;
  max-width:min(1360px,97%);
  margin-left:auto;
  margin-right:auto;
  box-sizing:border-box;
  padding-left:var(--st-pad,20px);
  padding-right:var(--st-pad,20px);
}
.stats-hdr{
  flex-shrink:0;
  width:100%;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:0;
}
.stats-hdr-inner{padding:14px 0 8px;width:100%;box-sizing:border-box}
.stats-hdr-tab-wrap{padding:8px 0 10px}
.stats-hdr-rule{
  display:block;
  border:0;
  border-top:1px solid var(--border);
  margin:0;
  padding:0;
  width:100%;
  height:0;
  background:transparent;
}
.stats-hdr-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px;flex-wrap:wrap}
/* Statistics 标题 + Overview/Calendar tabs 同一行(2 行布局) */
.stats-hdr-title-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.stats-hdr-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.02em;white-space:nowrap}
.stats-tabs-inline{display:flex;align-items:flex-end;align-self:stretch}
/* tab 在 title 行内时:去除独占行的下 border 间距,直接靠 padding 撑高度 */
.stats-tabs-inline .stats-tab{padding:8px 18px}
.stats-range-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;max-width:min(100%,560px);text-align:right}
.stats-range-lbl{font-size: 12px;color:var(--text2);font-family:var(--font-mono);font-weight:500;line-height:1.4}
/* Overview 选周下拉（日历样式对齐 Daily Log） */
.st-week-pop{display:none;position:fixed;z-index:9400;width:min(420px,calc(100vw - 24px));box-sizing:border-box}
.st-week-pop.open{display:block}
.st-week-pop-panel{position:relative;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 32px rgba(0,0,0,.55);padding:10px}
.st-week-pop-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.st-week-pop-title{flex:1;text-align:center;font-size:14px;font-weight:700;color:var(--text);font-family:var(--font-mono)}
.st-week-pop-nav{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;font-size:16px;line-height:1}
.st-week-pop-nav:hover{border-color:var(--accent);color:var(--accent)}
.st-wp-grid{width:100%}
.st-wp-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.st-wp-dows span{text-align:center;font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.st-wp-rows{display:flex;flex-direction:column;gap:6px}
.st-wp-row{display:grid;grid-template-columns:1fr minmax(0,5fr) 1fr;gap:4px;align-items:stretch;min-height:42px}
.st-wp-row--sel .st-wp-wend{opacity:0.5}
.st-wp-row > .st-wp-wend{border:1px solid var(--border);background:rgba(255,255,255,0.02);border-radius:8px}
.st-wp-mid5{display:flex;flex-direction:row;flex:1;min-width:0;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:rgba(255,255,255,0.03);transition:background .15s,border-color .15s,box-shadow .15s;cursor:pointer}
.st-wp-mid5:hover{background:rgba(230,126,34,0.08);border-color:rgba(230,126,34,0.35)}
.st-wp-mid5--week{border-color:rgba(230,126,34,0.55);box-shadow:0 0 0 1px rgba(230,126,34,0.2) inset;background:rgba(230,126,34,0.1)}
.st-wp-mid5--week:hover{background:rgba(230,126,34,0.16);border-color:rgba(230,126,34,0.75)}
.st-wp-day{flex:1;min-width:0;min-height:40px;border:none;border-radius:0;background:transparent;color:var(--text);font-size:12px;font-family:var(--font-mono);cursor:pointer;padding:2px 0 3px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.st-wp-wend{opacity:0.42;color:var(--text3)}
.st-wp-wend:hover{opacity:0.65;color:var(--text2)}
.st-wp-rth{color:var(--text);font-weight:500}
.st-wp-mid5 .st-wp-day{border-right:1px solid rgba(255,255,255,0.06)}
.st-wp-mid5 .st-wp-day:last-child{border-right:none}
.st-wp-day--muted{opacity:0.38}
.st-wp-day--week{background:rgba(230,126,34,0.22);color:var(--accent);font-weight:600}
.st-wp-day-num{line-height:1}
.st-wp-dot{width:4px;height:4px;border-radius:50%;background:var(--text3);opacity:0.25;transition:all .2s}
.st-wp-dot.has-data{background:var(--accent);opacity:1;box-shadow:0 0 4px rgba(230,126,34,0.6)}
.st-wp-row--sel .st-wp-mid5 .st-wp-day--week{background:rgba(230,126,34,0.28)}
.st-range-week-tap{cursor:pointer;text-decoration:underline;text-decoration-color:rgba(230,126,34,0.45);text-underline-offset:3px}
.st-range-week-tap:hover{color:var(--accent)}
/* v7.6 · Weekly Report 选周按钮（在 page-header 里）+ 弹窗（Mon–Sun 周制 + 行右徽标） */
.wr-week-pick-btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-family:var(--font-mono);font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s;margin-left:24px}
.wr-week-pick-btn:hover{border-color:rgba(230,126,34,0.45);color:var(--text)}
.wr-week-pick-text{line-height:1.2}
.wr-week-pick-chev{font-size:9px;color:var(--text3)}
.wr-week-pop{display:none;position:fixed;z-index:9400;width:min(460px,calc(100vw - 24px));box-sizing:border-box}
.wr-week-pop.open{display:block}
.wr-week-pop-panel{position:relative;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 32px rgba(0,0,0,.55);padding:10px}
.wr-week-pop-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.wr-week-pop-title{flex:1;text-align:center;font-size:14px;font-weight:700;color:var(--text);font-family:var(--font-mono)}
.wr-week-pop-nav{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;font-size:16px;line-height:1}
.wr-week-pop-nav:hover{border-color:var(--accent);color:var(--accent)}
.wr-wp-grid{width:100%}
/* v7.8-B3f：dows 4 列结构跟 row 对齐 [Su 1fr | Mo-Fr 5fr inner | Sa 1fr | meta 64px]，中间 inner 用同样的 mid5 padding 把 5 个字母与下方数字对齐 */
.wr-wp-dows{display:grid;grid-template-columns:1fr minmax(0,5fr) 1fr 64px;gap:4px;margin-bottom:6px;padding:0 6px}
.wr-wp-dows > span{text-align:center;font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.wr-wp-dows-mid5{display:flex;flex-direction:row;flex:1;min-width:0;border:1px solid transparent;border-radius:8px}
.wr-wp-dows-mid5 > span{flex:1;text-align:center;font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.wr-wp-rows{display:flex;flex-direction:column;gap:5px}
/* v7.8-B3f：行结构对齐 stWeekPicker：[Su 1fr] [Mo-Fr 5fr 中间块] [Sa 1fr] [meta 64px] */
.wr-wp-row{display:grid;grid-template-columns:1fr minmax(0,5fr) 1fr 64px;gap:4px;align-items:stretch;min-height:38px;padding:3px 6px;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}
.wr-wp-row:hover .wr-wp-mid5{background:rgba(230,126,34,0.08);border-color:rgba(230,126,34,0.35)}
.wr-wp-row--sel .wr-wp-wend{opacity:0.5}
.wr-wp-row > .wr-wp-wend{border:1px solid var(--border);background:rgba(255,255,255,0.02);border-radius:8px}
.wr-wp-mid5{display:flex;flex-direction:row;flex:1;min-width:0;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:rgba(255,255,255,0.03);transition:background .15s,border-color .15s,box-shadow .15s}
.wr-wp-mid5--week{border-color:rgba(230,126,34,0.55);box-shadow:0 0 0 1px rgba(230,126,34,0.2) inset;background:rgba(230,126,34,0.1)}
.wr-wp-row:hover .wr-wp-mid5--week{background:rgba(230,126,34,0.16);border-color:rgba(230,126,34,0.75)}
.wr-wp-day{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:3px 0;font-family:var(--font-mono);color:var(--text);font-size:11px;flex:1;min-width:0;min-height:36px}
.wr-wp-wend{opacity:0.42;color:var(--text3)}
.wr-wp-row:hover .wr-wp-wend{opacity:0.65;color:var(--text2)}
.wr-wp-rth{color:var(--text);font-weight:500}
.wr-wp-mid5 .wr-wp-day{border-right:1px solid rgba(255,255,255,0.06)}
.wr-wp-mid5 .wr-wp-day:last-child{border-right:none}
.wr-wp-day--muted{opacity:0.38}
.wr-wp-day--week{background:rgba(230,126,34,0.22);color:var(--accent);font-weight:600}
.wr-wp-row--sel .wr-wp-mid5 .wr-wp-day--week{background:rgba(230,126,34,0.28)}
.wr-wp-dnum{line-height:1}
.wr-wp-ddot{width:4px;height:4px;border-radius:50%;background:var(--text3);opacity:0.25;transition:all .2s}
.wr-wp-ddot.has{background:var(--accent);opacity:1;box-shadow:0 0 4px rgba(230,126,34,0.6)}
.wr-wp-meta{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:3px;padding:0 4px;font-family:var(--font-mono);min-width:0}
.wr-wp-pnl{font-size:11px;font-weight:600;line-height:1.2;text-align:right}
.wr-wp-pnl--pos{color:var(--green,#26a69a)}
.wr-wp-pnl--neg{color:var(--red,#ef5350)}
.wr-wp-pnl--none{color:var(--text3)}
.wr-wp-stat{font-size:10px;line-height:1;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-family:var(--font-mono)}
.wr-wp-stat--ok{color:#fff;background:var(--green,#26a69a)}
.wr-wp-stat--pending{color:var(--text3);background:transparent;border:1px solid var(--border)}
.wr-wp-stat--empty{color:var(--text3);background:transparent}
.wr-wp-foot{display:flex;justify-content:flex-end;margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}
.wr-wp-foot-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:4px 12px;font-size:11px;font-family:var(--font-mono);cursor:pointer}
.wr-wp-foot-btn:hover{border-color:var(--accent);color:var(--accent)}
/* v7.6 · Daily Deep Review 日期选择按钮 + chip strip + mini calendar 弹窗 */
.dr-date-pick-btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-family:var(--font-mono);font-size:12px;color:var(--text);cursor:pointer;transition:all .15s;min-width:160px}
.dr-date-pick-btn:hover{border-color:rgba(230,126,34,0.45)}
.dr-date-pick-text{line-height:1.2;flex:1;text-align:left}
.dr-date-pick-chev{font-size:9px;color:var(--text3)}
.dr-recent-strip{padding:10px 24px 8px;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.015)}
.dr-recent-strip:empty{display:none}
.dr-recent-label{font-size:9px;color:var(--text3);font-family:var(--font-mono);letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}
.dr-recent-empty{font-size:11px;color:var(--text3);font-family:var(--font-mono);padding:2px 0}
.dr-recent-chips{display:flex;flex-wrap:wrap;gap:6px}
.dr-recent-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:4px 10px;font-family:var(--font-mono);font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s}
.dr-recent-chip:hover{border-color:rgba(230,126,34,0.45);color:var(--text)}
.dr-recent-chip--sel{background:rgba(230,126,34,0.14);border-color:rgba(230,126,34,0.55);color:var(--accent)}
.dr-recent-date{line-height:1}
.dr-recent-pnl{font-size:10px;font-weight:600;line-height:1}
.dr-recent-pnl.pos{color:var(--green,#26a69a)}
.dr-recent-pnl.neg{color:var(--red,#ef5350)}
.dr-recent-check{color:var(--green,#26a69a);font-size:11px;line-height:1}
.dr-recent-chip--sel .dr-recent-check{color:var(--accent)}
.dr-date-pop{display:none;position:fixed;z-index:9400;width:min(420px,calc(100vw - 24px));box-sizing:border-box}
.dr-date-pop.open{display:block}
.dr-date-pop-panel{position:relative;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 32px rgba(0,0,0,.55);padding:10px}
.dr-date-pop-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.dr-date-pop-title{flex:1;text-align:center;font-size:14px;font-weight:700;color:var(--text);font-family:var(--font-mono)}
.dr-date-pop-nav{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;font-size:16px;line-height:1}
.dr-date-pop-nav:hover{border-color:var(--accent);color:var(--accent)}
/* v7.8-B3f：dr 日历对齐 wr/st 风格 — dows 4 列对齐 row 结构 */
.dr-dp-grid{width:100%}
.dr-dp-dows{display:grid;grid-template-columns:1fr minmax(0,5fr) 1fr;gap:4px;margin-bottom:6px;padding:0 6px}
.dr-dp-dows > span{text-align:center;font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.dr-dp-dows-mid5{display:flex;flex-direction:row;flex:1;min-width:0;border:1px solid transparent;border-radius:8px}
.dr-dp-dows-mid5 > span{flex:1;text-align:center;font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.dr-dp-rows{display:flex;flex-direction:column;gap:5px}
.dr-dp-row{display:grid;grid-template-columns:1fr minmax(0,5fr) 1fr;gap:4px;align-items:stretch;min-height:46px;padding:3px 6px;border-radius:8px}
.dr-dp-mid5{display:flex;flex-direction:row;flex:1;min-width:0;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:rgba(255,255,255,0.03)}
.dr-dp-row > .dr-dp-cell--wend{border:1px solid var(--border);background:rgba(255,255,255,0.02);border-radius:8px;opacity:0.55}
.dr-dp-mid5 .dr-dp-cell{flex:1;min-width:0;border-right:1px solid rgba(255,255,255,0.06)}
.dr-dp-mid5 .dr-dp-cell:last-child{border-right:none}
.dr-dp-cell{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:5px 0 3px;border:none;border-radius:0;background:transparent;color:var(--text);font-family:var(--font-mono);font-size:11px;cursor:pointer;transition:all .15s;min-height:44px}
.dr-dp-mid5 .dr-dp-cell:hover:not(:disabled){background:rgba(230,126,34,0.08)}
.dr-dp-row > .dr-dp-cell--wend:hover:not(:disabled){background:rgba(230,126,34,0.08);border-color:rgba(230,126,34,0.35);opacity:0.85}
.dr-dp-cell--muted{opacity:.32}
.dr-dp-cell--disabled{cursor:default;color:var(--text3);opacity:.4}
.dr-dp-cell--disabled:hover{background:transparent !important;border-color:var(--border) !important}
.dr-dp-cell--candidate{color:var(--text);font-weight:500}
/* reviewed / sel 选中态：在 mid5 内是色块，作为 wend 是描边覆盖 */
.dr-dp-mid5 .dr-dp-cell--reviewed{background:rgba(38,166,154,0.10)}
.dr-dp-row > .dr-dp-cell--wend.dr-dp-cell--reviewed{background:rgba(38,166,154,0.08);border-color:rgba(38,166,154,0.3);opacity:0.85}
.dr-dp-mid5 .dr-dp-cell--sel{background:rgba(230,126,34,0.20);box-shadow:0 0 0 1px rgba(230,126,34,0.55) inset}
.dr-dp-row > .dr-dp-cell--wend.dr-dp-cell--sel{background:rgba(230,126,34,0.18);border-color:rgba(230,126,34,0.6);box-shadow:0 0 0 1px rgba(230,126,34,0.25) inset;opacity:1}
.dr-dp-cell-num{line-height:1;font-size:12px}
.dr-dp-cell-pnl{font-size:8px;line-height:1;margin-top:2px;font-weight:600}
.dr-dp-cell-pnl.pos{color:var(--green,#26a69a)}
.dr-dp-cell-pnl.neg{color:var(--red,#ef5350)}
.dr-dp-cell-check{position:absolute;top:1px;right:3px;font-size:9px;color:var(--green,#26a69a);line-height:1}
.dr-dp-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;padding-top:8px;border-top:1px dashed var(--border)}
.dr-dp-legend{font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.dr-dp-lg{display:inline-block;width:10px;text-align:center}
.dr-dp-lg--reviewed{color:var(--green,#26a69a)}
.dr-dp-lg--candidate{color:var(--accent)}
.dr-dp-foot-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:4px 12px;font-size:11px;font-family:var(--font-mono);cursor:pointer}
.dr-dp-foot-btn:hover{border-color:var(--accent);color:var(--accent)}
.stats-tab-row{display:flex;align-items:center;justify-content:space-between}
.stats-tabs{display:flex}
.stats-tab{padding:9px 22px;font-size: 12px;font-family:var(--font-mono);cursor:pointer;color:var(--text3);border-bottom:2px solid transparent;transition:all .15s}
.stats-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.stats-tab:hover:not(.active){color:var(--text2)}
.stats-tpills{display:flex;gap:6px;padding:8px 0}
.stats-tpill{padding:6px 14px;border-radius:16px;font-size: 11px;font-family:var(--font-mono);font-weight:600;cursor:pointer;border:1px solid var(--border);color:var(--text2);background:rgba(255,255,255,0.03);transition:all .15s}
.stats-tpill.active{background:rgba(230,126,34,0.12);border-color:rgba(230,126,34,0.4);color:var(--accent)}
.stats-tpill:hover:not(.active){border-color:rgba(255,255,255,0.15);color:var(--text2)}
/* Statistics 子工具栏（Overview 专属：选周下拉 + Week/Month/Quarter/Year pill）。Calendar 时整行隐藏。 */
.stats-subbar-wrap{padding:6px 0 10px;border-top:1px solid var(--border)}
.stats-subbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.stats-subbar .stats-range-row{justify-content:flex-start;text-align:left;max-width:none;flex:0 1 auto}
.stats-subbar .stats-tpills{padding:0;flex:0 0 auto}
.stats-hdr--cal-active .stats-subbar-wrap{display:none}
/* Report：两个 pane（Weekly Report / Daily Deep Review），切 tab 时切 display。每个 pane 独立填充剩余高度 */
.report-pane{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;width:100%}
.report-pane:not(.active){display:none}
/* Report 顶栏：B3g #3 改成单行结构(Report 大标题 + tab 同行),复用 Statistics
   那套 .stats-hdr-title-row 的 flex 单行规则。删掉 <hr>,删掉 tab-wrap 独立行。
   padding 跟 .page-header 的 24px 同步,让 tab 左边界与下方 wr/dr 内层 page-header 对齐。 */
.report-hdr{flex-shrink:0;width:100%;background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px}
.report-hdr-row1{padding:14px 0 0}
/* Report 大标题 + tab 同一行,tab 底部贴齐(同 Statistics) */
.report-hdr-title-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.report-hdr-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.02em;white-space:nowrap}
/* tab 在 title 行内:贴齐底边(与下边框相接,形成 Statistics 同款下划线选中效果) */
.report-hdr-title-row .stats-tabs-inline{align-self:stretch}
.report-hdr-title-row .stats-tabs-inline .stats-tab{padding:8px 18px}
.stats-body{
  flex:1;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  padding:var(--st-pad,20px) 0;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  scrollbar-gutter:stable;
}
.stats-body > .stats-innerCol{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
}
.stats-body-inner{width:100%;display:flex;flex-direction:column;gap:var(--st-pad,20px);padding-bottom:var(--st-pad,20px);box-sizing:border-box}
/* Calendar: column centered in stats area (child width 100% of this box) */
.stats-body-inner.st-cal-active{align-items:center}
.stats-body-inner.st-cal-active .st-cal-zoom-outer{width:100%;max-width:100%}
/* Overview：外壳全宽；缩放写在 #st-ov-tuned（width=shell px + zoom）；正文字号与 Daily Log stat 卡对齐 */
.st-ov-zoom-shell{width:100%;min-height:0;box-sizing:border-box}
/* Overview 主列：纵向块间距与 .st-g2 列间距同一 token，避免「中间一道缝、上下紧贴」 */
.st-ov-tuned{display:flex;flex-direction:column;gap:var(--st-section-gap,var(--st-pad,20px));box-sizing:border-box;min-width:0;width:100%}
.st-stat-row{display:flex;flex-direction:column;gap:10px}
.st-stat-row--primary{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--st-section-gap,var(--st-pad,20px))}
.st-stat-row--secondary{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.st-scard{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:16px 18px;border-left:3px solid var(--border)}
.st-scard.g{border-left-color:var(--green)}.st-scard.r{border-left-color:var(--red)}.st-scard.o{border-left-color:var(--accent)}.st-scard.a{border-left-color:var(--accent)}.st-scard.t{border-left-color:var(--teacher)}.st-scard.streak-w{border-left-color:var(--green)}.st-scard.streak-l{border-left-color:var(--red)}
.st-scard--sm{padding:10px 14px}
.st-scard--sm .st-slbl{font-size:10px;margin-bottom:4px}
.st-scard--sm .st-sval{font-size:15px}
.st-scard--sm .st-ssub{font-size:10px;margin-top:2px}
.st-g2.st-g2--no-aspect>.st-sec{aspect-ratio:unset;min-height:0}
/* Overview KPI：与 Daily Log 右侧 .stat-lbl / .stat-val 对齐（11px / 18px） */
.st-slbl{font-size: 11px;color:var(--text2);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;margin-bottom:7px}
.st-sval{font-size: 18px;font-weight:700;font-family:var(--font-mono)}
.st-ssub{font-size: 11px;color:var(--text2);margin-top:4px;font-family:var(--font-mono)}
.st-pos{color:var(--green)}.st-neg{color:var(--red)}.st-acc{color:var(--accent)}.st-muted{color:var(--text2)}
.st-sec{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:20px 24px;display:flex;flex-direction:column}
.st-sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-shrink:0}
.st-sec-title{font-size: 12px;font-weight:700;color:var(--text);letter-spacing:1.5px;text-transform:uppercase;font-family:var(--font-mono)}
.st-sec-note{font-size: 12px;color:var(--text2);font-family:var(--font-mono)}
.st-g2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--st-section-gap,var(--st-pad,20px));align-items:stretch}
.st-g2>.st-sec{aspect-ratio:16/10;min-width:0;width:100%}
.st-dist-wrap{display:flex;align-items:stretch;flex:1;min-height:0;min-width:0;gap:12px;justify-content:space-between}
.st-dist-legend{flex:1 1 58%;display:flex;flex-direction:column;gap:10px;padding-right:0;justify-content:center;min-width:0;max-width:none}
.st-dist-legend.st-dist-legend--rows{justify-content:center;gap:10px;overflow-y:auto;min-height:0;padding-right:4px}
.st-ll-block{width:100%;box-sizing:border-box}
.st-ll-row--tog{cursor:pointer;border-radius:6px;padding:3px 4px;margin:0 -4px;transition:background .12s}
.st-ll-row--tog:hover{background:rgba(255,255,255,0.03)}
#st-ov-tuned .st-dist-legend--rows .st-drawer.st-drawer--res{margin:3px 0 3px 106px}
#st-ov-tuned .st-dist-legend--rows .st-ll-n{min-width:1.75rem;width:auto;text-align:right}
.st-ll-row{display:flex;align-items:center;gap:10px}
.st-ll-lbl{font-size: 12px;font-family:var(--font-mono);width:96px;text-align:right;flex-shrink:0}
.st-ll-bg{flex:1;min-width:150px;background:var(--bg3);border-radius:3px;height:9px;overflow:hidden}
.st-ll-fill{height:100%;border-radius:3px}
.st-ll-n{font-size: 13px;font-weight:700;font-family:var(--font-mono);width:20px;text-align:right;flex-shrink:0}
.st-dist-donut{flex:1 1 42%;min-width:0;min-height:0;position:relative;max-width:none;width:100%;display:flex;align-items:center;justify-content:flex-end;margin-left:0}
/* 饼图约为列宽的 75%，右对齐 → 与卡片右内边距的相对位置不变；图例列加宽后条形变长，gap 仍为 12px */
.st-donut-inner{width:75%;max-width:100%;max-height:100%;aspect-ratio:1;margin-left:auto;align-self:center;position:relative;min-height:0;min-width:0;flex-shrink:1}
.st-ov-bar-canvas-wrap{position:relative;flex:1;min-height:0;min-width:0;width:100%;align-self:stretch}
/* Bar+line 混合图：父级 CSS zoom 下 Chart 易低估宽度 → 用脚本按 offset 盒强制定宽；canvas 允许在 flex 内收缩 */
.st-ov-bar-canvas-wrap canvas#st-bar-c{min-width:0;min-height:0;display:block;vertical-align:top}
/* Statistics 图表 tooltip 改用 external → 挂 document.body（避免 #st-ov-tuned CSS zoom 导致整块发糊） */
body .chartjs-tooltip{opacity:1!important;z-index:10050!important}
.st-ov-ex-tooltip{
  position:fixed;z-index:10060;pointer-events:none;max-width:min(92vw,320px);
  padding:8px 11px;background:rgba(18,18,24,0.96);border:1px solid rgba(255,255,255,0.12);
  border-radius:8px;box-shadow:0 8px 28px rgba(0,0,0,0.45);color:var(--text);
  font-family:var(--font-mono),ui-monospace,monospace;line-height:1.35;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transform:translateZ(0);
}
.st-ov-ex-tooltip .st-ov-tt-title{font-weight:600;margin-bottom:4px;color:var(--text)}
.st-ov-ex-tooltip .st-ov-tt-line{display:flex;align-items:center;gap:8px;margin:2px 0}
.st-ov-ex-tooltip .st-ov-tt-swatch{flex-shrink:0;width:10px;height:10px;border-radius:2px;border:1px solid rgba(255,255,255,0.15)}
/* Error / Early Exit：列表在卡片内垂直居中（短列表上下留白一致；过长则内部滚动） */
.st-erows-bucket{flex:1;min-height:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}
.st-erows-bucket-inner{margin-block:auto;flex-shrink:0;width:100%}
/* Hide chart row until zoom+Chart layout settle (avoids big→small flash when switching Week/Month) */
.st-ov-charts-wrap.st-ov-charts-pending{visibility:hidden}
.st-erow{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .1s}
.st-erow:hover{background:rgba(255,255,255,0.03)}
.st-erow-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
/* Error/Exit 行：标签区可收缩；条形单独再缩（见 #st-ov-tuned） */
.st-erow .st-erow-name{flex:1 1 0;min-width:0;overflow:hidden;color:var(--text)}
.st-bar-wrap{background:var(--bg3);border-radius:3px;overflow:hidden}
.st-bar-fill{height:100%;border-radius:3px;transition:width .5s}
/* Overview Error / Early Exit：条形与 Settings 绿/橙标签一致（随主题变量） */
#st-ov-tuned .st-bar-fill--ov-green{background:color-mix(in srgb,var(--green) 62%,transparent)}
#st-ov-tuned .st-bar-fill--ov-orange{background:color-mix(in srgb,var(--accent) 62%,transparent)}
/* 数据列：固定宽度 + 居中 */
.st-erow-r{font-size: 12px;font-family:var(--font-mono);min-width:3.5rem;width:auto;max-width:11rem;text-align:center;flex-shrink:0;color:var(--text)}
.st-erow-pct{color:var(--text2);font-weight:600;font-size:11px;white-space:nowrap}
.st-erow-r.st-erow-r--exit{min-width:10.5rem;width:10.5rem}
.st-erow-avg{font-size: 12px;font-family:var(--font-mono);min-width:7rem;width:7rem;text-align:center;flex-shrink:0;color:var(--text2);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:0}
.st-erow-rbadge{font-size:10px;font-family:var(--font-mono);padding:1px 5px;border-radius:7px;border:1px solid rgba(148,163,184,0.25);font-weight:600;line-height:1.3;white-space:nowrap;letter-spacing:.2px}
.st-erow-rbadge.st-pos{color:var(--green);background:rgba(38,166,154,0.08);border-color:rgba(38,166,154,0.3)}
.st-erow-rbadge.st-neg{color:var(--red);background:rgba(239,83,80,0.08);border-color:rgba(239,83,80,0.3)}
.st-chev{font-size: 12px;color:var(--text2);width:14px;flex-shrink:0;transition:transform .2s}
.st-chev.open{transform:rotate(90deg)}
.st-drawer{display:none;flex-direction:column;gap:3px;margin:3px 0 3px 210px;padding:7px 10px;background:var(--bg3);border-radius:7px;border-left:2px solid rgba(255,255,255,0.08)}
.st-drawer.open{display:flex}
.st-drow{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-radius:5px;cursor:pointer;transition:background .1s}
.st-drow:hover{background:var(--bg2)}
.st-drow-d{font-size: 12px;font-family:var(--font-mono);color:var(--text2)}
.st-drow-p{font-size: 12px;font-family:var(--font-mono)}
.st-drow-a{font-size: 11px;color:var(--accent);font-family:var(--font-mono)}
.st-drow-t{color:var(--text2);font-family:var(--font-mono);font-weight:600;font-size:11px;letter-spacing:0.02em;margin-right:2px}
.st-hmc{border-radius:5px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:65px;transition:filter .15s;cursor:default}
.st-hmc:hover{filter:brightness(1.25)}
/* Overview only: +1px text vs global .st-* rules above (does not affect Calendar / Daily Log) */
#st-ov-tuned .st-slbl{font-size:12px}
#st-ov-tuned .st-sval{font-size:19px}
#st-ov-tuned .st-ssub{font-size:12px}
#st-ov-tuned .st-sec-title{font-size:13px}
#st-ov-tuned .st-sec-note{font-size:13px}
#st-ov-tuned .st-ll-lbl{font-size:13px}
#st-ov-tuned .st-ll-n{font-size:14px}
/* Error / Early Exit：与 Result 图例同阶 — 标签 13px、次数与 /avg 14px；条形缩短让出标签宽度；标签最多两行 */
#st-ov-tuned .st-erow .st-erow-name{
  font-size:13px;font-family:var(--font-mono);font-weight:400;line-height:1.3;
  white-space:normal;word-break:break-word;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;
}
#st-ov-tuned .st-erow .st-bar-wrap{
  flex:0 0 144px;width:144px;min-width:96px;max-width:176px;height:9px;align-self:center;
}
#st-ov-tuned .st-erow .st-erow-r,
#st-ov-tuned .st-erow .st-erow-avg{font-size:14px;font-weight:700;font-family:var(--font-mono)}
#st-ov-tuned .st-erow .st-erow-r.st-erow-r--exit{min-width:4.5rem;width:auto;max-width:12rem}
#st-ov-tuned .st-erow-pct{font-size:12px}
#st-ov-tuned .st-erow-avg.st-pos{color:var(--green)}
#st-ov-tuned .st-erow-avg.st-neg{color:var(--red)}
#st-ov-tuned .st-chev{font-size:13px}
#st-ov-tuned .st-drow-d{font-size:13px}
#st-ov-tuned .st-drow-p{font-size:13px}
#st-ov-tuned .st-drow-a{font-size:12px}
#st-ov-tuned .st-drow-t{font-size:13px}
#st-ov-tuned .st-filter-btn{font-size:12px}
#st-ov-tuned .st-g2>.st-sec{min-height:240px}
#st-ov-tuned .st-dist-donut{min-height:220px;max-height:min(380px,42vh)}
/* Calendar tuning host — vars set by stCalApplyTune() */
.st-cal-tuned{min-height:0;--cal-grid-gap:8px;--cal-main-gap:14px;--cal-main-minh:420px;--cal-cell-minh:118px;--cal-cell-pad-y:12px;--cal-cell-pad-x:10px;
  --cal-wd-fs:12px;--cal-num-fs:14px;--cal-pnl-fs:19px;--cal-info-fs:12px;--cal-nav-fs:14px;--cal-title-fs:15px;--cal-cvt-fs:12px;--cal-legend-fs:12px;
  --cal-leg-sq:10px;--cal-leg-dot:7px;--cal-wk-col-w:118px;--cal-wk-hdr-fs:11px;--cal-wk-hdr-minh:36px;--cal-wk-tag-fs:10px;--cal-wk-pnl-fs:17px;--cal-wk-sub-fs:11px;
  --cal-wk-card-minh:118px;--cal-wk-card-pad-y:12px;--cal-wk-card-pad-x:10px;--cal-wk-col-gap:8px;--cal-sec-pad-t:8px;--cal-sec-pad-x:12px;--cal-sec-pad-b:14px;--cal-cdot:6px;
  --cal-cdot-blue:6px;--cal-cdot-blue-gap:2px;--cal-cdot-blue-bot:4px;--cal-cdot-red-gap:3px;
  --cal-mm-title-fs:11px;--cal-mm-cell-h:14px;--cal-mm-cell-fs:7px;--cal-mm-grid-gap:2px;--cal-year-grid-gap:14px;--cal-mm-pad:14px}
.st-cal-sec{background:var(--bg2);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:var(--cal-sec-pad-t) var(--cal-sec-pad-x) var(--cal-sec-pad-b);box-shadow:0 8px 32px rgba(0,0,0,0.35)}
.st-cal-sec .st-sec-hdr{align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.st-cal-title{font-size:var(--cal-title-fs);font-weight:700;min-width:160px;text-align:center;font-family:var(--font-mono);color:var(--text)}
.st-cal-main-row{display:flex;align-items:stretch;gap:var(--cal-main-gap);min-height:var(--cal-main-minh)}
/* Month view: one grid so each calendar week row and the matching Week card share row height (avoids flex column stretching cards). */
.st-cal-sync-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr)) minmax(0,var(--cal-wk-col-w));
  column-gap:var(--cal-grid-gap);
  row-gap:var(--cal-grid-gap);
  width:100%;
  min-height:var(--cal-main-minh);
  align-items:stretch;
  box-sizing:border-box;
}
.st-cal-sync-grid .st-wk-band,
.st-cal-sync-grid .st-wk-card{
  margin-left:max(0px,calc(var(--cal-main-gap) - var(--cal-grid-gap)));
  box-sizing:border-box;
  min-width:0;
}
.st-cal-sync-grid .st-cal-wd{
  min-height:var(--cal-wk-hdr-minh);
  padding:0 4px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.st-cal-sync-grid .st-wk-hdr{
  margin-bottom:0;
  padding-bottom:0;
}
.st-cal-sync-grid .st-cal-cell,
.st-cal-sync-grid .st-cal-cell.empty{
  min-height:var(--cal-cell-minh);
  height:100%;
}
.st-cal-sync-grid .st-wk-card{
  flex:0 0 auto;
  min-height:var(--cal-wk-card-minh);
  height:100%;
  align-self:stretch;
}
.st-cal-legend{display:flex;flex-wrap:wrap;gap:12px 16px;font-size:var(--cal-legend-fs);font-family:var(--font-mono);color:var(--text2);font-weight:500}
.st-cal-legend span{display:inline-flex;align-items:center;gap:6px}
.st-cal-leg-sq{width:var(--cal-leg-sq);height:var(--cal-leg-sq);border-radius:3px;display:inline-block;flex-shrink:0}
.st-cal-leg-dot{width:var(--cal-leg-dot);height:var(--cal-leg-dot);border-radius:50%;display:inline-block;flex-shrink:0}
.st-cal-nav-btn{background:rgba(255,255,255,0.04);border:1px solid var(--border);color:var(--text);cursor:pointer;padding:6px 12px;border-radius:6px;font-size:var(--cal-nav-fs);font-weight:600;transition:all .15s}
.st-cal-nav-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(230,126,34,0.08)}
.st-cvt{padding:6px 14px;border-radius:14px;font-size:var(--cal-cvt-fs);font-family:var(--font-mono);font-weight:600;cursor:pointer;border:1px solid var(--border);color:var(--text2);background:rgba(255,255,255,0.04);transition:all .15s}
.st-cvt.active{background:rgba(230,126,34,0.12);border-color:rgba(230,126,34,0.4);color:var(--accent)}
.st-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--cal-grid-gap)}
.st-cal-wd{font-size:var(--cal-wd-fs);font-weight:700;font-family:var(--font-mono);color:var(--text);letter-spacing:0.04em;text-align:center;padding:10px 4px 8px;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,0.08)}
.st-cal-cell{border-radius:9px;padding:var(--cal-cell-pad-y) var(--cal-cell-pad-x);min-height:var(--cal-cell-minh);border:1px solid rgba(255,255,255,0.08);background:rgba(26,34,51,0.85);transition:filter .15s,box-shadow .15s}
.st-cal-cell.empty{background:transparent;border-color:transparent;min-height:var(--cal-cell-minh)}
.st-cal-cell.wk{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.06);opacity:1}
.st-cal-cell.wk .st-cal-num{color:var(--text3)}
.st-cal-cell.win-day{background:rgba(38,166,154,0.16);border-color:rgba(38,166,154,0.35)}
.st-cal-cell.loss-day{background:rgba(239,83,80,0.14);border-color:rgba(239,83,80,0.32)}
.st-cal-cell.today{border-color:rgba(230,126,34,0.75)!important;box-shadow:0 0 0 1px rgba(230,126,34,0.35)}
.st-cal-cell.clickable{cursor:pointer}.st-cal-cell.clickable:hover{filter:brightness(1.08);box-shadow:0 4px 16px rgba(0,0,0,0.2)}
/* 跨月日：整体降透明度灰化，但保留所有内容（日期、P&L、T·W、圆点） */
.st-cal-cell.out-of-month{opacity:0.5}
.st-cal-cell.out-of-month .st-cal-num{color:var(--text3)}
.st-cal-num{font-size:var(--cal-num-fs);font-weight:700;font-family:var(--font-mono);color:var(--text2);margin-bottom:8px;line-height:1.2}
.st-cal-pnl{font-size:var(--cal-pnl-fs);font-weight:700;font-family:var(--font-mono);line-height:1.15;letter-spacing:-0.02em}
.st-cal-info{font-size:var(--cal-info-fs);color:var(--text2);font-family:var(--font-mono);margin-top:8px;font-weight:500;opacity:0.95}
/* 格底：错误红点（左）与 Missing 蓝点（右）同一行；子块为 flex 行，避免 .st-cdot 块级竖排 */
.st-cdots-row{display:flex;flex-direction:row;align-items:center;width:100%;box-sizing:border-box;margin-top:var(--cal-cdot-blue-bot);min-height:0}
.st-cdots-row--split{justify-content:space-between}
.st-cdots-row--red-only{justify-content:flex-start}
.st-cdots-row--blue-only{justify-content:flex-end}
.st-cdots-left{display:flex;flex-direction:row;align-items:center;gap:var(--cal-cdot-red-gap);flex-wrap:nowrap;min-width:0}
.st-cdots-right{display:flex;flex-direction:row;align-items:center;gap:var(--cal-cdot-blue-gap);flex-wrap:nowrap;min-width:0}
.st-cdot{width:var(--cal-cdot);height:var(--cal-cdot);border-radius:50%;flex-shrink:0}
.st-cdot-err{background:var(--red);opacity:.55}
.st-cdots-right .st-cdot{width:var(--cal-cdot-blue);height:var(--cal-cdot-blue)}
.st-cdot-missed{background:var(--blue);opacity:.75}
.st-wk-col{display:flex;flex-direction:column;gap:var(--cal-wk-col-gap);width:var(--cal-wk-col-w);flex-shrink:0}
.st-wk-hdr{min-height:var(--cal-wk-hdr-minh);display:flex;align-items:center;justify-content:center;font-size:var(--cal-wk-hdr-fs);font-weight:700;font-family:var(--font-mono);color:var(--text);letter-spacing:0.12em;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,0.08);padding-bottom:4px;margin-bottom:2px}
.st-wk-card{flex:1;min-height:var(--cal-wk-card-minh);border-radius:9px;border:1px solid rgba(255,255,255,0.1);background:rgba(26,34,51,0.9);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:var(--cal-wk-card-pad-y) var(--cal-wk-card-pad-x)}
.st-wk-card.pos{background:rgba(38,166,154,0.14);border-color:rgba(38,166,154,0.32)}
.st-wk-card.neg{background:rgba(239,83,80,0.12);border-color:rgba(239,83,80,0.3)}
.st-wk-card.empty{background:rgba(255,255,255,0.03);border-color:rgba(255,255,255,0.06);opacity:1}
.st-wk-card.empty .st-wk-pnl{color:var(--text3)!important}
.st-wk-jump{cursor:pointer;transition:filter .15s,box-shadow .15s,border-color .15s}
.st-wk-jump:hover{filter:brightness(1.06);box-shadow:0 4px 14px rgba(0,0,0,0.22)}
.st-wk-tag{font-size:var(--cal-wk-tag-fs);font-weight:700;font-family:var(--font-mono);color:var(--text2);text-transform:uppercase;letter-spacing:0.06em}
.st-wk-pnl{font-size:var(--cal-wk-pnl-fs);font-weight:700;font-family:var(--font-mono);line-height:1.1}
.st-wk-sub{font-size:var(--cal-wk-sub-fs);font-family:var(--font-mono);color:var(--text2);font-weight:500}
.st-year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--cal-year-grid-gap)}
.st-month-mini{border-radius:10px;padding:var(--cal-mm-pad);background:rgba(26,34,51,0.75);border:1px solid rgba(255,255,255,0.1);cursor:pointer;transition:all .15s}
.st-month-mini:hover{border-color:rgba(255,255,255,0.22);background:rgba(26,34,51,0.95)}
.st-mm-title{font-size:var(--cal-mm-title-fs);font-family:var(--font-mono);color:var(--text);margin-bottom:8px;font-weight:700;letter-spacing:0.04em}
.st-mm-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--cal-mm-grid-gap)}
.st-mm-cell{border-radius:2px;height:var(--cal-mm-cell-h);display:flex;align-items:center;justify-content:center;font-size:var(--cal-mm-cell-fs);font-family:var(--font-mono);font-weight:700;overflow:hidden}
/* 日历：滑块 px 在 #st-cal-tuned；uiZoom 用 zoom 缩 #st-cal-tuned，并先设 width=shell 宽(px)，否则 width:100% 会占满一栏，左右「长度」看起来不变。 */
.st-cal-scale-pack{
  flex:1;
  min-height:0;
  width:100%;
  max-width:100%;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
}
.st-cal-zoom-outer{
  flex:1;
  display:flex;
  flex-direction:column;
  width:100%;
  min-height:0;
  box-sizing:border-box;
}
.st-cal-zoom-shell{
  flex:1;
  min-height:0;
  width:100%;
  max-width:100%;
  display:flex;
  flex-direction:column;
  align-items:stretch;
}
/* Calendar debug panel — fixed to viewport bottom so calendar stays visible above while tuning */
.st-cal-debug-wrap{
  display:none;
  position:fixed;
  left:max(12px, env(safe-area-inset-left, 0px));
  right:auto;
  bottom:0;
  width:min(calc(100vw - 24px),920px);
  max-height:min(82vh,760px);
  z-index:200;
  flex-direction:column;
  justify-content:flex-end;
  pointer-events:none;
}
.st-cal-debug-wrap .st-cal-debug-panel{pointer-events:auto}
.st-cal-debug-panel{
  background:var(--bg2);
  border:1px solid var(--border);
  border-bottom:none;
  border-radius:12px 12px 0 0;
  box-shadow:0 -12px 40px rgba(0,0,0,0.5);
  max-height:min(82vh,760px);
  display:flex;
  flex-direction:column;
  min-height:0;
  overflow:hidden;
}
.st-cal-debug-details{
  background:transparent;border:none;padding:0;margin:0;
  display:flex;flex-direction:column;
  flex:1;min-height:0;overflow:hidden;
  max-height:100%;
}
.st-cal-debug-sum{
  cursor:pointer;flex-shrink:0;
  font-size: 13px;font-weight:700;color:var(--accent);font-family:var(--font-mono);
  padding:12px 14px 8px;list-style-position:outside;
}
.st-cal-debug-hint{font-weight:400;color:var(--text3);font-size: 11px}
.st-cal-debug-inner{
  display:flex;flex-direction:column;gap:12px;
  flex:1 1 auto;min-height:0;
  max-height:min(calc(100vh - 140px),680px);
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  scrollbar-gutter:stable;
  padding:0 14px 14px;
}
body.st-cal-debug-visible #page-stats .stats-body{padding-bottom:min(52vh,580px);transition:padding-bottom .2s ease;box-sizing:border-box}
/* Admin-only: injected in Statistics calendar header (see stRenderCal) */
.st-cal-tune-inline{
  font-size: 11px;
  font-family:var(--font-mono);
  font-weight:600;
  padding:6px 10px;
  border-radius:8px;
  border:1px solid rgba(230,126,34,0.4);
  background:rgba(230,126,34,0.12);
  color:var(--accent);
  cursor:pointer;
  flex-shrink:0;
  white-space:nowrap;
  line-height:1.2;
}
.st-cal-tune-inline:hover,.st-cal-tune-inline:focus-visible{
  filter:brightness(1.12);
  outline:none;
}
.st-cal-debug-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.st-cal-dlbl{font-size: 12px;color:var(--text2);font-family:var(--font-mono);display:flex;align-items:center;gap:8px}
.st-cal-dsel{background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size: 12px;font-family:var(--font-mono)}
.st-cal-dbtn{background:transparent;border:1px solid var(--border);color:var(--text2);padding:6px 12px;border-radius:6px;font-size: 11px;font-family:var(--font-mono);cursor:pointer}
.st-cal-dbtn:hover{border-color:var(--accent);color:var(--accent)}
.st-cal-debug-fields{display:flex;flex-direction:column;gap:14px}
.st-cal-dgroup{border:1px solid rgba(255,255,255,0.08);border-radius:8px;padding:10px 12px 12px;background:rgba(0,0,0,0.18)}
.st-cal-dgroup-title{margin:0 0 4px;font-size: 12px;font-weight:700;color:var(--accent);font-family:var(--font-mono);letter-spacing:0.02em}
.st-cal-dgroup-hint{margin:0 0 10px;font-size: 10px;color:var(--text3);line-height:1.4;font-family:var(--font-mono)}
.st-cal-dgroup-rows{display:flex;flex-direction:column;gap:8px}
.st-cal-drow{display:flex;align-items:center;gap:10px;font-size: 11px;font-family:var(--font-mono);color:var(--text2)}
.st-cal-drow label{flex:1;min-width:0}
.st-cal-drow input[type=range]{flex:1;min-width:80px;accent-color:var(--accent)}
.st-cal-dval{min-width:36px;text-align:right;color:var(--text);font-weight:600}
.st-cal-export-lbl{font-size: 11px;color:var(--text3);font-family:var(--font-mono)}
.st-cal-export{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:10px;color:var(--text2);font-family:var(--font-mono);font-size: 10px;line-height:1.4;resize:vertical;min-height:120px}

/* Statistics Calendar Detail Panel - Single Row Layout */
.st-cal-detail-panel{display:none;margin-top:16px;background:var(--bg2);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;animation:stCalDetailSlideDown .25s ease}
.st-cal-detail-panel.open{display:block}
@keyframes stCalDetailSlideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

.st-cal-detail-header{display:flex;align-items:center;gap:16px;padding:12px 16px;
  background:var(--bg3);border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.st-cal-detail-header:hover{background:rgba(230,126,34,0.05)}
.st-cal-detail-title{font-size: 14px;font-weight:700;color:var(--text);font-family:var(--font-mono);white-space:nowrap}
.st-cal-detail-stats-inline{display:flex;align-items:center;gap:16px;flex:1}
.st-cal-detail-stat-inline{display:flex;align-items:baseline;gap:6px}
.st-cal-detail-stat-lbl{font-size: 9px;color:var(--text3);letter-spacing:0.5px;text-transform:uppercase;
  font-family:var(--font-mono)}
.st-cal-detail-stat-val{font-size: 15px;font-weight:700;font-family:var(--font-mono)}
.st-cal-detail-stat-val.pos{color:var(--green)}
.st-cal-detail-stat-val.neg{color:var(--red)}
.st-cal-detail-stat-val.acc{color:var(--accent)}
.st-cal-detail-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size: 18px;
  padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;
  border-radius:4px;transition:all .15s;flex-shrink:0;margin-left:auto}
.st-cal-detail-close:hover{background:var(--bg);color:var(--text)}

.st-cal-detail-scroll{max-height:320px;overflow-y:auto;padding:12px 16px}
.st-cal-detail-empty{text-align:center;padding:32px 12px;font-size: 12px;color:var(--text3)}

.st-cal-detail-trade{display:flex;flex-direction:column;gap:6px;padding:10px 12px;
  background:var(--bg3);border-radius:8px;border-left:3px solid var(--accent);margin-bottom:8px;
  cursor:pointer;transition:background .15s}
.st-cal-detail-trade:hover{background:rgba(230,126,34,0.08)}
.st-cal-detail-trade:last-child{margin-bottom:0}

.st-cal-detail-trade-row1{display:flex;align-items:center;gap:8px;font-size: 14px;font-family:var(--font-mono);color:var(--text)}
.st-cal-detail-trade-row2{display:flex;align-items:flex-start;gap:0;font-size: 12px;font-family:var(--font-mono);color:var(--text2)}

.st-cal-detail-trade-num{width:24px;height:24px;border-radius:6px;font-size: 11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);flex-shrink:0}
.st-cal-detail-trade-num.win{background:rgba(38,166,154,0.12);border:1px solid rgba(38,166,154,0.3);color:var(--green)}
.st-cal-detail-trade-num.loss{background:rgba(239,83,80,0.12);border:1px solid rgba(239,83,80,0.3);color:var(--red)}
.st-cal-detail-trade-num.neutral{background:rgba(230,126,34,0.12);border:1px solid rgba(230,126,34,0.25);color:var(--accent)}
.st-cal-detail-trade-num.missed-trade{background:rgba(155,109,255,0.12);border:1px solid rgba(155,109,255,0.3);color:var(--missed-trade)}

.st-cal-detail-trade-info{flex:1;min-width:0}

.st-cal-detail-trade-pnl{font-size: 15px;font-weight:700;font-family:var(--font-mono);flex-shrink:0;margin-left:auto}
.st-cal-detail-trade-pnl.pos{color:var(--green)}
.st-cal-detail-trade-pnl.neg{color:var(--red)}

.st-cal-detail-row2-left{flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding-right:8px}
.st-cal-detail-row2-right{flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding-left:8px;
  border-left:1px solid var(--border)}

.st-cal-detail-label{font-size: 10px;color:var(--text3);letter-spacing:0.5px;font-weight:600;margin-right:4px}

.st-cal-detail-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;
  font-size: 11px;font-weight:600;font-family:var(--font-mono);white-space:nowrap}
.st-cal-detail-tag.green{background:rgba(38,166,154,0.15);border:1px solid rgba(38,166,154,0.4);color:var(--green)}
.st-cal-detail-tag.red{background:rgba(239,83,80,0.15);border:1px solid rgba(239,83,80,0.4);color:var(--red)}
.st-cal-detail-tag.orange{background:rgba(230,126,34,0.15);border:1px solid rgba(230,126,34,0.4);color:var(--accent)}

.st-cal-detail-missed-badge{font-size: 11px;font-weight:600;font-family:var(--font-mono);color:var(--missed-trade);
  background:rgba(155,109,255,0.15);border:1px solid rgba(155,109,255,0.3);
  padding:2px 8px;border-radius:4px;flex-shrink:0;margin-left:auto}

/* ══════════════════════════════════════════════════════════
   FONT DEBUG PANEL
   ══════════════════════════════════════════════════════════ */
#font-debug-panel{position:fixed;bottom:20px;right:20px;width:320px;background:var(--bg2);
  border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,0.6);
  z-index:9999;display:none}
#font-debug-panel.open{display:block}
.font-debug-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;
  background:var(--bg3);border-bottom:1px solid var(--border);cursor:move}
.font-debug-title{font-size: 12px;font-weight:700;color:var(--text);font-family:var(--font-mono)}
.font-debug-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size: 16px;
  padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  border-radius:3px;transition:all .1s}
.font-debug-close:hover{background:var(--bg);color:var(--text)}
.font-debug-body{padding:12px;max-height:400px;overflow-y:auto}
.font-debug-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.font-debug-label{font-size: 10px;color:var(--text2);font-family:var(--font-mono);flex:1}
.font-debug-value{font-size: 11px;color:var(--accent);font-weight:700;font-family:var(--font-mono);
  min-width:40px;text-align:right;margin:0 8px}
.font-debug-input{flex:1;accent-color:var(--accent)}
.font-debug-toggle{position:fixed;bottom:20px;right:20px;width:40px;height:40px;
  background:var(--accent);border:none;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--bg);
  font-size: 18px;font-weight:700;box-shadow:0 4px 12px rgba(230,126,34,0.4);
  transition:all .2s;z-index:9998}
.font-debug-toggle:hover{transform:scale(1.1);box-shadow:0 6px 16px rgba(230,126,34,0.6)}
.font-debug-toggle.hidden{display:none}
.font-debug-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* ============================================================
   K-LINE CHART STYLES (Phase 1-2)
   ============================================================ */

/* View Mode Switch (Screenshot ↔ Chart) */
.view-mode-switch {
  display: flex;
  gap: 0;
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  flex-shrink: 0;
}

.mode-btn {
  flex: 1;
  padding: 6px 12px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text2);
  font-size: 12px;
  font-family: var(--font-mono);
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}

.mode-btn:first-child {
  border-radius: 6px 0 0 6px;
  border-right: none;
}

.mode-btn:last-child {
  border-radius: 0 6px 6px 0;
}

.mode-btn:hover {
  background: var(--bg3);
  color: var(--text);
}

.mode-btn.active {
  background: rgba(38, 166, 154, 0.10);
  color: var(--green);
  border-color: rgba(38, 166, 154, 0.35);
  font-weight: 600;
}

/* K-line Chart Container — 双图：主图 + 成交量，时间轴双向同步 */
#chart-container {
  background: var(--bg);
  border-radius: 8px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  box-sizing: border-box;
}

#kline-main,
#kline-volume {
  background: transparent;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

#kline-main {
  overflow: visible;
}

/* 下槽：独立成交量图容器（与主图时间轴同步） */
.kline-volume-slot {
  flex-shrink: 0;
  background: var(--bg);
}

/* K-line：DOM 箭头层（相对高低价偏移，pointer-events 不挡十字线） */
.kline-trade-arrows {
  position: absolute;
  inset: 0;
  z-index: 10050;
  overflow: visible;
  pointer-events: none;
}
/* 仅用 setMarkers 时此层恒空；全屏透明叠层会触发 GPU 与 canvas 二次合成，表现为中间糊、两侧相对清 */
.kline-trade-arrows:empty {
  display: none !important;
}

/* L/M：悬浮窗内美东时间（与 Entry 同行样式） */
.kline-marker-tooltip .kline-lm-tooltip-time {
  margin-top: 6px;
}

/* Teacher 腿标 L1/L2：与漏单圆点同坐标系，颜色同 --teacher */
.kline-teacher-leg-label {
  position: absolute;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  color: var(--teacher);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.75);
  white-space: nowrap;
  pointer-events: none;
}

.kline-missed-leg-label {
  position: absolute;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 11px;
  font-weight: 700;
  color: #9b59b6;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.75);
  white-space: nowrap;
  pointer-events: none;
}

.kline-entry-t1-label {
  position: absolute;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 10px;
  font-weight: 700;
  color: rgba(200, 200, 200, 0.88);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.75);
  white-space: nowrap;
  pointer-events: none;
}

.kline-arr {
  position: absolute;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.kline-arr-up {
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 13px solid #26a69a;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.35));
}

.kline-arr-down {
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 13px solid #ef5350;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.35));
}

.kline-arr-dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #9b59b6;
  border: 1.5px solid rgba(155, 89, 182, 0.85);
  box-sizing: border-box;
}

/* Debug: marker hit-test bands (?kline_hit_zones=1); SVG overlay above chart, below tooltip */
.kline-hit-zones-layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
  z-index: 9999;
}
#kline-hit-zones-svg:empty {
  display: none !important;
}

/* K-line：十字线对齐 bar 时显示；fixed 贴指针（与截图画框 pill 结构一致） */
.kline-marker-tooltip {
  position: fixed;
  /* ★ Phase 2 修复:从 100100 → 99000,避免越过登录 modal(z-index 100000) */
  z-index: 99000;
  max-width: 240px;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.35;
  pointer-events: none;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  border: 1px solid var(--border, #2b2b43);
  background: var(--bg-elevated, var(--bg));
  color: var(--text);
}

.kline-tt-shot .kline-tt-line1 {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.02em;
  color: var(--text);
}

.kline-tt-shot .kline-tt-line2 {
  margin-top: 6px;
}

.kline-marker-tooltip .ppill {
  position: static;
  left: auto;
  top: auto;
  cursor: default;
  font-size: 11px;
  padding: 2px 7px;
}

.kline-tt-pnl-row,
.kline-tt-entry-row {
  margin-top: 8px;
  padding-top: 6px;
  border-top: 1px solid var(--border, #2b2b43);
  font-size: 11px;
  font-weight: 600;
  font-family: var(--font-mono, ui-monospace, monospace);
  color: var(--text2);
}

.kline-tt-miss-sub {
  margin-top: 4px;
  font-size: 11px;
  font-family: var(--font-mono, ui-monospace, monospace);
  color: var(--text2);
}

.kline-tt-warn {
  margin-top: 4px;
  font-size: 11px;
  color: var(--warn, #f1c40f);
}

.kline-tt-sep {
  height: 1px;
  margin: 8px 0;
  background: var(--border, #2b2b43);
}

/* Data Source Modal Buttons */
#datasource-modal button:hover {
  background: var(--bg) !important;
  border-color: var(--accent) !important;
}

/* Ensure scale bar only shows in screenshot mode */
#screenshot-scale-bar {
  display: flex;
}

/* =============================================================
   K-line Chart 标签 — 顶部导航栏 + 左侧工具栏（v35 整合）
   ============================================================= */

/* Mode wrappers：勿 flex-shrink，否则左栏高度不足时 K 线区被挤扁裁切 */
#mode-screenshot-wrap { display: block; flex-shrink: 0; }
#mode-chart-wrap {
  display: none;
  flex-direction: column;
  flex-shrink: 0;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
#mode-chart-wrap.active { display: flex; }

/* =============================================
   顶部导航栏 — TradingView 风格
   ============================================= */
#kline-top-nav {
  height: 36px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 10px;
  gap: 0;
  flex-shrink: 0;
  font-family: var(--font-mono);
  font-size: 12px;
  user-select: none;
  overflow: hidden;
}

.ktn-symbol {
  color: var(--text);
  font-weight: bold;
  font-size: 13px;
  padding: 0 6px 0 4px;
  font-family: 'Helvetica Neue', Arial, sans-serif;
}
.ktn-tf {
  color: var(--text2);
  font-size: 11px;
  padding: 0 8px 0 2px;
  font-family: 'Helvetica Neue', Arial, sans-serif;
}
.ktn-sep {
  width: 1px;
  height: 18px;
  background: var(--border);
  margin: 0 8px;
  flex-shrink: 0;
}

/* OHLC 数值区 */
.ktn-ohlc {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px;
  flex-shrink: 0;
}
.ktn-ohlc-item {
  display: flex;
  gap: 3px;
}
.ktn-ohlc-label {
  color: var(--text2);
}
.ktn-ohlc-val {
  color: var(--text);
  min-width: 38px;
  font-variant-numeric: tabular-nums;
}

/* 指标图例区 */
.ktn-indicators {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  padding: 0 8px;
  min-width: 0;
  overflow: hidden;
}
.ktn-ind {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(128, 128, 128, 0.08);
  border: 1px solid transparent;
  cursor: default;
  font-size: 11px;
  flex-shrink: 0;
}
.ktn-ind:hover { border-color: var(--border); }
.ktn-ind-dot {
  width: 10px;
  height: 3px;
  border-radius: 2px;
  flex-shrink: 0;
}
.ktn-toggle {
  cursor: pointer;
  font-size: 11px;
  padding: 0 2px;
  border-radius: 3px;
  color: var(--text2);
  display: inline-flex;
  align-items: center;
}
.ktn-toggle:hover {
  background: var(--bg3);
  color: var(--text);
}
.ktn-ind-lbl {
  color: var(--text2);
}
.ktn-ind-val {
  color: var(--text);
  font-variant-numeric: tabular-nums;
  min-width: 40px;
}

/* =============================================
   工作区：左侧栏 + 图表
   ============================================= */
#kline-workspace {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 600px;
  background: var(--bg);
}

/* =============================================
   左侧工具栏 — 45px 宽，仅图标，TradingView 风格
   ============================================= */
#kline-sidebar {
  width: 45px;
  min-width: 45px;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 0 6px 0;
  gap: 2px;
  overflow: hidden;
  flex-shrink: 0;
}

.kline-tool-btn {
  width: 37px;
  height: 34px;
  background: none;
  border: none;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text2);
  transition: 0.15s;
  position: relative;
  padding: 0;
}
.kline-tool-btn:hover {
  background: var(--bg3);
  color: var(--text);
}
.kline-tool-btn.kline-tool-active {
  background: rgba(230, 126, 34, 0.15);
  color: var(--accent);
  border-left: 2px solid var(--accent);
  border-radius: 0 5px 5px 0;
}
.kline-sidebar-sep {
  width: 28px;
  height: 1px;
  background: var(--border);
  margin: 4px 0;
  flex-shrink: 0;
}

/* =============================================
   图表容器 — K线模式下的新布局适配
   ============================================= */
#mode-chart-wrap #chart-container {
  flex: 1;
  min-width: 0;
  position: relative;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  /* 覆盖原有的固定高度，改为灵活布局 */
}

/* K线绘图画布：在 #kline-main 内，低于 L1/L2 箭头层(10050)，高于 LWC 画布 */
#kline-draw-canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
  image-rendering: auto;
  z-index: 10040;
}
#kline-draw-canvas.kline-draw-active {
  pointer-events: auto;
  cursor: crosshair;
}

/* K线行内文字编辑器（绘图工具使用；父级为 #kline-main，需高于绘布/箭头层） */
.kline-inline-text-editor {
  position: absolute;
  z-index: 10100;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  min-width: 120px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.6);
}
.kline-text-drag-handle {
  height: 15px;
  background: var(--bg3);
  cursor: move;
  border-radius: 3px 3px 0 0;
  display: flex;
  align-items: center;
  padding: 0 6px;
  user-select: none;
}
.kline-text-drag-dots {
  color: var(--text3);
  font-size: 8px;
  letter-spacing: 4px;
  pointer-events: none;
}
.kline-inline-text-content {
  padding: 5px 8px;
  min-width: 100px;
  min-height: 22px;
  color: var(--text);
  font-size: 13px;
  font-family: 'Microsoft YaHei', sans-serif;
  outline: none;
  white-space: pre-wrap;
  word-break: break-word;
  cursor: text;
}

/* 浅色主题适配 — 确保在亮色模式下可见 */
html[data-theme="light"] .ktn-ind {
  background: rgba(0, 0, 0, 0.04);
}

/* Right-actions 图标化版本（统一 --text2 灰色，hover 轻微提亮） */
.right-actions--icons { gap: 2px; }
.right-actions--icons .ann-btn--icon {
  padding: 6px 8px;
  color: var(--text2);
  min-width: 0;
}
.right-actions--icons .ann-btn--icon:hover { color: var(--text); background: var(--bg3); }
.right-actions--icons .ann-btn--icon:disabled { opacity: 0.4; cursor: not-allowed; }
.right-actions--icons .ann-btn--icon:disabled:hover { background: transparent; color: var(--text2); }
.right-actions--icons .ann-btn--danger { color: var(--accent); }
.right-actions--icons .ann-btn--danger:hover { color: var(--accent); background: rgba(230,126,34,0.12); }
.right-actions--icons .ann-btn--danger:disabled:hover { color: var(--accent); background: transparent; }
.ann-btn-sep { width: 1px; height: 14px; background: var(--border); margin: 0 4px; align-self: center; flex-shrink: 0; }

/* ★ 导入交易: broker 下拉,跟 ann-btn 同色调 */
.import-broker-select {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text2);
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 3px 6px;
  cursor: pointer;
  outline: none;
  transition: all .15s;
  align-self: center;
  max-width: 130px;
}
.import-broker-select:hover { color: var(--text); background: var(--bg3); }
.import-broker-select:focus { border-color: var(--accent); }
.import-broker-select option { background: var(--bg2); color: var(--text); }
.import-broker-select option:disabled { color: var(--text3); }

/* ★ Clear 确认 Modal */
.tj-modal-overlay {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0, 0, 0, 0.55);
  display: flex; align-items: center; justify-content: center;
  animation: tjModalFadeIn .12s ease;
}
@keyframes tjModalFadeIn { from { opacity: 0; } to { opacity: 1; } }
.tj-modal-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 26px 18px;
  min-width: 360px; max-width: 440px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.6);
  font-family: inherit;
}
.tj-modal-title {
  font-size: 15px; color: var(--text); font-weight: 600;
  margin-bottom: 12px; letter-spacing: .3px;
}
.tj-modal-date {
  font-size: 12px; color: var(--text2); font-family: var(--font-mono);
  margin-bottom: 16px;
}
.tj-modal-date span { color: var(--text); font-weight: 600; }
.tj-modal-section { margin-bottom: 12px; }
.tj-modal-section-h {
  font-size: 11px; color: var(--text2); margin-bottom: 6px; letter-spacing: .5px;
}
.tj-modal-list {
  list-style: none; padding: 0; margin: 0;
  font-size: 11.5px; color: var(--text); line-height: 1.85;
}
.tj-modal-list li::before { content: "·  "; color: var(--text2); }
.tj-modal-warn {
  font-size: 11px; color: var(--red); margin: 14px 0 18px;
  font-family: var(--font-mono);
}
.tj-modal-actions {
  display: flex; justify-content: flex-end; gap: 10px;
}
.tj-modal-btn {
  padding: 7px 18px; border: 1px solid var(--border); border-radius: 6px;
  background: transparent; color: var(--text2);
  font-size: 12px; font-family: var(--font-mono); cursor: pointer;
  transition: all .12s;
}
.tj-modal-btn:hover { color: var(--text); background: var(--bg3); }
.tj-modal-btn--danger { border-color: var(--red); color: var(--red); }
.tj-modal-btn--danger:hover { background: var(--red); color: white; }
/* 2026-05-24: 昵称补全 modal 用 — primary 按钮 + input + msg */
.tj-modal-btn--primary { border-color: var(--accent); color: var(--accent); }
.tj-modal-btn--primary:hover { background: var(--accent); color: white; }
.tj-modal-input {
  width: 100%; box-sizing: border-box;
  padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg); color: var(--text);
  font-size: 13px; font-family: inherit;
}
.tj-modal-input:focus { outline: none; border-color: var(--accent); }
.tj-modal-msg {
  font-size: 11px; color: var(--text2); min-height: 14px; margin-top: 6px;
  font-family: var(--font-mono);
}
.tj-modal-msg--err { color: var(--red); }
.tj-modal-msg--ok  { color: var(--green); }

/* K线顶部栏右端缩放控件 — 灰色质感，与 Save 按钮一致 */
.ktn-zoom {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  padding-left: 8px;
  flex-shrink: 0;
}
.ktn-zoom-lbl {
  color: var(--text2);
  font-size: 11px;
  padding-right: 2px;
}
.ktn-zoom-btn {
  padding: 3px 8px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text2);
  font-size: 11px;
  font-family: var(--font-mono);
  border-radius: 4px;
  cursor: pointer;
  transition: 0.12s;
  line-height: 1.2;
}
.ktn-zoom-btn:hover { background: var(--bg3); color: var(--text); }
.ktn-zoom-btn.ktn-zoom-active {
  background: var(--bg3);
  color: var(--text);
  border-color: var(--border);
}

/* ── Missing Setup Analysis ─────────────────────────────────────── */
.st-miss-row:hover{
  background:rgba(155,109,255,0.08);
}
html[data-theme="light"] .st-miss-row:hover{
  background:rgba(124,77,255,0.06);
}

/* ── Teacher section collapsible (与每张 trade-card 折叠风格一致) ───────── */
#teacher-comparison.teacher-collapsed .teacher-controls{display:none !important}
#teacher-comparison.teacher-collapsed .teacher-body{display:none}

/* ── Month / Quarter / Year picker (复用 .st-week-pop 容器 + 自有网格) ───────── */
.st-mqy-pop{width:min(360px,calc(100vw - 24px))}
.st-mqp-grid{width:100%}
.st-mqp-cells{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.st-mqp-cells--q{grid-template-columns:repeat(2,1fr)}
.st-mqp-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 6px;min-height:54px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}
.st-mqp-cell:hover{background:rgba(230,126,34,0.08);border-color:rgba(230,126,34,0.35)}
.st-mqp-cell--sel{background:rgba(230,126,34,0.22);color:var(--accent);border-color:rgba(230,126,34,0.55);font-weight:600;box-shadow:0 0 0 1px rgba(230,126,34,0.2) inset}
.st-mqp-cell--sel:hover{background:rgba(230,126,34,0.28)}
.st-mqp-cell-lbl{line-height:1}
.st-mqp-cell-sub{font-size:9px;color:var(--text3);line-height:1}
.st-mqp-foot{display:flex;justify-content:flex-end;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.st-mqp-foot-btn{background:transparent;border:1px solid var(--border);color:var(--text2);font-family:var(--font-mono);font-size:11px;padding:4px 10px;border-radius:6px;cursor:pointer;transition:all .15s}
.st-mqp-foot-btn:hover{border-color:var(--accent);color:var(--accent)}

/* v7.5.1 Bug 7: nav 项右上角红点徽标（Persona 待审核 V/复发提示等） */
.nav-item{position:relative}
.nav-item-badge{display:inline-block;min-width:14px;height:14px;padding:0 4px;margin-left:6px;background:var(--accent);color:var(--bg);border-radius:8px;font-size:9px;line-height:14px;text-align:center;font-weight:700;vertical-align:middle;font-family:var(--font-mono)}

/* ════════════════════════════════════════════════════════════════════════
 * §§ REPLAY_PAGE_CSS §§ — 整合自 index_v31_v17.html 的 replay 样式
 * 所有选择器都用 `#page-replay` 前缀作用域,防止污染主程序
 * 所有原 replay 的 ID `xxx` 已改为 `rp-xxx`
 * 颜色用硬编码深色值(replay 原版风格,跟主程序的 CSS 变量略有不同)
 * ════════════════════════════════════════════════════════════════════════ */

/* 注意:右下角的 #font-debug-toggle / #tj-ec-fab 是用户的调试工具,保持原位
   这两个 position:fixed 浮在右下角的元素会轻微遮住 Reset Trades,这是可接受的 */

/* page-replay 容器:占满 main 区域,内部自带工作区布局 */
/* 字体:跟原版 replay 一致,避免主程序 PingFang SC 细体污染 */
/* 注意:不在这里写 display:flex —— 会覆盖 .page { display:none } 全局规则导致永久显示 */
/* 让主程序的 .page.active { display:flex } 来控制可见性,我们只在 .active 时补强 */
#page-replay {
  padding:0; overflow:hidden; position:relative;
  font-family:'Microsoft YaHei',sans-serif;
  color:#eee;
}
/* .active 时确保 flex 链路完整(主程序的 .page.active { display:flex } 已经够了,
   这里只补 flex-direction:column 和 min-height:0,因为某些浏览器对 flex item 默认 row) */
#page-replay.active {
  flex-direction:column;
  min-height:0;
}
#page-replay #rp-root { width:100%; flex:1; display:flex; flex-direction:column; position:relative; min-height:0; }

/* ── 工作区整体布局 ── */
#page-replay #rp-workspace {
  display:flex; flex-direction:row; flex:1; min-height:0; min-width:0; width:100%;
  background:#131722;
}

/* ── 左侧工具栏 (45px,只放图标) ── */
#page-replay #rp-sidebar {
  width:45px; min-width:45px; background:#1e222d; border-right:1px solid #2a2e39;
  display:flex; flex-direction:column; align-items:center; padding:8px 0 6px 0;
  gap:2px; z-index:30; overflow:hidden;
}
#page-replay .rp-tool-icon-btn {
  width:37px; height:34px; background:none; border:none; border-radius:5px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#787b86; transition:0.15s; position:relative;
}
#page-replay .rp-tool-icon-btn:hover { background:#2a2e39; color:#d1d4dc; }
#page-replay .rp-tool-icon-btn.rp-tool-active {
  background:rgba(230,126,34,0.15); color:#e67e22;
  border-left:2px solid #e67e22; border-radius:0 5px 5px 0;
}
#page-replay .rp-sidebar-sep { width:28px; height:1px; background:#2a2e39; margin:4px 0; }
#page-replay .rp-sidebar-spacer { flex-grow:1; }

/* ── 中间主区域 ── */
#page-replay #rp-main-area {
  flex-grow:1; flex-shrink:1; display:flex; flex-direction:column;
  position:relative; background:transparent; z-index:1;
  min-width:0; min-height:0; max-height:100%;
}

/* ── 顶部导航栏 (TradingView 风格) ── */
#page-replay #rp-top-nav {
  height:36px; background:#1e222d; border-bottom:1px solid #2a2e39;
  display:flex; align-items:center; padding:0 10px; gap:0;
  z-index:50; flex-shrink:0;
  font-family:Consolas,'Courier New',monospace; font-size:12px; user-select:none;
}
#page-replay .rp-nav-sep { width:1px; height:18px; background:#2a2e39; margin:0 8px; }
#page-replay .rp-nav-tf { color:#787b86; font-size:11px; padding:0 8px 0 2px; font-family:'Helvetica Neue',Arial,sans-serif; }
#page-replay .rp-nav-ohlc { display:flex; align-items:center; gap:8px; padding:0 4px; }
#page-replay .rp-nav-ohlc-item { display:flex; gap:3px; }
#page-replay .rp-nav-ohlc-label { color:#aab4c0; }
#page-replay .rp-nav-ohlc-val { color:#d1d4dc; }
#page-replay .rp-nav-indicators { display:flex; align-items:center; gap:6px; flex:1; padding:0 8px; }
#page-replay .rp-nav-ind {
  display:flex; align-items:center; gap:4px; padding:2px 6px; border-radius:3px;
  background:rgba(30,34,45,0.6); border:1px solid transparent; cursor:default; font-size:13px;
}
#page-replay .rp-nav-ind:hover { border-color:#2a2e39; }
#page-replay .rp-nav-ind-dot { width:10px; height:3px; border-radius:2px; flex-shrink:0; }
#page-replay .rp-nav-toggle { cursor:pointer; font-size:11px; padding:0 2px; border-radius:3px; }
#page-replay .rp-nav-toggle:hover { background:#434651; }
#page-replay .rp-nav-ind-val { color:#d1d4dc; }
#page-replay .rp-nav-right { display:flex; align-items:center; gap:4px; margin-left:auto; }
#page-replay .rp-nav-btn {
  display:flex; align-items:center; gap:4px; padding:4px 8px; border:none; background:none;
  color:#787b86; border-radius:4px; cursor:pointer; font-size:11px; transition:0.15s;
}
#page-replay .rp-nav-btn:hover { background:#2a2e39; color:#d1d4dc; }
#page-replay .rp-nav-btn svg { flex-shrink:0; }

/* Symbol 下拉 */
#page-replay #rp-symbol-dropdown { position:relative; display:inline-block; }
#page-replay #rp-symbol-btn {
  background:none; border:none; color:#e67e22; font-weight:bold; font-size:14px;
  letter-spacing:1px; padding:4px 10px; border-radius:4px; cursor:pointer;
  font-family:Consolas,'Courier New',monospace; display:flex; align-items:center; gap:4px; transition:.15s;
}
#page-replay #rp-symbol-btn:hover { background:rgba(230,126,34,0.15); }
#page-replay #rp-symbol-menu {
  display:none; position:absolute; top:calc(100% + 4px); left:0;
  background:#1a1f2e; border:1px solid rgba(230,126,34,0.45); border-radius:6px;
  padding:4px 0; z-index:999; min-width:90px; box-shadow:0 4px 16px rgba(0,0,0,0.6);
}
#page-replay .rp-sym-opt {
  padding:5px 14px; font-size:12px; font-family:Consolas,'Courier New',monospace;
  color:#d1d4dc; cursor:pointer; letter-spacing:1px; transition:.12s;
}
#page-replay .rp-sym-opt:hover { background:rgba(230,126,34,0.15); color:#e67e22; }
#page-replay .rp-sym-opt.active { color:#e67e22; font-weight:bold; }

/* 日期显示按钮 (右栏顶部,点击打开小日历) */
#page-replay #rp-sidebar-date-wrap {
  display:flex; align-items:center; justify-content:center;
  padding:2px 8px 4px; border-bottom:1px solid #2a2e39; margin-bottom:4px;
}
#page-replay #rp-nav-date-display {
  color:#e67e22; font-size:20px; font-weight:bold; padding:1px 10px; cursor:pointer;
  border-radius:4px; transition:.15s; font-family:Consolas,'Courier New',monospace; letter-spacing:1px;
  white-space:nowrap; line-height:1.15;
}
#page-replay #rp-nav-date-display:hover { background:rgba(230,126,34,0.15); }

/* ── 画布 / 图表 容器 ── */
#page-replay #rp-canvas-container {
  flex-grow:1; position:relative; overflow:hidden; background:transparent;
  display:flex; justify-content:center; align-items:center; z-index:10;
  min-height:0; min-width:0;
}
#page-replay #rp-draw-canvas {
  position:absolute; image-rendering:auto; pointer-events:none; z-index:20; top:0; left:0;
}
#page-replay #rp-chart-wrapper {
  display:flex; flex-direction:column; width:100%; height:100%;
  position:absolute; top:0; left:0; z-index:10; background:#131722;
}
#page-replay #rp-chart-container { flex:3; position:relative; min-height:0; cursor:crosshair; }
#page-replay #rp-vol-container { flex:1; position:relative; min-height:0; cursor:crosshair; }
#page-replay #rp-pane-separator { height:1px; background:#434651; z-index:5; pointer-events:none; }
#page-replay #rp-current-date-display {
  position:absolute; top:20px; left:20px; padding:8px 15px;
  font-size:12px; font-weight:bold; color:#fff; z-index:50;
  border-left:3px solid #e67e22; border-radius:6px; display:none;
  text-shadow:1px 1px 5px rgba(0,0,0,0.8);
  background:rgba(20,20,20,0.7);
}

/* ════════ 2026-05-22 重构: K线下方 [时间轴 + 横控制栏 + 拖手 + Pro Feed 卡片墙] ════════ */

/* ── ① 时间轴进度条 #rp-timeline-bar ── */
#page-replay #rp-timeline-bar {
  flex-shrink:0; height:28px; background:#1e222d;
  border-top:1px solid #2a2e39;
  display:flex; align-items:center; padding:0 12px; gap:10px;
  z-index:30; user-select:none;
}
#page-replay .rp-tl-side {
  font-size:10px; color:#787b86; font-family:Consolas,'Courier New',monospace;
  letter-spacing:1px; flex-shrink:0; min-width:36px; text-align:center;
}
#page-replay .rp-tl-track {
  position:relative; flex:1; height:18px;
  display:flex; align-items:center;
}
/* 底色 track */
#page-replay .rp-tl-track::before {
  content:''; position:absolute; left:0; right:0; top:50%;
  transform:translateY(-50%);
  height:4px; border-radius:2px;
  background:#252a36;
  pointer-events:none;
}
/* 已播放着色 */
#page-replay .rp-tl-fill {
  position:absolute; left:0; top:50%;
  transform:translateY(-50%);
  height:4px; width:0%; border-radius:2px;
  background:linear-gradient(90deg, rgba(230,126,34,0.6), #e67e22);
  pointer-events:none; transition:width .08s linear;
  z-index:1;
}
/* 整点 tick 竖线 */
#page-replay .rp-tl-tick {
  position:absolute; top:50%; transform:translate(-50%, -50%);
  width:1px; height:10px; background:rgba(120,123,134,0.45);
  pointer-events:none; z-index:2;
}
/* 实际 input range:盖在 track 上,完全透明只接事件 */
#page-replay .rp-tl-input {
  position:absolute; inset:0; width:100%; height:100%;
  margin:0; padding:0; background:transparent; appearance:none;
  cursor:pointer; z-index:3;
}
#page-replay .rp-tl-input::-webkit-slider-runnable-track {
  height:18px; background:transparent;
}
#page-replay .rp-tl-input::-moz-range-track {
  height:18px; background:transparent; border:none;
}
#page-replay .rp-tl-input::-webkit-slider-thumb {
  appearance:none; width:14px; height:14px; border-radius:50%;
  background:#e67e22; border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(230,126,34,0.5), 0 2px 4px rgba(0,0,0,0.4);
  cursor:grab; margin-top:0;
}
#page-replay .rp-tl-input:active::-webkit-slider-thumb { cursor:grabbing; }
#page-replay .rp-tl-input::-moz-range-thumb {
  width:14px; height:14px; border-radius:50%;
  background:#e67e22; border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(230,126,34,0.5), 0 2px 4px rgba(0,0,0,0.4);
  cursor:grab;
}
#page-replay .rp-tl-input:focus { outline:none; }
/* hover/drag tooltip */
#page-replay .rp-tl-tooltip {
  position:absolute; top:-22px; transform:translateX(-50%);
  background:#1a1f2e; border:1px solid rgba(230,126,34,0.5);
  border-radius:4px; padding:2px 6px;
  font-size:10px; color:#e67e22;
  font-family:Consolas,'Courier New',monospace; letter-spacing:1px;
  opacity:0; transition:opacity .12s; pointer-events:none;
  z-index:60; white-space:nowrap;  /* 高于 K 线区任何 overlay(top-nav 是 50) */
}

/* ── ② 横向控制栏 #rp-control-bar ── */
#page-replay #rp-control-bar {
  flex-shrink:0; height:36px; background:#1e222d;
  border-top:1px solid #2a2e39;
  display:flex; align-items:center; justify-content:center; padding:0 14px; gap:10px;
  z-index:30;
}
#page-replay #rp-control-bar #rp-jump-anchor { line-height:1; }
#page-replay #rp-control-bar #rp-time-display {
  font-size:18px; font-weight:bold; color:#f39c12;
  font-family:Consolas,'Courier New',monospace; letter-spacing:2px;
  cursor:pointer; padding:0 8px;
  border:1px solid rgba(243,156,18,0.3); border-radius:4px;
  background:rgba(243,156,18,0.06);
  transition:.15s; line-height:1.2;
  /* 6.5迭代①: 与「上一根/下一根/开始」统一 26px 高 + flex 居中, 让控件栏所有框底边对齐(原 ~27.6px 偏高致按钮显偏上) */
  height:26px; box-sizing:border-box; display:inline-flex; align-items:center; justify-content:center;
}
#page-replay #rp-control-bar #rp-time-display:hover {
  border-color:rgba(243,156,18,0.55); background:rgba(243,156,18,0.12);
}
#page-replay #rp-control-bar .rp-ctrl-btn {
  background:#2a2e39; color:#d1d4dc; border:1px solid #434651;
  padding:3px 14px 0; border-radius:4px; cursor:pointer;
  font-size:12px; font-weight:bold; transition:0.15s;
  /* 6.5迭代①: flex 居中后文字仍因字体度量偏上 → 手动 padding-top:3px(底 0)把文字往下压 ~1.5px, 上下留白对称(框仍 26px 不动) */
  line-height:1;
  display:inline-flex; align-items:center; justify-content:center; height:26px; box-sizing:border-box;
}
#page-replay #rp-control-bar .rp-ctrl-btn:hover {
  background:#434651; color:#e67e22; border-color:#e67e22;
}
#page-replay #rp-control-bar .rp-ctrl-sep {
  width:1px; height:20px; background:#2a2e39; margin:0 4px;
}
/* 2026-06-02: 播放粒度拨片(替代旧 Anim 按钮) — 圆钮左右拨, 左=分钟级手动 右=秒级动画连播 */
#page-replay #rp-control-bar #rp-grain-switch {
  position:relative; height:26px; flex-shrink:0; cursor:pointer;
  display:inline-flex; align-items:center; gap:0;
  padding:2px; border-radius:14px; border:1px solid rgba(120,123,134,0.4);
  background:rgba(30,34,45,0.7); user-select:none;
  transition:border-color 0.15s, background 0.15s;
}
#page-replay #rp-control-bar #rp-grain-switch .rp-grain-opt {
  position:relative; z-index:2; min-width:38px; text-align:center;
  font-size:11px; font-weight:bold; letter-spacing:0.5px; line-height:22px;
  color:#787b86; transition:color 0.15s;
}
/* 圆钮(滑块): 默认盖在"分钟"(左), 秒级时滑到右 */
#page-replay #rp-control-bar #rp-grain-switch .rp-grain-knob {
  position:absolute; z-index:1; top:2px; left:2px; bottom:2px; width:calc(50% - 2px);
  border-radius:12px; background:rgba(120,123,134,0.28);
  transition:left 0.18s ease, background 0.18s;
}
/* 分钟级(默认): 左侧 opt 高亮 */
#page-replay #rp-control-bar #rp-grain-switch .rp-grain-opt:first-child { color:#d1d4dc; }
/* 秒级(rp-grain-on): 钮滑到右, 右侧 opt 橙色高亮, 左侧变暗 */
#page-replay #rp-control-bar #rp-grain-switch.rp-grain-on .rp-grain-knob {
  left:50%; background:rgba(230,126,34,0.30);
}
#page-replay #rp-control-bar #rp-grain-switch.rp-grain-on .rp-grain-opt:first-child { color:#787b86; }
#page-replay #rp-control-bar #rp-grain-switch.rp-grain-on .rp-grain-opt:last-child { color:#e67e22; }
#page-replay #rp-control-bar #rp-grain-switch:hover { border-color:#e67e22; }
#page-replay #rp-control-bar #rp-btn-autoplay {
  /* #6 (2026-06-04): 字号/内距对齐 .rp-ctrl-btn(「下一根」), 保留青色高亮区分「播放」 */
  width:auto; height:26px; padding:3px 14px 0;
  border-radius:4px; border:1px solid rgba(38,166,154,0.4);
  background:rgba(38,166,154,0.07); color:#26a69a; font-size:12px; font-weight:bold;
  cursor:pointer; transition:background 0.15s, border-color 0.15s; letter-spacing:0.5px;
  display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
  line-height:1;
}
#page-replay #rp-control-bar #rp-btn-autoplay.rp-auto-on {
  background:rgba(230,126,34,0.22); border-color:#e67e22; color:#e67e22;
}
#page-replay #rp-control-bar #rp-btn-autoplay:disabled {
  opacity:0.3; cursor:default; pointer-events:none;
}

/* ── ③ 拖手 #rp-bottom-splitter ── */
#page-replay #rp-bottom-splitter {
  flex-shrink:0; height:6px; background:#1e222d;
  cursor:ns-resize; position:relative; z-index:30;
  display:flex; align-items:center; justify-content:center;
  border-top:1px solid #2a2e39; border-bottom:1px solid #2a2e39;
  transition:background .15s;
}
#page-replay #rp-bottom-splitter:hover { background:#2a2e39; }
#page-replay .rp-splitter-handle {
  width:42px; height:2px; border-radius:2px;
  background:rgba(120,123,134,0.5);
  transition:background .15s;
}
#page-replay #rp-bottom-splitter:hover .rp-splitter-handle {
  background:#e67e22;
}

/* ── ④ Pro Feed 横向卡片墙 #rp-bottom-panel / #rp-pro-feed ── */
#page-replay #rp-bottom-panel {
  /* 2026-05-22: 旧 3 列 (165→120) 改成单一 Pro Feed 容器,高度可由拖手调节
     初始 120px = 默认值;拖手会改 height 内联样式。 */
  min-height:120px; height:120px; background:#1e222d;
  display:flex; flex-direction:column; z-index:30; flex-shrink:0;
  overflow:hidden;
}
#page-replay #rp-pro-feed {
  flex:1; display:flex; flex-direction:column; min-height:0; min-width:0;
  background:rgba(30,34,45,0.7); padding:6px 12px 8px;
}
#page-replay .rp-pf-header {
  flex-shrink:0; display:flex; align-items:center; justify-content:space-between;
  margin-bottom:5px;
}
#page-replay .rp-pf-title {
  font-size:11px; font-weight:bold; color:#e74c3c;
  text-transform:uppercase; letter-spacing:1px;
}
#page-replay .rp-pf-count {
  font-size:10px; color:#787b86;
  font-family:Consolas,'Courier New',monospace; letter-spacing:1px;
}
#page-replay .rp-pf-scroll {
  flex:1; min-height:0; min-width:0;
  display:flex; gap:8px;
  overflow-x:auto; overflow-y:hidden;
  align-items:stretch;
  /* 两侧对称 padding */
  padding:2px 2px 8px;
  scrollbar-width:thin; scrollbar-color:#434651 transparent;
}
#page-replay .rp-pf-scroll::-webkit-scrollbar { height:8px; }
#page-replay .rp-pf-scroll::-webkit-scrollbar-track { background:transparent; }
#page-replay .rp-pf-scroll::-webkit-scrollbar-thumb {
  background:#434651; border-radius:4px;
}
#page-replay .rp-pf-scroll::-webkit-scrollbar-thumb:hover { background:#e67e22; }

#page-replay .rp-pf-empty {
  flex:1; display:flex; align-items:center; justify-content:center;
  color:#555; font-size:11px; font-style:italic;
  letter-spacing:0.5px;
}

#page-replay .rp-pf-card {
  flex:0 0 280px; min-width:280px; max-width:280px;
  position:relative;
  background:#131722; border:1px solid #2a2e39; border-radius:5px;
  padding:8px 10px 8px;
  display:flex; flex-direction:column; gap:4px;
  transition:border-color .15s, background .15s, box-shadow .15s;
  overflow:hidden;
}
#page-replay .rp-pf-card:hover {
  border-color:rgba(230,126,34,0.4); background:#171c2a;
}
/* 2026-05-23：header 行（label chip 左，time 右），body 文本另起一行 */
#page-replay .rp-pf-card-header {
  display:flex; justify-content:space-between; align-items:center;
  gap:8px; min-height:16px;
}
#page-replay .rp-pf-card-label-spacer {
  /* 无 label 时占位，让 time 靠右 */
  display:inline-block; min-width:1px; flex:1;
}
#page-replay .rp-pf-card-time {
  font-size:11px; color:#aab4c0; opacity:1;
  font-family:Consolas,'Courier New',monospace; letter-spacing:1px;
  pointer-events:none; flex-shrink:0;
}
#page-replay .rp-pf-card-body {
  flex:1; min-height:0; color:#d1d4dc;
  font-size:13px; line-height:1.55;
  overflow:hidden; word-wrap:break-word; white-space:pre-wrap;
}

/* 2026-05-22:最新卡(最右那张)特殊高亮 — 由 rpRefreshProFeed 给最后一张加 .rp-pf-card-latest */
#page-replay .rp-pf-card.rp-pf-card-latest {
  border-color:#e67e22;
  background:linear-gradient(180deg, rgba(230,126,34,0.10) 0%, rgba(30,34,45,0.7) 100%);
  box-shadow:0 0 0 1px rgba(230,126,34,0.35), 0 2px 12px rgba(230,126,34,0.15);
}
#page-replay .rp-pf-card.rp-pf-card-latest:hover {
  background:linear-gradient(180deg, rgba(230,126,34,0.16) 0%, rgba(30,34,45,0.8) 100%);
}
#page-replay .rp-pf-card.rp-pf-card-latest .rp-pf-card-time {
  color:#e67e22; opacity:1; font-weight:bold;
}
/* "NEW" 角标:左上角小亮点 + 文字 — 2026-05-23 移到 header 内，跟 label 同一行 */
#page-replay .rp-pf-card.rp-pf-card-latest .rp-pf-card-header::before {
  content:'● LATEST';
  font-size:8px; color:#e67e22; font-weight:bold;
  font-family:Consolas,'Courier New',monospace; letter-spacing:1.5px;
  pointer-events:none; margin-right:4px; flex-shrink:0;
}

/* ---- 2026-05-23 中央化：C 列标签 chip（Analysis Card 时间旁 + Pro Feed 卡内）---- */
#page-replay .rp-tag-chip {
  display:inline-block; padding:1px 7px;
  font-size:10px; font-weight:600; letter-spacing:.5px;
  font-family:Consolas,'Courier New',monospace;
  background:rgba(230,126,34,0.18); color:#e67e22;
  border-radius:10px; line-height:1.5;
  white-space:nowrap; max-width:160px;
  overflow:hidden; text-overflow:ellipsis;
}
#page-replay .rp-pf-card-label {
  /* Pro Feed header 行内的 label chip — 跟 time 同一排，label 左 time 右 */
  flex:0 1 auto; vertical-align:middle;
}

/* 隐藏态 (rpToggleNotesPanel "Notes" 按钮切换):整个 Pro Feed 内子元素隐藏 */
#page-replay #rp-bottom-panel.rp-notes-hidden #rp-pro-feed > * { display:none; }

/* 2026-05-23: T1 锁态 — 跟 hidden 不同, panel 整体收 0 高度 + splitter 也隐藏(T1 不能拖回来)
   `.rp-notes-locked` 由 rpApplyNotesPermission() 加到 #rp-bottom-panel 上 */
#page-replay #rp-bottom-panel.rp-notes-locked {
  height:0 !important; min-height:0 !important; padding:0 !important;
  border-top:none !important; overflow:hidden !important;
}
#page-replay #rp-bottom-panel.rp-notes-locked > * { display:none !important; }
/* splitter 是 #rp-bottom-panel 的兄弟节点,T1 锁态时让它也消失 */
body.tier-1 #page-replay #rp-bottom-splitter,
body.is-banned #page-replay #rp-bottom-splitter { display:none !important; }

/* ── 右侧交易面板 ── */
#page-replay #rp-trading-sidebar {
  width:240px; min-width:240px; background:#1e222d; border-left:1px solid #2a2e39;
  display:flex; flex-direction:column; padding:10px;  /* 2026-05-22 修(§12-1): 35px bottom-padding 是 sidebar 时代余量, 顶栏改版后让 Reset Trades 贴底 → 改对称 10px */
  gap:8px; z-index:30; overflow-y:auto;
  min-height:0; max-height:100%;
  flex-shrink:0;
}
#page-replay .rp-pos-cell {
  background:#131722; padding:7px 8px; border-radius:4px; border:1px solid #2a2e39;
}
#page-replay .rp-pos-cell-label { font-size:9px; color:#9aa7b4; text-transform:uppercase; letter-spacing:0.5px; }
#page-replay .rp-pos-cell-val { font-weight:bold; font-size:12px; color:#d1d4dc; margin-top:2px; font-family:Consolas,'Courier New',monospace; }
#page-replay .rp-pnl-row {
  display:flex; justify-content:space-between; align-items:center;
  background:#131722; border:1px solid #2a2e39; border-radius:4px; padding:6px 10px;
}
#page-replay .rp-pnl-row-label { font-size:11px; color:#9aa7b4; text-transform:uppercase; }
#page-replay .rp-pnl-row-val { font-weight:bold; font-size:12px; color:#d1d4dc; font-family:Consolas,'Courier New',monospace; }
#page-replay .rp-trade-btn {
  background:transparent; border:1px solid; padding:8px 4px; border-radius:5px;
  cursor:pointer; font-weight:bold; transition:0.15s; font-size:13px; font-family:inherit;
}
#page-replay .rp-btn-buy { color:#26a69a; border-color:rgba(38,166,154,0.5); }
#page-replay .rp-btn-buy:hover { background:rgba(38,166,154,0.15); border-color:#26a69a; }
#page-replay .rp-btn-sell { color:#ef5350; border-color:rgba(239,83,80,0.5); }
#page-replay .rp-btn-sell:hover { background:rgba(239,83,80,0.15); border-color:#ef5350; }
#page-replay .rp-btn-flat { color:#9aa0a6; border-color:#434651; }
#page-replay .rp-btn-flat:hover { background:rgba(120,123,134,0.18); color:#d1d4dc; border-color:#787b86; }
#page-replay .rp-trade-input {
  background:#131722; border:1px solid #434651; color:#eee;
  padding:6px; border-radius:4px; font-family:Consolas,'Courier New',monospace; font-size:14px;
  text-align:center; width:100%;
  /* 2026-05-22:用户已经在两侧给了 [−] [+] 按钮,内置 spinner 白色突兀,隐藏掉 */
  -moz-appearance:textfield;       /* Firefox */
  appearance:textfield;
}
#page-replay .rp-trade-input::-webkit-outer-spin-button,
#page-replay .rp-trade-input::-webkit-inner-spin-button {
  -webkit-appearance:none; margin:0;       /* Chrome/Safari/Edge */
}
#page-replay .rp-qty-btn {
  background:#2a2e39; color:#d1d4dc; border:1px solid #434651;
  width:28px; height:28px; border-radius:4px; cursor:pointer;
  font-size:16px; font-weight:bold; flex-shrink:0; line-height:1;
  display:flex; align-items:center; justify-content:center;
}
#page-replay .rp-qty-btn:hover { background:#434651; }
#page-replay #rp-trade-log-container tr { border-bottom:1px solid #2a2e39; }
#page-replay #rp-trade-log-container td { padding:3px 4px; color:#d1d4dc; font-family:Consolas,'Courier New',monospace; }
#page-replay .rp-btn-reset-text {
  background:none; border:1px solid rgba(239,83,80,0.4); color:#ef5350;
  padding:5px 10px; border-radius:4px; cursor:pointer;
  font-size:11px; width:100%; transition:0.15s;
}
#page-replay .rp-btn-reset-text:hover { background:rgba(239,83,80,0.1); border-color:#ef5350; }

/* 挂单行 */
#page-replay .rp-pending-row {
  display:flex; align-items:center; gap:4px;
  padding:4px 6px; border-radius:4px; margin-bottom:3px;
  background:#0d1017; border:1px solid #2a2e39; font-size:10px; font-family:Consolas,'Courier New',monospace;
}
#page-replay .rp-pending-row .rp-pr-side { font-weight:bold; flex-shrink:0; width:14px; }
#page-replay .rp-pending-row .rp-pr-info { flex:1; color:#8b949e; }
#page-replay .rp-pending-row .rp-pr-del {
  background:none; border:none; color:#444; cursor:pointer;
  font-size:13px; padding:0 2px; flex-shrink:0; transition:.12s;
}
#page-replay .rp-pending-row .rp-pr-del:hover { color:#ef5350; }
#page-replay .rp-trade-btn.rp-chart-selecting {
  outline:2px solid #f39c12; outline-offset:2px;
  animation:rpChartSelectPulse 1s ease-in-out infinite;
}
@keyframes rpChartSelectPulse { 0%,100%{opacity:1} 50%{opacity:.6} }

/* Vol chip */
#page-replay #rp-vol-src-bar {
  display:none; position:absolute; left:6px; top:4px; z-index:5;
  gap:3px; font-size:9px; font-family:Consolas,'Courier New',monospace;
  pointer-events:auto; user-select:none;
}
#page-replay .rp-vol-chip {
  padding:1px 6px; border-radius:3px; cursor:pointer; font-size:9px;
  border:1px solid #555; color:#bbb; background:rgba(0,0,0,0.15);
  line-height:1.4; transition:.12s; letter-spacing:0.5px;
}
#page-replay .rp-vol-chip.active { background:#e67e22; color:#fff; border-color:#e67e22; }
#page-replay .rp-vol-chip:not(.active):hover { border-color:#e67e22; color:#e67e22; }

/* ── 分析卡片 (跟随 K 线浮动) ── */
#page-replay #rp-analysis-card {
  position:absolute; z-index:80; width:220px;
  background:rgba(18,22,34,0.96); border:1px solid rgba(155,89,182,0.35);
  border-radius:9px; padding:10px 13px 12px;
  box-shadow:0 4px 24px rgba(0,0,0,0.7);
  pointer-events:none; transition:opacity .15s; display:none;
}
#page-replay #rp-analysis-card.rp-visible { display:block; }
#page-replay #rp-analysis-card button { pointer-events:auto; }
#page-replay .rp-ac-time {
  font-size:11px; font-family:Consolas,'Courier New',monospace; letter-spacing:1.5px;
  color:#9b59b6; font-weight:bold; margin-bottom:7px;
}
#page-replay .rp-ac-section { margin-bottom:7px; }
#page-replay .rp-ac-section:last-child { margin-bottom:0; }
#page-replay .rp-ac-label {
  font-size:8px; letter-spacing:2px; text-transform:uppercase;
  margin-bottom:3px; font-family:Consolas,'Courier New',monospace;
}
#page-replay .rp-ac-label.rp-me  { color:#3498db; }
#page-replay .rp-ac-label.rp-pro { color:#e74c3c; }
#page-replay .rp-ac-text { font-size:11px; line-height:1.55; color:#c8d0dc; }
#page-replay .rp-ac-divider { height:1px; background:rgba(255,255,255,0.06); margin:7px 0; }

#page-replay #rp-ac-toggle-btn {
  /* 2026-06-02 修: 改为 .rp-topleft-btns 内的 flex item(原 absolute top:8/left:8 与容器重叠已移除) */
  flex-shrink:0;
  background:rgba(18,22,34,0.85); border:1px solid #2a2e39;
  border-radius:5px; padding:4px 8px;
  color:#787b86; font-size:10px; font-family:Consolas,'Courier New',monospace;
  cursor:pointer; display:flex; align-items:center; gap:5px;
  transition:.15s; letter-spacing:0.5px;
}
#page-replay #rp-ac-toggle-btn:hover { border-color:#9b59b6; color:#9b59b6; }
#page-replay #rp-ac-toggle-btn.rp-active {
  border-color:#9b59b6; color:#9b59b6; background:rgba(155,89,182,0.12);
}
/* 2026-06-02: 「分析卡」功能暂时对所有用户隐藏(后续可能再开放 → 删掉下面这一条即可恢复按钮) */
#page-replay #rp-ac-toggle-btn { display:none !important; }
/* 2026-05-23 中央化恢复：原 hidden override 已删，rp-visible 控制权交还 JS */

/* 2026-05-23 修: K 线左上角按钮组 — flex 容器固定 left:8px,
   子按钮自然排布 + 固定 8px 间距,Notes 始终紧跟 Full Day 不会重叠 */
#page-replay .rp-topleft-btns {
  position:absolute; top:8px; left:8px; z-index:90;
  display:flex; gap:8px; align-items:center;
}
/* 6.5迭代②: 「全天」「分析」两钮统一为 SVG 图标(时钟/眼睛, 同 11px stroke 风格)
   → 图标几何居中、天然在同一水平线; 再固定等高(28)+等宽(72)+内容居中 → 两框完全一致 */
#page-replay #rp-view-toggle-btn,
#page-replay #rp-notes-toggle-btn {
  height:28px; width:72px; box-sizing:border-box; justify-content:center;
}

#page-replay #rp-view-toggle-btn {
  /* #4 (2026-06-04): 加大加亮(10→12px / 灰→亮 / 底色加深 / 描边更清), 让左上角控件一眼可见 */
  background:rgba(18,22,34,0.95); border:1px solid #3a4150; border-radius:5px;
  padding:5px 12px; color:#cfd4dc; font-size:12px; font-weight:bold; font-family:Consolas,'Courier New',monospace;
  cursor:pointer; display:flex; align-items:center; gap:5px;
  transition:.15s; letter-spacing:0.5px;
  white-space:nowrap;  /* 防止 "↺ Default" 之类窄宽度文字断行 */
}
#page-replay #rp-view-toggle-btn:hover { border-color:#e67e22; color:#e67e22; }

/* 2026-05-23: Full Day = 纯浏览模式 — 所有回放/交易交互禁用 + 灰显
   - #rp-timeline-bar  进度条整条禁用
   - #rp-control-bar   控制栏(Prev/Next/Anim/Play/Speed/时间显示)整体禁用
   - .rp-fullday-disabled-zone  右侧 sidebar 内的 Qty/Market/Chart Order/Pending 区
   - .rp-fullday-disabled-btn   Reset Trades(在 zone 外但要一起禁)
   - K 线可缩放/拖拽(LWC 自带,不动它)
   - 状态数字面板 / Trade Log 表格 / Pro Feed / Notes / Save 等只读区:不动 */
#page-replay.rp-fullday-mode #rp-timeline-bar,
#page-replay.rp-fullday-mode #rp-control-bar,
#page-replay.rp-fullday-mode .rp-fullday-disabled-zone,
#page-replay.rp-fullday-mode .rp-fullday-disabled-btn {
  pointer-events:none !important;
  opacity:0.42; filter:grayscale(0.6);
  transition:opacity .2s, filter .2s;
}
/* Full Day 下,禁用区里的 input 即便被 Tab 聚焦也不显示光标 / 选中(纯视觉防御) */
#page-replay.rp-fullday-mode .rp-fullday-disabled-zone input,
#page-replay.rp-fullday-mode .rp-fullday-disabled-zone input:focus {
  caret-color:transparent !important;
  user-select:none !important;
  outline:none !important;
}
/* Full Day 模式下,Full Day 按钮本身不要灰(它要保持可点切回) */
#page-replay.rp-fullday-mode #rp-view-toggle-btn {
  opacity:1; filter:none; pointer-events:auto;
}

/* Full Day 模式横幅(写在 sidebar 顶部, sidebar-date 之下) — 非禁用元素,正常显示
   由 rpToggleFullDayView 控制 display 显隐(不用 CSS :checked 之类的,JS 更稳) */
#page-replay #rp-fullday-banner {
  display:none;
  flex-shrink:0;
  margin:0;
  padding:7px 12px;
  background:rgba(243,156,18,0.12);
  border:none;
  border-bottom:1px solid rgba(243,156,18,0.35);
  font-size:12px; color:#f39c12; letter-spacing:1px;
  font-family:Consolas,'Courier New',monospace;
  text-align:center; line-height:1.4;
}
#page-replay.rp-fullday-mode #rp-fullday-banner { display:block; }

#page-replay #rp-notes-toggle-btn {
  /* 2026-05-23 修: 改成 flex item,由父容器 .rp-topleft-btns 控制位置和间距 */
  /* #4 (2026-06-04): 加大加亮, 与「全天」钮一致 */
  background:rgba(18,22,34,0.95); border:1px solid #3a4150; border-radius:5px;
  padding:5px 12px; color:#cfd4dc; font-size:12px; font-weight:bold; font-family:Consolas,'Courier New',monospace;
  cursor:pointer; display:flex; align-items:center; gap:5px;
  transition:.15s; letter-spacing:0.5px;
  white-space:nowrap;
}
#page-replay #rp-notes-toggle-btn:hover { border-color:#3498db; color:#3498db; }
#page-replay #rp-notes-toggle-btn.rp-active {
  border-color:#3498db; color:#3498db; background:rgba(52,152,219,0.12);
}
/* 2026-06-03 (#3): 锁态由"灰 dim"改"低调柔金"提示升级 — 不发光不闪, 仅与旁边中性钮区分;
   鼠标小手仍显示(点击弹升级提示). 原灰色方案见 git 历史(2026-05-23). */
#page-replay #rp-notes-toggle-btn.rp-locked {
  color:#d8b563 !important; border-color:rgba(216,181,99,0.45) !important;
  background:rgba(216,181,99,0.08) !important; opacity:0.95;
}
#page-replay #rp-notes-toggle-btn.rp-locked:hover {
  color:#e8c884 !important; border-color:rgba(216,181,99,0.70) !important;
}
#page-replay #rp-notes-toggle-btn .rp-notes-lock {
  font-size:9px; margin-left:2px; opacity:0.85;
}
/* 笔记隐藏态规则已合并到 2026-05-22 重构段(行 ~2670),旧 #rp-box-me / #rp-box-pro 选择器已废除 */

/* ── 右侧 Tab 切换 ── */
#page-replay .rp-ts-tab-bar { display:flex; border-bottom:1px solid #2a2e39; margin-bottom:10px; }
#page-replay .rp-ts-tab-btn {
  flex:1; padding:6px 0; background:none; border:none; border-bottom:2px solid transparent;
  color:#787b86; font-size:11px; font-family:Consolas,'Courier New',monospace; letter-spacing:1px;
  cursor:pointer; text-transform:uppercase; transition:.15s; margin-bottom:-1px;
}
#page-replay .rp-ts-tab-btn.active { color:#e67e22; border-bottom-color:#e67e22; }
#page-replay .rp-ts-tab-btn:hover:not(.active) { color:#d1d4dc; }
#page-replay .rp-ts-tab-pane { display:none; flex-direction:column; gap:0; flex:1; min-height:0; }
#page-replay .rp-ts-tab-pane.active { display:flex; }

/* 2026-05-23: Divergence 整块隐藏(后台保留,要恢复时把下面 5 条规则删掉即可)
   - tab 按钮 / tab pane / Analysis Card 内的 ⇅ Diff 按钮(Card 已整块隐藏,这条是冗余防御) */
#page-replay #rp-ts-tab-diverg,
#page-replay #rp-ts-pane-diverg { display:none !important; }
/* Divergence 隐藏后 Trades 是唯一 tab → tab-bar 视觉冗余 → 一起隐藏让 sidebar 顶部干净 */
#page-replay .rp-ts-tab-bar { display:none !important; }

/* ── 分歧点 ── */
#page-replay #rp-diverg-list-wrap {
  flex:1; background:#131722; border:1px solid #2a2e39; border-radius:4px;
  overflow-y:auto; min-height:0;
}
#page-replay .rp-diverg-row {
  display:flex; flex-direction:column; gap:3px;
  padding:8px 10px; border-bottom:1px solid #2a2e39;
  cursor:pointer; transition:.12s;
}
#page-replay .rp-diverg-row:last-child { border-bottom:none; }
#page-replay .rp-diverg-row:hover { background:rgba(155,89,182,0.12); }
#page-replay .rp-diverg-row-top { display:flex; align-items:center; gap:8px; }
#page-replay .rp-diverg-time {
  font-size:12px; font-weight:bold; color:#9b59b6;
  font-family:Consolas,'Courier New',monospace; flex-shrink:0;
}
#page-replay .rp-diverg-desc { font-size:11px; color:#d1d4dc; line-height:1.4; flex:1; }
#page-replay .rp-diverg-views { font-size:10px; color:#787b86; line-height:1.5; }
#page-replay .rp-diverg-me  { color:#3498db; }
#page-replay .rp-diverg-pro { color:#e74c3c; }
#page-replay #rp-diverg-empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; color:#444; font-size:11px; letter-spacing:1px; font-family:Consolas,'Courier New',monospace; gap:6px;
}
#page-replay .rp-diverg-del-btn {
  background:none; border:none; color:#444; font-size:15px;
  cursor:pointer; padding:0 2px; line-height:1; flex-shrink:0;
  transition:color .12s;
}
#page-replay .rp-diverg-del-btn:hover { color:#ef5350; }

/* 分歧点 K 线 Tooltip(浮动在最顶层,故意不放 page-replay 作用域)*/
#rp-diverg-tooltip {
  display:none; position:fixed; z-index:9999;
  background:#1a1f2e; border:1px solid rgba(155,89,182,0.6);
  border-radius:8px; padding:10px 14px; min-width:220px; max-width:300px;
  box-shadow:0 4px 20px rgba(0,0,0,0.7); pointer-events:none;
}
#rp-diverg-tooltip .rp-dt-time { font-size:11px; color:#9b59b6; font-family:Consolas,'Courier New',monospace; letter-spacing:1px; margin-bottom:5px; font-weight:bold; }
#rp-diverg-tooltip .rp-dt-desc { font-size:12px; color:#e6edf3; margin-bottom:7px; line-height:1.4; }
#rp-diverg-tooltip .rp-dt-divider { height:1px; background:#2a2e39; margin:6px 0; }
#rp-diverg-tooltip .rp-dt-label { font-size:9px; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:2px; }
#rp-diverg-tooltip .rp-dt-text { font-size:11px; line-height:1.5; }

/* 分歧点输入弹窗(浮动) */
#rp-diverg-modal {
  display:none; position:fixed; left:0; top:0; width:100%; height:100%;
  background:rgba(0,0,0,0.8); z-index:10000;
  align-items:center; justify-content:center;
}
#rp-diverg-modal .rp-modal-box { background:#1e222d; width:360px; padding:28px; border-radius:10px; border:1px solid #2a2e39; }
#rp-diverg-modal h3 { color:#e67e22; margin-top:0; margin-bottom:18px; font-size:16px; border-bottom:1px solid #2a2e39; padding-bottom:12px; }
#rp-diverg-modal textarea {
  width:100%; padding:8px 10px; border-radius:5px; border:1px solid #434651;
  background:#131722; color:#eee; font-size:13px; font-family:Consolas,'Courier New',monospace;
  resize:vertical; min-height:70px; outline:none; margin-bottom:10px; line-height:1.5;
}
#rp-diverg-modal textarea:focus { border-color:#9b59b6; }
#rp-diverg-modal .rp-diverg-preview-box {
  background:#0d1017; border:1px solid #2a2e39; border-radius:4px;
  padding:8px 10px; margin-bottom:12px; font-size:11px; line-height:1.7;
}
#rp-diverg-modal .rp-diverg-preview-label {
  font-size:9px; letter-spacing:1.5px; color:#555;
  text-transform:uppercase; margin-bottom:3px;
}
#rp-diverg-modal .rp-modal-row { display:flex; gap:10px; margin-top:6px; }
#rp-diverg-modal .rp-modal-btn {
  flex:1; padding:9px; border:none; border-radius:5px;
  cursor:pointer; font-weight:bold; font-size:13px; transition:0.2s;
}
#rp-diverg-modal .rp-modal-btn-primary { background:linear-gradient(135deg,#27ae60,#2ecc71); color:white; }
#rp-diverg-modal .rp-modal-btn-cancel { background:#434651; color:#d1d4dc; }
#rp-diverg-modal .rp-modal-label { font-size:11px; color:#787b86; margin-bottom:4px; text-transform:uppercase; }

/* Jump 弹窗 (Quick chips + 滚轮选时) */
#page-replay .rp-jchip {
  background:rgba(255,255,255,0.04); border:1px solid #2a2e39; color:#8b949e;
  font-size:10px; padding:4px 0; border-radius:4px; cursor:pointer;
  font-family:Consolas,'Courier New',monospace; transition:.12s; flex:1; text-align:center;
}
#page-replay .rp-jchip:hover, #page-replay .rp-jchip.active {
  border-color:#e67e22; color:#e67e22; background:rgba(230,126,34,0.12);
}
#page-replay .rp-jwi {
  display:flex; align-items:center; justify-content:center;
  font-family:Consolas,'Courier New',monospace; font-weight:bold; height:32px; font-size:13px;
  color:#252b3b; line-height:1;
}
#page-replay .rp-jwi.rp-near { color:#5a6070; font-size:16px; }
#page-replay .rp-jwi.rp-sel { color:#f0e8dc; font-size:24px; line-height:1; }
#page-replay #rp-jwH::before, #page-replay #rp-jwM::before {
  content:''; position:absolute; left:0; right:0; top:50%;
  transform:translateY(-50%); height:32px;
  background:rgba(230,126,34,0.08);
  border-top:1px solid rgba(230,126,34,0.38); border-bottom:1px solid rgba(230,126,34,0.38);
  pointer-events:none; z-index:2;
}
#page-replay #rp-jwH::after, #page-replay #rp-jwM::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom,#0d1017 0%,transparent 25%,transparent 75%,#0d1017 100%);
  pointer-events:none; z-index:3;
}

/* 行内文字编辑器 */
#page-replay .rp-inline-text-editor {
  position:absolute; z-index:200;
  background:rgba(19,23,34,0.96); border:1px solid #434651; border-radius:4px;
  min-width:120px; box-shadow:0 2px 10px rgba(0,0,0,0.6);
}
#page-replay .rp-text-drag-handle {
  height:15px; background:#2a2e39; cursor:move; border-radius:3px 3px 0 0;
  display:flex; align-items:center; padding:0 6px; user-select:none;
}
#page-replay .rp-text-drag-dots {
  color:#787b86; font-size:8px; letter-spacing:4px; pointer-events:none;
}
#page-replay .rp-inline-text-content {
  padding:5px 8px; min-width:100px; min-height:22px;
  color:#eee; font-size:13px; font-family:'Microsoft YaHei',sans-serif;
  outline:none; white-space:pre-wrap; word-break:break-word; cursor:text;
}

/* 加载遮罩(进 replay 页面时短暂显示) */
#page-replay #rp-fetch-overlay {
  display:none; position:absolute; inset:0; background:rgba(13,17,23,.88);
  z-index:9998; flex-direction:column; align-items:center; justify-content:center; gap:14px;
}
#page-replay #rp-fetch-overlay.rp-show { display:flex; }
#page-replay .rp-fetch-ring {
  width:44px; height:44px; border:3px solid #30363d; border-top-color:#e67e22;
  border-radius:50%; animation:rpSpin .8s linear infinite;
}
@keyframes rpSpin { to { transform:rotate(360deg); } }
#page-replay .rp-fetch-msg { color:#8b949e; font-size:13px; letter-spacing:1px; font-family:Consolas,'Courier New',monospace; }

/* 右上角小日历弹窗(B2 新加) */
#rp-cal-popup {
  background:#1a1f2e; border:1px solid rgba(230,126,34,0.4); border-radius:8px;
  padding:10px; z-index:9999; min-width:240px;
  box-shadow:0 4px 24px rgba(0,0,0,0.7);
  /* 整体放大 10%,原点设右上角(popup 右对齐) */
  transform: scale(1.1);
  transform-origin: top right;
}



/* ============================================================
   LOGIN MODAL — Cyan brand modal (.lm-* namespace)
   ============================================================ */
#login-modal {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100000;
  align-items: center; justify-content: center;
  font-family: 'Space Grotesk', 'PingFang SC', 'Microsoft YaHei', system-ui, sans-serif;
}
#login-modal .lm-backdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(7, 9, 15, 0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
#login-modal .lm-card {
  position: relative;
  width: 380px; max-width: calc(100vw - 32px);
  margin: 0;
  padding: 0;
  background: #161c2d;
  border: 1px solid rgba(27, 228, 245, 0.28);
  border-radius: 14px;
  box-shadow: 0 24px 60px -12px rgba(0, 0, 0, 0.7), 0 0 40px -10px rgba(27, 228, 245, 0.18);
  overflow: hidden;
  animation: lm-in 0.28s cubic-bezier(.16, 1, .3, 1);
  z-index: 1;
}
@keyframes lm-in {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to   { opacity: 1; transform: none; }
}
#login-modal .lm-close {
  position: absolute; top: 14px; right: 14px;
  width: 28px; height: 28px;
  background: transparent; border: none; cursor: pointer;
  color: #98a1b3; font-size: 22px; line-height: 1;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s, color 0.15s;
  padding: 0;
}
#login-modal .lm-close:hover { background: rgba(255, 255, 255, 0.06); color: #e6ebf5; }
#login-modal .lm-head {
  padding: 32px 32px 22px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  text-align: left;
}
#login-modal .lm-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  background: rgba(27, 228, 245, 0.10);
  border: 1px solid rgba(27, 228, 245, 0.28);
  border-radius: 8px;
  color: #1be4f5; font-weight: 700; font-size: 13px;
  font-family: 'Space Grotesk', sans-serif;
  margin-bottom: 14px;
}
#login-modal .lm-title {
  font-size: 18px; font-weight: 600; color: #e6ebf5;
  letter-spacing: 0.2px;
  margin: 0;
}
#login-modal .lm-sub {
  font-size: 11px; color: #555f73;
  letter-spacing: 2px; text-transform: uppercase;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  margin-top: 4px;
}
#login-modal .lm-body { padding: 22px 32px 28px; }
#login-modal .lm-field { margin-bottom: 14px; }
#login-modal .lm-label {
  /* ★ 6.6 A4: 标签改中文(邮箱/密码) → 调大字号 + 用基础字体(原 9px 等宽大写是英文 eyebrow 样式,
     中文过小且字体不对) + 提亮(#555f73→#aeb8c8, 提灰度不纯白) */
  display: block; font-size: 12px; letter-spacing: 0.3px;
  color: #aeb8c8;
  margin-bottom: 6px;
}
#login-modal .lm-input {
  width: 100%; padding: 11px 14px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  color: #e6ebf5; font-size: 13px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  outline: none; transition: border-color 0.15s, background 0.15s;
  box-sizing: border-box;
}
#login-modal .lm-input:focus {
  border-color: rgba(27, 228, 245, 0.5);
  background: rgba(27, 228, 245, 0.04);
}
/* ★ 6.6 A4: 占位符提亮(原浏览器默认偏暗看不清, 提灰度不纯白) */
#login-modal .lm-input::placeholder { color: rgba(200, 210, 220, 0.45); }
/* ★ 6.6 A3/A8: 密码框显示/隐藏眼睛图标(登录/注册/确认共用) */
#login-modal .lm-pw-wrap { position: relative; }
#login-modal .lm-pw-wrap .lm-input { padding-right: 40px; }
#login-modal .lm-pw-toggle {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: none; border: none; padding: 4px; cursor: pointer;
  color: rgba(200, 210, 220, 0.5); display: flex; align-items: center;
  transition: color 0.15s;
}
#login-modal .lm-pw-toggle:hover { color: #1be4f5; }
#login-modal .lm-btn {
  width: 100%; padding: 12px;
  margin-top: 6px;
  background: transparent;
  border: 1px solid rgba(27, 228, 245, 0.5);
  color: #1be4f5;
  border-radius: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, transform 0.18s;
}
#login-modal .lm-btn:hover:not(:disabled) {
  background: rgba(27, 228, 245, 0.08);
  border-color: #1be4f5;
  transform: translateY(-1px);
}
#login-modal .lm-btn:disabled { opacity: 0.6; cursor: wait; }
#login-modal .lm-error {
  font-size: 11px; color: #ef5350;
  text-align: center; margin-top: 10px;
  min-height: 14px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
/* ★ 窗口B 新增:忘记密码入口。右对齐弱化小字,hover 转主题青色。纯增量。 */
#login-modal .lm-forgot {
  text-align: right;
  margin-top: 8px;
}
#login-modal .lm-forgot a {
  font-size: 11px;
  color: rgba(200, 210, 220, 0.55);
  text-decoration: none;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  transition: color 0.18s;
}
#login-modal .lm-forgot a:hover {
  color: #1be4f5;
}
/* ★ 窗口B 新增:重置密码回跳"设新密码"覆盖层。仿 login-modal 视觉,
   recovery- 前缀自包含防撞,JS 注入故默认就要可见(无 display:none)。 */
#recovery-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100001;
  display: flex;
  align-items: center; justify-content: center;
  font-family: 'Space Grotesk', 'PingFang SC', 'Microsoft YaHei', system-ui, sans-serif;
}
#recovery-overlay .recovery-backdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(7, 9, 15, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
#recovery-overlay .recovery-card {
  position: relative;
  width: 380px; max-width: calc(100vw - 32px);
  padding: 28px 26px;
  background: #161c2d;
  border: 1px solid rgba(27, 228, 245, 0.28);
  border-radius: 14px;
  box-shadow: 0 24px 60px -12px rgba(0, 0, 0, 0.7), 0 0 40px -10px rgba(27, 228, 245, 0.18);
  z-index: 1;
}
#recovery-overlay .recovery-title {
  font-size: 16px; font-weight: 600; color: #e6ebf5;
  margin-bottom: 4px;
}
#recovery-overlay .recovery-sub {
  font-size: 11px; color: rgba(200, 210, 220, 0.55);
  margin-bottom: 18px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
#recovery-overlay .recovery-input {
  width: 100%; padding: 11px 14px;
  margin-bottom: 10px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  color: #e6ebf5; font-size: 13px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  outline: none; transition: border-color 0.15s, background 0.15s;
  box-sizing: border-box;
}
#recovery-overlay .recovery-input:focus {
  border-color: rgba(27, 228, 245, 0.5);
  background: rgba(27, 228, 245, 0.04);
}
#recovery-overlay .recovery-btn {
  width: 100%; padding: 12px;
  margin-top: 6px;
  background: transparent;
  border: 1px solid rgba(27, 228, 245, 0.5);
  color: #1be4f5;
  border-radius: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s;
}
#recovery-overlay .recovery-btn:hover:not(:disabled) {
  background: rgba(27, 228, 245, 0.08);
  border-color: #1be4f5;
}
#recovery-overlay .recovery-btn:disabled { opacity: 0.6; cursor: wait; }
#recovery-overlay .recovery-msg {
  font-size: 11px; text-align: center;
  margin-top: 12px; min-height: 14px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  color: rgba(200, 210, 220, 0.6);
}
#recovery-overlay .recovery-msg.recovery-ok { color: #4caf50; }
#recovery-overlay .recovery-msg.recovery-err { color: #ef5350; }

/* ★ 窗口C 新增:注册同意声明小字(仿 .lm-forgot)+ 条款/隐私占位层
   (仿 #recovery-overlay,legal- 前缀防撞,z-index 压过登录 modal)。纯增量。 */
#login-modal .lm-consent {
  /* ★ 6.6 A11: 加真实勾选框 → 改 flex 左对齐(原 text-align:center) */
  margin-top: 10px;
  font-size: 11px;
  line-height: 1.6;
  color: rgba(200, 210, 220, 0.5);
  display: flex; align-items: flex-start; gap: 8px; text-align: left;
}
#login-modal .lm-consent-box {
  flex: 0 0 auto; margin-top: 2px; width: 14px; height: 14px;
  accent-color: #1be4f5; cursor: pointer;
}
#login-modal .lm-consent a {
  color: rgba(200, 210, 220, 0.7);
  text-decoration: none;
  transition: color 0.18s;
}
#login-modal .lm-consent a:hover { color: #1be4f5; }

#legal-overlay {
  position: fixed; inset: 0; z-index: 100001;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Space Grotesk', 'PingFang SC', 'Microsoft YaHei', system-ui, sans-serif;
}
#legal-overlay .legal-backdrop {
  position: fixed; inset: 0;
  background: rgba(7, 9, 15, 0.82);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
#legal-overlay .legal-card {
  position: relative; width: 560px; max-width: calc(100vw - 32px);
  max-height: 80vh; display: flex; flex-direction: column;
  background: #161c2d; border: 1px solid rgba(27, 228, 245, 0.28);
  border-radius: 14px;
  box-shadow: 0 24px 60px -12px rgba(0,0,0,0.7), 0 0 40px -10px rgba(27,228,245,0.18);
}
#legal-overlay .legal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px 12px; border-bottom: 1px solid rgba(255,255,255,0.08);
}
#legal-overlay .legal-title { font-size: 16px; font-weight: 600; color: #e8edf4; }
#legal-overlay .legal-close {
  background: none; border: none; color: rgba(200,210,220,0.6);
  font-size: 22px; cursor: pointer; line-height: 1; padding: 0 4px;
}
#legal-overlay .legal-close:hover { color: #1be4f5; }
#legal-overlay .legal-banner {
  margin: 12px 22px 0; padding: 10px 12px;
  background: rgba(255, 180, 60, 0.1);
  border: 1px solid rgba(255, 180, 60, 0.32);
  border-radius: 8px; font-size: 12px; line-height: 1.6; color: #ffcf80;
}
#legal-overlay .legal-body {
  padding: 14px 22px 22px; overflow-y: auto;
  font-size: 13px; line-height: 1.8; color: rgba(210,218,228,0.86);
}
#legal-overlay .legal-body h4 {
  margin: 16px 0 6px; font-size: 13.5px; color: #cfe3ea; font-weight: 600;
}
#legal-overlay .legal-body p { margin: 0 0 8px; white-space: pre-line; }

/* ============================================================
   v8.0 SYMBOL DIMENSION (Stage 2) — only-read symbol tag + Hero pick screen
   ============================================================ */

/* Daily Log 标题旁的只读 symbol tag (橙色) */
.symbol-tag-readonly{
  font-size:11px;
  font-family:var(--font-mono);
  font-weight:700;
  letter-spacing:1px;
  color:var(--accent);
  background:rgba(230,126,34,0.10);
  border:1px solid rgba(230,126,34,0.30);
  border-radius:4px;
  padding:3px 8px;
  cursor:default;
  user-select:none;
}

/* 选标的 Hero 页 — 黑底全屏,跟 #landing-screen 同档 z-index */
#symbol-pick-screen{
  position:fixed; inset:0; z-index:50;
  display:flex; align-items:center; justify-content:center;
  background:#000;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:#fff;
  overflow:hidden;
}
#symbol-pick-screen .sp-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(230,126,34,0.10), transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(243,156,18,0.06), transparent 55%);
  pointer-events:none;
}
#symbol-pick-screen .sp-wrap{
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center;
  gap:48px; padding:24px;
  max-width:920px; width:100%;
  animation: sp-fade-in .5s ease-out;
}
@keyframes sp-fade-in{
  from{opacity:0; transform:translateY(8px)}
  to  {opacity:1; transform:translateY(0)}
}
#symbol-pick-screen .sp-head{
  text-align:center; display:flex; flex-direction:column; align-items:center; gap:14px;
}
#symbol-pick-screen .sp-badge{
  display:inline-flex; align-items:center; gap:8px;
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  color:#e67e22; opacity:.85;
  font-family:'JetBrains Mono', ui-monospace, monospace;
}
#symbol-pick-screen .sp-badge-dot{
  width:6px; height:6px; border-radius:50%;
  background:#e67e22;
  box-shadow:0 0 8px rgba(230,126,34,0.6);
  animation: pulse 2s ease-in-out infinite;
}
#symbol-pick-screen .sp-title{
  font-size:48px; font-weight:700; letter-spacing:-0.5px;
  color:#fff;
}
#symbol-pick-screen .sp-sub{
  font-size:13px; color:rgba(255,255,255,0.55);
  font-family:'JetBrains Mono', ui-monospace, monospace;
  letter-spacing:0.3px;
}
#symbol-pick-screen .sp-buttons{
  display:flex; gap:32px; flex-wrap:wrap; justify-content:center;
}
#symbol-pick-screen .sp-btn{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px;
  width:300px; height:200px;
  background:rgba(255,255,255,0.03);
  border:1.5px solid rgba(255,255,255,0.10);
  border-radius:14px;
  cursor:pointer;
  transition: border-color .2s, background .2s, transform .15s, box-shadow .2s;
  font-family:inherit; color:inherit;
  padding:24px;
}
#symbol-pick-screen .sp-btn:hover{
  border-color:#e67e22;
  background:rgba(230,126,34,0.08);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(230,126,34,0.18);
}
#symbol-pick-screen .sp-btn:active{
  transform:translateY(0);
}
#symbol-pick-screen .sp-btn-code{
  font-size:56px; font-weight:800; letter-spacing:-1px;
  color:#fff;
  font-family:'JetBrains Mono', ui-monospace, monospace;
  line-height:1;
}
#symbol-pick-screen .sp-btn-pill{
  font-size:11px;
  color:rgba(255,255,255,0.70);
  padding:5px 12px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:999px;
  font-family:'JetBrains Mono', ui-monospace, monospace;
  letter-spacing:0.3px;
  text-align:center;
  white-space:nowrap;
}
#symbol-pick-screen .sp-btn:hover .sp-btn-pill{
  border-color:rgba(230,126,34,0.40);
  background:rgba(230,126,34,0.10);
  color:rgba(255,255,255,0.85);
}

/* 小屏兜底 */
@media (max-width: 720px){
  #symbol-pick-screen .sp-title{ font-size:32px }
  #symbol-pick-screen .sp-buttons{ gap:18px }
  #symbol-pick-screen .sp-btn{ width:240px; height:170px }
  #symbol-pick-screen .sp-btn-code{ font-size:44px }
}

/* ============================================================
 * §2.2 会员系统:tier / role 闸门样式（v4 Step 4-A）
 * ============================================================
 * 配套:permissions.js applyRoleToBodyClass()
 *
 * Body class 约定（3 档制，effectiveTier 折叠后）:
 *   role-admin | role-user         角色
 *   tier-1 | tier-2 | tier-3       前端档位（DB 4/5 折叠为 3）
 *   is-banned                      封禁用户
 *   is-trial                       试用激活中
 *
 * 元素级 class 三套:
 *   .tier-min-N        档位不足 → 直接隐藏（display:none）
 *                      用于:Replay 高级元素、Settings sidebar、Brain 观察池等
 *   .feature-locked-tN 档位不足 → 显示但带 🔒 锁标 + 半透明
 *                      用于:CSV 按钮、AI 日报、周报、Report tab 等(混合 UX)
 *   .admin-only        非 admin → 直接隐藏
 *   .feature-disabled  全员隐藏(等同于功能下线,如 ai.followup 追问段)
 *
 * 注意:这是 UX 层屏蔽,真正的权限闸门在 Edge Function + RLS。
 *      就算用户改 DOM 强行点出按钮,后端还会拦。
 * ============================================================ */

/* ──── tier-min-N: 档位不足直接隐藏 ────
 * 2026-05-16 重排后当前无元素使用此 class（CSV/Replay 全下放 T1，
 * 原挂载点已摘或改 feature-locked-*）。规则保留作"直接隐藏"语义的
 * 可复用基建——将来若有新功能需要"够档才出现、不显示锁标"，
 * 仍可挂 tier-min-2/3。无元素挂载时规则不生效，保留无副作用。
 */
.tier-min-2,
.tier-min-3,
.admin-only,
.feature-disabled { display: none !important; }

/* admin 看到所有 tier-min-* + admin-only（feature-disabled 仍隐藏，对 admin 也禁） */
body.role-admin .tier-min-2,
body.role-admin .tier-min-3,
body.role-admin .admin-only { display: revert !important; }

/* T2 解锁 tier-min-2 */
body.tier-2 .tier-min-2 { display: revert !important; }

/* T3 解锁 tier-min-2 + tier-min-3 */
body.tier-3 .tier-min-2,
body.tier-3 .tier-min-3 { display: revert !important; }

/* 封禁用户:全部 tier 元素隐藏（覆盖以上 revert） */
body.is-banned .tier-min-2,
body.is-banned .tier-min-3,
body.is-banned .admin-only { display: none !important; }

/* ──── Replay 动画控制行 ────
 * 历史: 曾叠加 .tier-min-3，admin/T3 下 `body.role-admin .tier-min-3
 * { display:revert !important }` 会把 inline flex 覆盖成 block，故曾需
 * 专用 class + 同级 !important 显式写回 flex。
 * 2026-05-16 重排: Replay 全部=T1，.rp-anim-row 已摘 tier-min-3（见 app.js），
 * 不再有 revert 冲突，纯 flex 定义即可，删去原 body.tier-3/.role-admin !important 分支。
 */
.rp-anim-row {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-top: 6px;
}

/* ──── feature-locked-tN: 档位不足显示锁标,点击弹模态 ──── */
/* 默认（用户档位不足）:半透明 + 锁标,但仍可点击触发升级模态
   2026-05-31: 新增 t1（K线回放/答疑/视频下放 T1 后，T0 可见带锁引导）;
               锁图标灰 #888 → 金 #d4a04a 匹配升级引导金质主题。 */
.feature-locked-t1,
.feature-locked-t2,
.feature-locked-t3 {
  opacity: 0.55;
  position: relative;
}
.feature-locked-t1::after,
.feature-locked-t2::after,
.feature-locked-t3::after {
  /* CSS pseudo-element 无法继承 currentColor, 硬编码金色 #d4a04a (深/浅色均可辨). */
  content: '';
  display: inline-block;
  width: 0.9em; height: 0.9em;
  margin-left: 4px;
  vertical-align: -1px;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d4a04a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
}

/* 档位满足 → 解锁外观(去掉 opacity 和 ::after)。解锁矩阵：
   t1 ← tier1/2/3/4/admin · t2 ← tier2/3/4/admin · t3 ← tier3/4/admin */
body.tier-1 .feature-locked-t1,
body.tier-2 .feature-locked-t1,
body.tier-2 .feature-locked-t2,
body.tier-3 .feature-locked-t1,
body.tier-3 .feature-locked-t2,
body.tier-3 .feature-locked-t3,
body.tier-4 .feature-locked-t1,
body.tier-4 .feature-locked-t2,
body.tier-4 .feature-locked-t3,
body.role-admin .feature-locked-t1,
body.role-admin .feature-locked-t2,
body.role-admin .feature-locked-t3 { opacity: 1; }

body.tier-1 .feature-locked-t1::after,
body.tier-2 .feature-locked-t1::after,
body.tier-2 .feature-locked-t2::after,
body.tier-3 .feature-locked-t1::after,
body.tier-3 .feature-locked-t2::after,
body.tier-3 .feature-locked-t3::after,
body.tier-4 .feature-locked-t1::after,
body.tier-4 .feature-locked-t2::after,
body.tier-4 .feature-locked-t3::after,
body.role-admin .feature-locked-t1::after,
body.role-admin .feature-locked-t2::after,
body.role-admin .feature-locked-t3::after { display: none; }

/* 封禁用户 feature-locked-* 也隐藏(避免封禁用户点出弹框) */
body.is-banned .feature-locked-t1,
body.is-banned .feature-locked-t2,
body.is-banned .feature-locked-t3 { display: none !important; }

/* ── 金质锁标胶囊（视频卡 / 有空间处的醒目锁标，opt-in，不强加导航） ── */
.tj-lock-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 700;
  padding: 4px 9px; border-radius: 7px;
  color: var(--tjgold-2);
  background: var(--tjgold-soft);
  border: 1px solid var(--tjgold-edge);
  white-space: nowrap;
}
.tj-lock-chip svg { flex: none; }

/* ──── Replay Pro Analysis 占位规则（2026-05-16 重排后废除）────
 * 原规则: body:not(.tier-3):not(.role-admin) #rp-box-pro > * { display:none }
 * 当时 Replay pro = T3，非 T3 隐藏内容但保留外壳占位 3 列布局。
 * 2026-05-16 重排后 Replay 全部功能下放 T1（全员可见），
 * 故此隐藏规则整体废除。#rp-box-pro 内容对所有登录用户正常显示。
 * 布局占位不再需要（内容本来就显示，flex 列自然撑开）。
 */

/* ============================================================
 * 升级提示模态框 tj-upg-* （permissions.js showUpgradePrompt）
 * ============================================================ */

/* 遮罩（升级 / 差价 / 确认 / 成功 共用） */
.tj-upg-overlay {
  position: fixed;
  inset: 0;
  background: rgba(4, 7, 12, 0.62);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  padding: 20px;
  animation: tj-upg-fade-in 0.16s ease-out;
}
@keyframes tj-upg-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.tj-upg-card {
  background: var(--bg2);
  color: var(--text);
  border-radius: 16px;
  width: min(440px, 94vw);
  max-height: 88vh;
  overflow: auto;
  box-shadow: 0 24px 70px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3);
  border: 1px solid var(--border);
  font-family: inherit;
  animation: tj-upg-pop-in 0.22s cubic-bezier(0.2, 1.1, 0.4, 1);
}
@keyframes tj-upg-pop-in {
  from { transform: translateY(8px) scale(0.97); opacity: 0; }
  to   { transform: none; opacity: 1; }
}
.tj-upg-card::-webkit-scrollbar { width: 8px; }
.tj-upg-card::-webkit-scrollbar-thumb { background: var(--border); border-radius: 8px; }

/* header（D 版：无 logo，纯标题左对齐 + eyebrow） */
.tj-upg-header {
  padding: 22px 22px 0;
  position: relative;
}
.tj-upg-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--tjgold-2);
  margin: 0 0 6px;
}
.tj-upg-title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: var(--text);
}
.tj-upg-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: transparent;
  border: none;
  color: var(--text3);
  font-size: 24px;
  line-height: 1;
  width: 32px;
  height: 32px;
  cursor: pointer;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.tj-upg-close:hover { background: var(--bg3); color: var(--text); }

.tj-upg-body {
  padding: 16px 22px 22px;
  font-size: 14px;
  line-height: 1.55;
}
.tj-upg-lead {
  margin: 6px 0 0;
  font-size: 14px;
  color: var(--text2);
  line-height: 1.6;
}
.tj-upg-lead b, .tj-upg-body strong { color: var(--text); font-weight: 600; }

/* 解锁清单（金色边框柔光块） */
.tj-upg-unlocks {
  margin: 16px 0 0;
  padding: 14px 16px;
  border-radius: 12px;
  background: var(--tjgold-soft);
  border: 1px solid var(--tjgold-edge);
}
.tj-upg-unlocks-h {
  font-size: 12px;
  font-weight: 700;
  color: var(--tjgold-2);
  margin: 0 0 8px;
  letter-spacing: .02em;
}
.tj-upg-unlocks ul {
  margin: 0; padding: 0; list-style: none;
  display: flex; flex-direction: column; gap: 7px;
}
.tj-upg-unlocks li {
  font-size: 13px;
  color: var(--text);
  display: flex; gap: 9px; align-items: flex-start;
  line-height: 1.45;
}
.tj-upg-unlocks li svg { flex: none; margin-top: 1px; color: var(--tjgold-2); }
/* 2026-06-01: 功能列表按档位上色——T1 普通白字(默认) / T2 浅金过渡 / T3 顶配金色渐变。
   T3 用「亮金→深琥珀」渐变文字，与上方标题的扁平金 var(--tjgold-2) 区分开，避免糊在一起。 */
.tj-upg-unlocks li.upg-t2 span { color: var(--tjgold-1); font-weight: 500; }
.tj-upg-unlocks li.upg-t3 span {
  font-weight: 700; color: #d97e1c;
  background: linear-gradient(90deg, #ffd877, #d97e1c);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
/* 浅色主题(白底)：深色用的亮金端(#ffd877 / --tjgold-1)会发虚，改用更深可读的金/琥珀。 */
html[data-theme="light"] .tj-upg-unlocks li.upg-t2 span { color: var(--tjgold-2); }
html[data-theme="light"] .tj-upg-unlocks li.upg-t3 span {
  background: linear-gradient(90deg, #c8851a, #8f5208);
  -webkit-text-fill-color: transparent; color: #8f5208;
}

/* 月/年 toggle */
.tj-upg-cycle {
  display: flex; gap: 4px;
  margin: 18px 0 12px;
  padding: 4px;
  background: var(--bg3);
  border-radius: 10px;
}
.tj-upg-cycle button {
  flex: 1;
  font: inherit; font-size: 13px; font-weight: 600;
  padding: 8px; border-radius: 7px;
  border: none; background: transparent; color: var(--text2);
  cursor: pointer; transition: .15s;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.tj-upg-cycle button.active {
  background: var(--bg2); color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,.18);
}
.tj-upg-save {
  font-size: 10px; font-weight: 700;
  color: var(--tjgold-ink-strong);
  background: var(--tjgold-grad);
  padding: 2px 6px; border-radius: 5px;
}

/* 档位卡：名字左、价钱右 */
.tj-tier-card {
  display: flex; align-items: center; gap: 12px;
  width: 100%; text-align: left; font: inherit;
  padding: 15px 16px; border-radius: 13px; cursor: pointer;
  transition: .16s; position: relative; margin-bottom: 9px;
  border: 1px solid var(--border); background: var(--bg3); color: var(--text);
}
.tj-tier-card:hover { transform: translateY(-1px); }
.tj-tier-card .tc-name { font-size: 15px; font-weight: 700; flex: none; }
.tj-tier-card .tc-spacer { flex: 1; }
.tj-tier-card .tc-price { font-size: 12px; color: var(--text2); white-space: nowrap; }
.tj-tier-card .tc-price b { font-size: 17px; color: var(--text); font-weight: 700; margin-right: 1px; }
.tj-tier-card .tc-arrow { flex: none; color: var(--text3); transition: .16s; display: flex; }
.tj-tier-card:hover .tc-arrow { transform: translateX(3px); }

/* 主推（精英版）：满金渐变 + 深字高对比 */
.tj-tier-card.is-floor {
  background: var(--tjgold-grad);
  border: 1px solid transparent;
  box-shadow: 0 5px 22px rgba(212,160,74,.28);
}
.tj-tier-card.is-floor .tc-name { color: var(--tjgold-ink-strong); }
.tj-tier-card.is-floor .tc-price { color: var(--tjgold-ink); }
.tj-tier-card.is-floor .tc-price b { color: var(--tjgold-ink-strong); }
.tj-tier-card.is-floor .tc-arrow { color: var(--tjgold-ink-strong); }
.tj-tier-card.is-floor:hover { box-shadow: 0 8px 30px rgba(212,160,74,.4); }
/* 选中态（升级弹窗档位单选）：与 is-floor 同款满金渐变，但由"选中"驱动而非固定主推。
   单独建类，避免改 is-floor（payments.js 付款方式层 Stripe 卡复用了 is-floor）。 */
.tj-tier-card.is-selected {
  background: var(--tjgold-grad);
  border: 1px solid transparent;
  box-shadow: 0 5px 22px rgba(212,160,74,.28);
}
.tj-tier-card.is-selected .tc-name { color: var(--tjgold-ink-strong); }
.tj-tier-card.is-selected .tc-price { color: var(--tjgold-ink); }
.tj-tier-card.is-selected .tc-price b { color: var(--tjgold-ink-strong); }
.tj-tier-card.is-selected:hover { box-shadow: 0 8px 30px rgba(212,160,74,.4); }
/* 「选择套餐」小标 + 主 CTA 全宽金按钮 */
.tj-upg-pick { font-size: 12px; color: var(--text3); margin: 16px 0 9px; letter-spacing: .04em; }
.tj-upg-cta { width: 100%; flex: none; margin-top: 8px; padding: 14px; font-size: 15px; }
.tj-upg-cta .tj-cta-arrow { display: inline-flex; }
.tc-badge {
  position: absolute; top: -9px; right: 14px;
  font-size: 10px; font-weight: 800; letter-spacing: .06em;
  color: var(--tjgold-1); background: var(--bg2);
  border: 1px solid var(--tjgold-edge);
  padding: 3px 9px; border-radius: 7px;
  box-shadow: 0 2px 6px rgba(0,0,0,.3);
  display: flex; align-items: center; gap: 3px;
}

/* 次级升/加购引导分隔 */
.tj-upsell-hint {
  font-size: 12px; color: var(--text3);
  margin: 14px 0 9px;
  display: flex; align-items: center; gap: 8px;
}
.tj-upsell-hint::before, .tj-upsell-hint::after {
  content: ""; flex: 1; height: 1px; background: var(--border);
}

/* Trial 卡（仅 T0 新开通显示，虚线金边引导） */
.tj-trial-card {
  display: flex; align-items: center; gap: 11px;
  width: 100%; text-align: left; font: inherit;
  padding: 13px 16px; border-radius: 12px; cursor: pointer; margin-top: 10px;
  border: 1px dashed var(--tjgold-edge); background: transparent; color: var(--text);
  transition: .15s;
}
.tj-trial-card:hover { background: var(--tjgold-soft); }
.tj-trial-card .tt-emoji { font-size: 18px; flex: none; }
.tj-trial-card .tc-main { flex: 1; min-width: 0; }
.tj-trial-card .tc-name { font-size: 13px; font-weight: 700; }
.tj-trial-card .tc-sub { font-size: 12px; color: var(--text2); margin-top: 2px; }
.tj-trial-card .tc-arrow { flex: none; color: var(--text3); margin-left: auto; }

/* footer + 次级链接 */
.tj-upg-footer { text-align: center; margin-top: 16px; }
.tj-upg-later {
  background: none; border: none; color: var(--text3);
  font: inherit; font-size: 13px; cursor: pointer;
  padding: 6px 12px; border-radius: 7px;
}
.tj-upg-later:hover { color: var(--text2); }

/* ── 差价 / 通用确认框共用主体 ── */
.tj-cf-icon {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.tj-cf-icon.gold { background: var(--tjgold-soft); color: var(--tjgold-2); }
.tj-cf-icon.danger { background: rgba(239,83,80,.12); color: var(--red); }
.tj-cf-amount {
  margin: 16px 0; padding: 16px; border-radius: 12px;
  background: var(--bg3); border: 1px solid var(--border);
  display: flex; align-items: baseline; justify-content: space-between;
}
.tj-cf-amount .lbl { font-size: 13px; color: var(--text2); }
.tj-cf-amount .val {
  font-size: 26px; font-weight: 800; color: var(--tjgold-2);
  font-variant-numeric: tabular-nums;
}
.tj-cf-note { font-size: 12px; color: var(--text3); line-height: 1.6; margin: 0; }
.tj-cf-err {
  margin: 12px 0 0; padding: 10px 12px; border-radius: 9px;
  background: rgba(239,83,80,.1); border: 1px solid rgba(239,83,80,.32);
  color: var(--red); font-size: 13px; line-height: 1.5;
  display: none;
}
.tj-cf-err.is-shown { display: block; }
.tj-cf-actions { display: flex; gap: 10px; margin-top: 20px; }

/* 统一按钮 */
.tj-btn {
  flex: 1; font: inherit; font-size: 14px; font-weight: 600;
  padding: 12px; border-radius: 11px; cursor: pointer;
  border: 1px solid var(--border); transition: .15s;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.tj-btn[disabled] { opacity: .6; cursor: default; pointer-events: none; }
.tj-btn-ghost { background: var(--bg3); color: var(--text2); }
.tj-btn-ghost:hover { color: var(--text); }
.tj-btn-gold {
  flex: 1.4; border: none; background: var(--tjgold-grad);
  color: var(--tjgold-ink-strong); font-weight: 800;
  box-shadow: 0 3px 14px rgba(212,160,74,.32);
}
.tj-btn-gold:hover { filter: brightness(1.05); box-shadow: 0 5px 20px rgba(212,160,74,.44); }
.tj-btn-danger { flex: 1.2; border: none; background: var(--red); color: #fff; font-weight: 700; }
.tj-btn-danger:hover { filter: brightness(1.06); }

/* 按钮内 spinner（加载态） */
.tj-btn-spin {
  width: 15px; height: 15px;
  border: 2px solid rgba(0,0,0,.25); border-top-color: currentColor;
  border-radius: 50%; animation: tj-btn-rot .7s linear infinite;
}
.tj-btn-gold .tj-btn-spin { border-color: rgba(0,0,0,.25); border-top-color: var(--tjgold-ink-strong); }
@keyframes tj-btn-rot { to { transform: rotate(360deg); } }

/* 跳转 Stripe 金质加载卡（payments._showRedirectOverlay） */
.tj-redirect-spin {
  width: 32px; height: 32px; margin: 0 auto 16px;
  border: 3px solid var(--tjgold-edge);
  border-top-color: var(--tjgold-2);
  border-radius: 50%;
  animation: tj-btn-rot .7s linear infinite;
}
.tj-redirect-text { font-size: 14px; color: var(--text2); margin: 0; }

/* ── 成功卡片（升级 / 升降级共用，复刻 #payment-success 体验） ── */
.tj-cf-success { text-align: center; padding: 34px 26px; }
.tj-cf-success .ring {
  width: 66px; height: 66px; border-radius: 50%; margin: 0 auto 18px;
  background: var(--tjgold-soft);
  display: flex; align-items: center; justify-content: center;
  animation: tj-upg-pop-in .4s cubic-bezier(.2,1.4,.4,1);
}
.tj-cf-success .ring svg { color: var(--tjgold-2); }
.tj-cf-success h2 { margin: 0 0 8px; font-size: 22px; font-weight: 800; color: var(--text); }
.tj-cf-success p {
  margin: 0; color: var(--text2); font-size: 14px;
  display: flex; align-items: center; justify-content: center; gap: 9px;
}
.tj-cf-success .sp {
  width: 15px; height: 15px;
  border: 2px solid var(--border); border-top-color: var(--tjgold-2);
  border-radius: 50%; animation: tj-btn-rot .7s linear infinite;
}

/* ── 兼容旧 markup（payments.js 仍用的 .sub-action-btn 在别处定义；
      保留旧 .tj-upg-btn* 作降级别名，避免遗漏调用点裸奔） ── */
.tj-upg-btn {
  padding: 10px 16px; border-radius: 10px; border: 1px solid var(--border);
  font: inherit; font-size: 13px; cursor: pointer; background: var(--bg3); color: var(--text);
}
.tj-upg-btn-secondary { background: transparent; color: var(--text2); }
.tj-upg-btn-secondary:hover { background: var(--bg3); }
.tj-upg-btn-primary { background: var(--tjgold-grad); color: var(--tjgold-ink-strong); border-color: transparent; font-weight: 700; }
.tj-upg-btn-primary:hover { filter: brightness(1.05); }

/* ============================================================
 * 实时播报模块[8] 样式 —— 由 broadcast-prototype.html 移植
 * 安全约束：
 *   - 不含 :root / html[data-theme] / *{} / body{} / 滚动条全局（沿用主站）
 *   - 所有规则收敛在 #page-broadcast 作用域，零碰撞主站通用类
 *   - keyframes 全部 bc- 前缀，不覆盖主站同名(如 pulse)
 *   - #bc-cal-popup / .mask 为 position:fixed，DOM 在 #page-broadcast 内，
 *     #page-broadcast 前缀不影响其视口定位
 * ============================================================ */
/* 应用壳布局：替代原型被剔除的全局 body{flex column}。
 * 主站 .page.active 已是撑满 flex 列，.bc-wrap 作为填充子项，
 * min-height:0 确保内部 .feed{flex:1;overflow-y:auto} 真正可滚。*/
#page-broadcast .bc-wrap{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}
@keyframes bc-pulse {0%,100%{opacity:.3}50%{opacity:1}}
@keyframes bc-liveDropIn {0%{opacity:0;transform:translateY(-18px) scale(.985)}60%{opacity:1}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes bc-liveGlow {0%{box-shadow:0 0 0 0 rgba(230,126,34,0);border-color:var(--border)}14%{box-shadow:0 0 22px 2px rgba(230,126,34,.42);border-color:var(--accent)}55%{box-shadow:0 0 10px 1px rgba(230,126,34,.18);border-color:var(--border2)}100%{box-shadow:0 0 0 0 rgba(230,126,34,0);border-color:var(--border)}}
@keyframes bc-liveBar {0%{transform:scaleY(0);opacity:0}18%{transform:scaleY(1);opacity:1}65%{transform:scaleY(1);opacity:1}100%{transform:scaleY(1);opacity:0}}
@keyframes bc-liveTag {0%{opacity:0;transform:translateX(-6px) scale(.7)}22%{opacity:1;transform:translateX(0) scale(1)}68%{opacity:1;transform:translateX(0) scale(1)}100%{opacity:0;transform:translateX(0) scale(.92)}}
@keyframes bc-panelIn {from{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
#page-broadcast .page-header {padding:16px 24px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg2)}
#page-broadcast .page-header-left {display:flex;align-items:center;gap:10px}
#page-broadcast .page-title {font-size:18px;font-weight:700;color:var(--text)}
#page-broadcast .hdr-right {display:flex;align-items:center;gap:12px}
#page-broadcast .datepick {display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--text2)}
#page-broadcast .date-trigger {display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font-mono);font-size:11px;padding:6px 11px;cursor:pointer;position:relative;transition:border-color .15s;user-select:none}
#page-broadcast .date-trigger:hover {border-color:var(--accent)}
#page-broadcast .date-trigger .date-label {letter-spacing:.5px}
#page-broadcast .date-trigger input[type=date] {position:absolute;inset:0;width:100%;height:100%;opacity:0;border:none;padding:0;margin:0;cursor:pointer}
#page-broadcast .datepick .today-btn {background:transparent;border:1px solid var(--border2);color:var(--accent);font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:6px 10px;border-radius:5px;cursor:pointer}
#page-broadcast .datepick .today-btn:hover {background:var(--accent);color:#fff}
#page-broadcast .live-pill {display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--win);border:1px solid rgba(38,166,154,.35);border-radius:20px;padding:4px 11px}
#page-broadcast .live-pill.history {color:var(--text3);border-color:var(--border)}
#page-broadcast .live-dot {width:6px;height:6px;border-radius:50%;background:var(--win);animation:bc-pulse 2s ease-in-out infinite}
#page-broadcast .live-pill.history .live-dot {background:var(--text3);animation:none}
#page-broadcast .daily-tip {display:flex;align-items:center;gap:10px;padding:10px 24px;background:linear-gradient(90deg,rgba(230,126,34,.10),rgba(230,126,34,.02));border-bottom:1px solid var(--border);flex-shrink:0}
#page-broadcast .daily-tip .tip-tag {font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);white-space:nowrap;font-weight:700}
#page-broadcast .daily-tip .tip-body {flex:1;font-size:13px;color:var(--text);min-width:0;line-height:1.5}
#page-broadcast .daily-tip .tip-body.empty {color:var(--text3);font-style:italic}
#page-broadcast .daily-tip .tip-edit {background:transparent;border:1px solid var(--border2);color:var(--accent);font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:5px;cursor:pointer;white-space:nowrap}
#page-broadcast .daily-tip .tip-edit:hover {background:var(--accent);color:#fff}
#page-broadcast .daily-tip input {flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-size:13px;padding:7px 12px;font-family:inherit;outline:none}
#page-broadcast .cat-bar {display:flex;flex-wrap:wrap;gap:7px;padding:12px 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg);align-items:center}
#page-broadcast .cat-chip {font-family:var(--font-mono);font-size:11px;letter-spacing:.5px;color:var(--text2);background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:5px 13px;cursor:pointer;transition:all .15s;user-select:none;display:inline-flex;align-items:center;gap:6px}
#page-broadcast .cat-chip .cdot {width:7px;height:7px;border-radius:50%}
#page-broadcast .cat-chip:hover {border-color:var(--border2);color:var(--text)}
#page-broadcast .cat-chip.on {background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
#page-broadcast .cat-chip.on .cdot {box-shadow:0 0 0 2px rgba(255,255,255,.4)}
#page-broadcast .cat-chip.all {border-style:dashed}
#page-broadcast .cat-chip.all.on {background:var(--bg3);border-color:var(--accent);border-style:solid;color:var(--accent)}
#page-broadcast .cat-chip .tier-mini {font-size:8px;opacity:.7;letter-spacing:.5px}
/* 2026-05-24: 风格对齐答疑 .qa-cat-chip-admin — 默认灰色冷调, hover 才变橙. 去掉原 hover 旋转 / 背景填充 */
#page-broadcast .gear-btn {margin-left:auto;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
#page-broadcast .gear-btn:hover {background:transparent;color:var(--accent);border-color:var(--accent)}
#page-broadcast .mask {position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:100;display:none;align-items:flex-start;justify-content:center;padding-top:80px}
#page-broadcast .mask.show {display:flex}
#page-broadcast .panel {background:var(--bg2);border:1px solid var(--border2);border-radius:14px;width:min(560px,92vw);max-height:78vh;overflow:hidden;display:flex;flex-direction:column;animation:bc-panelIn .2s ease;box-shadow:0 24px 60px rgba(0,0,0,.5)}
#page-broadcast .panel-hd {padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
#page-broadcast .panel-hd h3 {font-size:15px;font-weight:700}
#page-broadcast .panel-hd .x {background:transparent;border:none;color:var(--text2);font-size:20px;cursor:pointer;line-height:1}
#page-broadcast .panel-hd .x:hover {color:var(--text)}
#page-broadcast .panel-body {padding:14px 20px;overflow-y:auto}
#page-broadcast .cat-row {display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:9px;margin-bottom:8px;background:var(--bg);transition:transform .2s ease,opacity .2s ease}
#page-broadcast .cat-row .grip {color:var(--text3);cursor:grab;font-size:14px;user-select:none}
#page-broadcast .cat-row .grip:active {cursor:grabbing}
#page-broadcast .cat-row.dragging {opacity:.4}
#page-broadcast .cat-row.dragover {border-color:var(--accent);border-style:dashed}
#page-broadcast .cat-row .swatch {width:16px;height:16px;border-radius:50%;flex-shrink:0;cursor:pointer;border:2px solid rgba(255,255,255,.15)}
#page-broadcast .cat-row input.cname {flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:13px;padding:6px 9px;outline:none;min-width:60px}
#page-broadcast .cat-row input.cname:focus {border-color:var(--accent)}
#page-broadcast .cat-row select.ctier {background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font-mono);font-size:11px;padding:6px 7px;outline:none;cursor:pointer}
#page-broadcast .cat-row select.ctier:focus {border-color:var(--accent)}
#page-broadcast .cat-row .cdel {background:transparent;border:1px solid rgba(239,83,80,.35);color:var(--loss);border-radius:6px;padding:6px 9px;font-size:11px;cursor:pointer;font-family:var(--font-mono)}
#page-broadcast .cat-row .cdel:hover {background:var(--loss);color:#fff}
#page-broadcast .panel-ft {padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:center}
#page-broadcast .panel-ft input {flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:7px;color:var(--text);font-family:inherit;font-size:13px;padding:9px 12px;outline:none}
#page-broadcast .panel-ft input:focus {border-color:var(--accent)}
#page-broadcast .panel-ft .addbtn {background:var(--accent);border:none;color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:10px 18px;border-radius:7px;cursor:pointer;white-space:nowrap}
#page-broadcast .panel-ft .addbtn:hover {background:var(--accent2)}
#page-broadcast .panel-note {font-family:var(--font-mono);font-size:10px;color:var(--text3);padding:0 20px 14px;line-height:1.5}
#page-broadcast .confirm-box {background:var(--bg2);border:1px solid var(--loss);border-radius:14px;width:min(440px,92vw);animation:bc-panelIn .2s ease;box-shadow:0 24px 60px rgba(0,0,0,.5);overflow:hidden}
#page-broadcast .confirm-box .cb-hd {padding:16px 20px;font-size:15px;font-weight:700;color:var(--loss);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
#page-broadcast .confirm-box .cb-body {padding:18px 20px;font-size:13.5px;line-height:1.6;color:var(--text)}
#page-broadcast .confirm-box .cb-body b {color:var(--loss)}
#page-broadcast .confirm-box .cb-ft {padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
#page-broadcast .confirm-box button {font-family:var(--font-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:8px 16px;border-radius:6px;cursor:pointer}
#page-broadcast .confirm-box .cancel {background:transparent;border:1px solid var(--border2);color:var(--text2)}
#page-broadcast .confirm-box .danger {background:var(--loss);border:1px solid var(--loss);color:#fff;font-weight:700}
#page-broadcast .feed {flex:1;overflow-y:auto;padding:14px 24px 24px}
#page-broadcast .feed-inner {display:flex;flex-direction:column;gap:5px;max-width:1300px;margin:0 auto}
#page-broadcast .msg {display:flex;align-items:flex-start;gap:12px;background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:6px 14px;position:relative;overflow:visible}
#page-broadcast .msg.fresh {animation:bc-liveDropIn .5s cubic-bezier(.22,.61,.36,1) both, bc-liveGlow 2s ease .05s both}
#page-broadcast .msg.fresh::before {content:"";position:absolute;left:-1px;top:6px;bottom:6px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--accent2),var(--accent));transform-origin:center;animation:bc-liveBar 2s ease .05s both;pointer-events:none}
#page-broadcast .msg.fresh::after {content:"NEW";position:absolute;right:10px;top:-9px;font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:1.5px;color:#fff;background:var(--accent);padding:2px 7px;border-radius:4px;box-shadow:0 2px 8px rgba(230,126,34,.5);animation:bc-liveTag 2s ease .05s both;pointer-events:none}
#page-broadcast .msg.editable {cursor:pointer}
#page-broadcast .msg.editable:hover {border-color:var(--border2)}
#page-broadcast .msg .dot {width:8px;height:8px;border-radius:50%;flex-shrink:0;align-self:center}
#page-broadcast .msg .mc {flex:1;min-width:0}
#page-broadcast .msg .mtop {display:flex;align-items:center;gap:8px;margin-bottom:1px;flex-wrap:wrap}
#page-broadcast .msg .mcat {font-family:var(--font-mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:4px;font-weight:700}
#page-broadcast .msg .mtier {font-family:var(--font-mono);font-size:8px;letter-spacing:.5px;color:var(--text3);border:1px solid var(--border);padding:1px 5px;border-radius:3px}
#page-broadcast .msg .mtime {font-family:var(--font-mono);font-size:12px;color:var(--text2);white-space:nowrap;margin-left:auto}
#page-broadcast .msg .medited {font-family:var(--font-mono);font-size:9px;color:var(--text3);font-style:italic}
#page-broadcast .msg .mbody {font-size:13.5px;line-height:1.45;color:var(--text);overflow-wrap:anywhere}
#page-broadcast .msg .mbody a {color:var(--accent2);text-decoration:none;border-bottom:1px dotted var(--accent2)}
#page-broadcast .msg .mbody a:hover {color:var(--accent)}
#page-broadcast .edit-box {display:flex;flex-direction:column;gap:8px;width:100%}
#page-broadcast .edit-box select, #page-broadcast .edit-box textarea {background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:inherit;font-size:13px;padding:8px 10px;outline:none}
#page-broadcast .edit-box textarea {resize:vertical;min-height:60px;line-height:1.5}
#page-broadcast .edit-box .erow {display:flex;gap:8px;align-items:center}
#page-broadcast .edit-box .erow .grow {flex:1}
#page-broadcast .ebtn {font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:6px 12px;border-radius:5px;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--text2)}
#page-broadcast .ebtn.save {background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
#page-broadcast .ebtn.del {border-color:rgba(239,83,80,.4);color:var(--loss)}
#page-broadcast .ebtn.del:hover {background:var(--loss);color:#fff}
#page-broadcast .composer {flex-shrink:0;border-top:1px solid var(--border);background:var(--bg2);padding:14px 24px;display:flex;flex-direction:column;gap:8px}
#page-broadcast .composer.hidden {display:none}
#page-broadcast .composer .crow {display:flex;gap:10px;align-items:flex-end}
#page-broadcast .composer select {background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:7px;color:var(--text);font-family:var(--font-mono);font-size:12px;padding:9px 12px;outline:none;cursor:pointer}
#page-broadcast .composer textarea {flex:1;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:7px;color:var(--text);font-family:inherit;font-size:13.5px;padding:10px 14px;outline:none;resize:none;min-height:44px;max-height:140px;line-height:1.5}
#page-broadcast .composer textarea:focus, #page-broadcast .composer select:focus {border-color:var(--accent)}
#page-broadcast .composer .send {background:var(--accent);border:none;border-radius:7px;color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:11px 22px;cursor:pointer;transition:background .15s;white-space:nowrap}
#page-broadcast .composer .send:hover {background:var(--accent2)}
#page-broadcast .composer .chint {font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:.5px}
#page-broadcast .empty-feed {text-align:center;color:var(--text3);font-size:13px;padding:60px 20px;font-family:var(--font-mono)}

/* ── 播报模块自定义日历弹窗 ───────────────────────────────────
 * 原型用 <input type=date>，broadcast.js 改为与主站 Statistics/
 * Daily-Review 一致的自定义弹窗日历（#bc-cal-popup / .bccal-*）。
 * CSS 转换脚本只取了原型，原型无此日历 → 这段是补回的缺口。
 * 1:1 沿用主站 #cal-popup 设计语言，仅前缀化 + #page-broadcast 收敛。
 * #bc-cal-popup 为 position:fixed（JS 设 top/left），#page-broadcast
 * 前缀不影响其视口定位。
 * ─────────────────────────────────────────────────────────── */
#page-broadcast #bc-cal-popup{display:none;position:fixed;z-index:9000;background:var(--bg2);
  border:1px solid var(--border);border-radius:12px;padding:16px;width:268px;
  box-shadow:0 20px 60px rgba(0,0,0,.8);user-select:none}
#page-broadcast #bc-cal-popup.open{display:block}
#page-broadcast .bccal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
#page-broadcast .bccal-title{font-size:13px;font-weight:700;color:var(--text);font-family:var(--font-mono)}
#page-broadcast .bccal-nav{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px 8px;
  border-radius:5px;font-size:16px;line-height:1;transition:all .15s}
#page-broadcast .bccal-nav:hover{background:var(--bg3);color:var(--accent)}
#page-broadcast .bccal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
#page-broadcast .bccal-wd{text-align:center;font-size:9px;letter-spacing:1px;color:var(--text3);
  font-family:var(--font-mono);padding:3px 0;text-transform:uppercase}
#page-broadcast .bccal-wd.weekend{color:rgba(74,85,104,0.5)}
#page-broadcast .bccal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
#page-broadcast .bccal-day{display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:5px 2px 4px;border-radius:7px;cursor:pointer;transition:all .15s;border:1px solid transparent}
#page-broadcast .bccal-day:hover:not(.weekend):not(.other-month):not(.disabled){background:var(--bg3);border-color:var(--border)}
#page-broadcast .bccal-day.today{border-color:rgba(230,126,34,0.4);background:rgba(230,126,34,0.06)}
#page-broadcast .bccal-day.selected{background:rgba(230,126,34,0.15);border-color:var(--accent)}
#page-broadcast .bccal-day.weekend{cursor:default;opacity:0.35}
#page-broadcast .bccal-day.disabled{cursor:default;opacity:0.3}
#page-broadcast .bccal-day.other-month{cursor:default;opacity:0.2}
#page-broadcast .bccal-day-num{font-size:12px;font-family:var(--font-mono);color:var(--text);line-height:1}
#page-broadcast .bccal-day.weekend .bccal-day-num{color:var(--text3)}
#page-broadcast .bccal-day.disabled .bccal-day-num{color:var(--text3)}
#page-broadcast .bccal-day.selected .bccal-day-num{color:var(--accent);font-weight:700}
#page-broadcast .bccal-day.today .bccal-day-num{color:var(--accent)}
#page-broadcast .bccal-dot{width:4px;height:4px;border-radius:50%;background:var(--text3);opacity:0.25;transition:all .2s}
#page-broadcast .bccal-dot.has-data{background:var(--accent);opacity:1;box-shadow:0 0 4px rgba(230,126,34,0.6)}

/* ★ 窗口A 新增:login-modal 登录/注册切换条。
 * #login-modal 作用域收敛;配色对齐该 modal 既有青色调
 * (强调 #1be4f5 / 弱化文字 #555f73 / 文字 #e6ebf5),不引入新风格。 */
#login-modal .lm-tabs { display:flex; gap:0; margin:0 32px; border-bottom:1px solid rgba(255,255,255,0.06); }
#login-modal .lm-tab {
  flex:1; background:none; border:none; cursor:pointer;
  padding:11px 0; font-size:13px; color:#555f73;
  font-family:inherit; border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
}
#login-modal .lm-tab:hover { color:#e6ebf5; }
#login-modal .lm-tab.active { color:#1be4f5; border-bottom-color:#1be4f5; font-weight:700; }

/* ============================================================
   ★ 窗口A.5 新增:个人中心页作用域样式。
   全部规则 #page-account 收敛(仿播报 CSS 隔离,零污染主站);
   复用现有 CSS 变量,不新增 :root。
   ============================================================ */
/* account 是居中卡片流页面（设计意图：640px 窄列居中，非通栏）。
 *   原 bug：作为 .page.active(flex列) 的子项却无 flex:1，
 *   未撑开 + 宽度按内容收缩 → 窄竖条。修法：撑满 flex 列并可滚，
 *   保留 max-width:640+margin:auto（保留其居中设计，区别于
 *   admin 的通栏铺满）。box-sizing 防 padding 撑破 640。 */
#page-account .acc-wrap {
  /* #8 (2026-06-04): 滚动容器放满宽 → 滚动条贴面板最右、整片黑区都能滚;
     卡片仍视觉居中(改用左右 padding 撑出 640 内容区, 替代原 max-width:640+margin:auto,
     原方案下 640 框右侧的黑色留白不属滚动区, 在那滚鼠标无反应) */
  flex: 1; min-height: 0; overflow-y: auto;
  width: 100%; box-sizing: border-box;
  padding-top: 28px; padding-bottom: 60px;
  padding-left: max(20px, calc((100% - 640px) / 2));
  padding-right: max(40px, calc((100% - 640px) / 2));
}
#page-account .acc-title { font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 20px; }
#page-account .acc-loading,
#page-account .acc-empty { padding: 48px 16px; text-align: center; color: var(--text3); font-size: 14px; }
#page-account .acc-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 16px;
}
#page-account .acc-card-h {
  font-size: 13px; font-weight: 700; color: var(--accent);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 14px;
}
#page-account .acc-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 14px;
}
#page-account .acc-row:last-child { border-bottom: none; }
#page-account .acc-k { color: var(--text3); }
#page-account .acc-v { color: var(--text); font-weight: 500; text-align: right; }
#page-account .acc-tier {
  display: inline-block; padding: 2px 10px; border-radius: 999px;
  background: rgba(230,126,34,0.12); color: var(--accent);
  font-size: 12px; font-weight: 700;
}
#page-account .acc-ref-row { display: flex; gap: 10px; align-items: center; margin-bottom: 12px; }
#page-account .acc-ref {
  flex: 1; background: var(--bg3); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px; font-family: ui-monospace, Menlo, monospace;
  font-size: 15px; letter-spacing: 1px; color: var(--text); user-select: all;
}
#page-account .acc-hint { font-size: 12px; color: var(--text3); margin-top: 10px; line-height: 1.6; }
/* UX-10/12 (窗口 X+3): 订阅管理卡按钮行 */
#page-account .acc-sub-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
#page-account .acc-edit-row { display: flex; gap: 10px; }
#page-account .acc-input {
  flex: 1; background: var(--bg3); border: 1px solid var(--border);
  border-radius: 8px; padding: 9px 12px; color: var(--text);
  font-size: 14px; outline: none;
}
#page-account .acc-input:focus { border-color: var(--accent); }
#page-account .acc-input-block { display: block; width: 100%; margin-bottom: 10px; box-sizing: border-box; }
#page-account .acc-btn {
  background: var(--accent); color: #fff; border: none;
  border-radius: 8px; padding: 9px 18px; font-size: 13px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
}
#page-account .acc-btn:hover { background: var(--accent2, var(--accent)); filter: brightness(1.08); }
#page-account .acc-btn:disabled { opacity: .55; cursor: default; }
#page-account .acc-btn-ghost {
  background: transparent; color: var(--accent);
  border: 1px solid var(--accent); padding: 9px 16px;
}
#page-account .acc-btn-ghost:hover { background: rgba(230,126,34,0.08); }
#page-account .acc-btn-danger { background: transparent; color: var(--red); border: 1px solid var(--red); }
#page-account .acc-btn-danger:hover { background: rgba(239,83,80,0.06); }
#page-account .acc-msg { font-size: 12px; margin-top: 10px; min-height: 16px; color: var(--text3); }
#page-account .acc-msg.acc-ok { color: var(--green, #26a69a); }
#page-account .acc-msg.acc-err { color: var(--red); }

/* ============================================================
 * 管理后台模块[7] — admin.js 配套样式
 *   - 全规则收敛 #page-admin 作用域，零碰撞主站通用类
 *     （复刻 #page-broadcast 隔离规范，蓝图 §7.1）
 *   - 复用主题 CSS 变量（--bg/--bg2/--border/--accent/--text…），
 *     深色/浅色双主题自动适配，不引入新色板
 *   - 第①段：Tab 条 + 区容器 + 占位的基础排版。
 *     列表/详情/操作的样式随第②③段追加。
 * ============================================================ */
/* .page.active 是 display:flex;flex-direction:column 的列容器，
 *   子元素必须 flex:1 才能撑满内容区宽高（复刻已验证样板
 *   #page-broadcast .bc-wrap 第3739行）。第①段漏写 flex:1 +
 *   叠加 margin:0 auto，导致 wrap 收缩成窄竖条——此处根因修复。
 *   最大宽度约束改到内部内容流，wrap 本身撑满。 */
/* 完全复刻播报页结构（已验证样板 #page-broadcast）：
 *   .page.active(flex列) > .adm-wrap(flex:1撑满) >
 *     .page-header(通栏标题条) / .adm-tabbar / .adm-region
 *   —— 全部通栏铺满，不加 max-width 居中（播报页就没有，
 *      admin 与之一致最稳）。内部留白靠各自 padding。
 *   历史教训：曾给 .adm-wrap>* 加 max-width:1200px;margin:auto，
 *      把通栏 page-header 框成居中窄盒——已移除。 */
#page-admin .adm-wrap {
  flex: 1; display: flex; flex-direction: column;
  min-height: 0; overflow-y: auto;
}
/* page-header 通栏：复刻 #page-broadcast .page-header（第3746行）*/
#page-admin .page-header {
  padding: 16px 24px 12px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0; background: var(--bg2);
}
#page-admin .page-header-left { display: flex; align-items: center; gap: 10px; }
#page-admin .page-title { font-size: 18px; font-weight: 700; color: var(--text); }
/* tab 条 + 内容区：通栏 padding，但内容居中（max-width 1300px 与统计/播报/答疑/视频统一）*/
#page-admin .adm-region {
  max-width: 1300px;
  width: 100%;
  margin: 0 auto;
  padding: 0 24px 28px;
  box-sizing: border-box;
}
#page-admin .hdr-right { display: flex; align-items: center; gap: 12px; }
#page-admin .adm-whoami {
  font-size: 11px; color: var(--text2);
  font-family: var(--font-mono, monospace);
  letter-spacing: .5px;
}
#page-admin .adm-tabbar {
  display: flex; gap: 4px;
  border-bottom: 1px solid var(--border);
  margin: 16px 0 20px;
  padding: 0 24px;
}
#page-admin .adm-tab {
  appearance: none; background: transparent;
  border: none; border-bottom: 2px solid transparent;
  padding: 10px 18px; margin-bottom: -1px;
  font-size: 12px; font-weight: 600;
  color: var(--text2); cursor: pointer;
  font-family: inherit; letter-spacing: .5px;
  transition: color .15s, border-color .15s;
}
#page-admin .adm-tab:hover { color: var(--text); }
#page-admin .adm-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
#page-admin .adm-tab[data-soon] { color: var(--text3); cursor: default; }
#page-admin .adm-tab[data-soon]:hover { color: var(--text3); }
#page-admin .adm-soon {
  display: inline-block; font-size: 9px;
  padding: 1px 6px; margin-left: 4px;
  border: 1px solid var(--border);
  border-radius: 8px; color: var(--text3);
  letter-spacing: 1px; vertical-align: middle;
}
#page-admin .adm-region { min-height: 200px; }
#page-admin .adm-placeholder {
  padding: 48px 24px; text-align: center;
  color: var(--text2); font-size: 13px;
  background: var(--bg2);
  border: 1px dashed var(--border);
  border-radius: 10px;
}

/* ---- C-1 会员列表（第②段，续 #page-admin 作用域）---- */
#page-admin .adm-mb-toolbar {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 14px; flex-wrap: wrap;
}
#page-admin .adm-search {
  flex: 1; min-width: 180px; max-width: 320px;
  padding: 8px 12px; font-size: 12px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  font-family: inherit; outline: none;
  transition: border-color .15s;
}
#page-admin .adm-search:focus { border-color: var(--accent); }
#page-admin .adm-mb-count {
  font-size: 11px; color: var(--text2);
  font-family: var(--font-mono, monospace);
}
#page-admin .adm-btn {
  appearance: none; cursor: pointer;
  padding: 7px 14px; font-size: 11px; font-weight: 600;
  background: var(--bg3); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  font-family: inherit; letter-spacing: .5px;
  transition: background .15s, border-color .15s;
}
#page-admin .adm-btn:hover {
  border-color: var(--accent); color: var(--accent);
}
#page-admin .adm-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border); border-radius: 10px;
}
#page-admin .adm-table {
  width: 100%; border-collapse: collapse;
  font-size: 12px; min-width: 760px;
}
#page-admin .adm-table thead th {
  position: sticky; top: 0;
  background: var(--bg2);
  color: var(--text2); font-weight: 600;
  text-align: left; padding: 11px 14px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
#page-admin .adm-th {
  cursor: pointer; user-select: none;
  transition: color .12s;
}
#page-admin .adm-th:hover { color: var(--text); }
#page-admin .adm-th-active { color: var(--accent); }
#page-admin .adm-table tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text); white-space: nowrap;
}
#page-admin .adm-table tbody tr:last-child td { border-bottom: none; }
#page-admin .adm-row { cursor: pointer; transition: background .12s; }
#page-admin .adm-row:hover { background: var(--bg3); }
#page-admin .adm-td-email {
  font-family: var(--font-mono, monospace);
  color: var(--text);
}
#page-admin .adm-empty {
  text-align: center; padding: 36px 14px;
  color: var(--text2);
}
#page-admin .adm-badge {
  display: inline-block; padding: 2px 9px;
  font-size: 10px; font-weight: 600;
  border-radius: 10px; letter-spacing: .5px;
}
#page-admin .adm-st-ok    { background: rgba(38,166,154,.16);  color: #26a69a; }
#page-admin .adm-st-trial { background: rgba(59,130,246,.16);  color: #3b82f6; }
#page-admin .adm-st-exp   { background: rgba(243,156,18,.16);  color: #f39c12; }
#page-admin .adm-st-ban   { background: rgba(239,83,80,.16);   color: #ef5350; }
#page-admin .adm-st-admin    { background: rgba(167,139,250,.18); color: #a78bfa; }  /* 管理员·紫 */
#page-admin .adm-st-internal { background: rgba(148,163,184,.18); color: #94a3b8; margin-left: 4px; }  /* 内部号·灰蓝 */
/* 开发者·金色发光动画(仅 admin 后台可见的特例,不外露给用户,不违付费金色铁律) */
#page-admin .adm-st-dev {
  background: linear-gradient(120deg, #f4d27a 0%, #d4a04a 42%, #f6da86 80%);
  background-size: 200% 100%;
  color: #3a2a08; font-weight: 700;
  box-shadow: 0 0 5px rgba(212,160,74,.6), 0 0 11px rgba(212,160,74,.35);
  animation: admDevGlow 2.4s ease-in-out infinite;
}
@keyframes admDevGlow {
  0%,100% { background-position: 0% 50%;   box-shadow: 0 0 5px rgba(212,160,74,.5),  0 0 10px rgba(212,160,74,.28); }
  50%     { background-position: 100% 50%; box-shadow: 0 0 9px rgba(212,160,74,.95), 0 0 18px rgba(212,160,74,.58); }
}
@media (prefers-reduced-motion: reduce) { #page-admin .adm-st-dev { animation: none; } }
#page-admin .adm-mb-hideint  { display:inline-flex; align-items:center; gap:4px; font-size:12px; color:var(--text2); cursor:pointer; user-select:none; margin-left:8px; }
#page-admin .adm-err-box { border-color: rgba(239,83,80,.4); }
#page-admin .adm-err-title {
  font-size: 13px; font-weight: 700; color: #ef5350;
  margin-bottom: 6px;
}
#page-admin .adm-err-msg { font-size: 12px; color: var(--text2); margin-bottom: 4px; }
#page-admin .adm-err-hint { font-size: 11px; color: var(--text3); margin-bottom: 12px; }

/* ---- C-2 详情页（第③段，续 #page-admin 作用域）---- */
#page-admin .adm-d-bar {
  display: flex; align-items: center; gap: 14px;
  padding: 0 24px; margin-bottom: 16px;
}
#page-admin .adm-d-title {
  font-size: 14px; font-weight: 700; color: var(--text);
  font-family: var(--font-mono, monospace);
}
#page-admin .adm-d-grid {
  display: grid; grid-template-columns: minmax(280px, 380px) 1fr;
  gap: 20px; padding: 0 24px;
}
#page-admin .adm-d-left,
#page-admin .adm-d-right { min-width: 0; }
#page-admin .adm-d-sec {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; margin-bottom: 14px;
}
#page-admin .adm-d-sec-t {
  font-size: 12px; font-weight: 700; color: var(--text);
  margin-bottom: 12px; letter-spacing: .5px;
}
#page-admin .adm-d-kv {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 7px 0; font-size: 12px;
  border-bottom: 1px solid var(--border);
}
#page-admin .adm-d-kv:last-child { border-bottom: none; }
#page-admin .adm-d-k { color: var(--text2); flex-shrink: 0; }
#page-admin .adm-d-v { color: var(--text); text-align: right; word-break: break-all; }
#page-admin .adm-mono { font-family: var(--font-mono, monospace); }
#page-admin .adm-muted { color: var(--text3); }
#page-admin .adm-d-stub {
  font-size: 12px; color: var(--text2); line-height: 1.6;
  padding: 4px 0 10px;
}
#page-admin .adm-op {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; margin-bottom: 14px;
}
#page-admin .adm-op-primary { border-color: var(--border2); }
#page-admin .adm-op-t {
  font-size: 13px; font-weight: 700; color: var(--text);
  margin-bottom: 4px;
}
#page-admin .adm-op-d {
  font-size: 11px; color: var(--text2); line-height: 1.6;
  margin-bottom: 12px;
}
#page-admin .adm-op-row {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
#page-admin .adm-input {
  flex: 1; min-width: 120px;
  padding: 8px 12px; font-size: 12px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  font-family: inherit; outline: none;
  transition: border-color .15s;
}
#page-admin .adm-input:focus { border-color: var(--accent); }
#page-admin .adm-input-num { flex: 0 0 110px; min-width: 90px; }
#page-admin select.adm-input { flex: 0 0 190px; min-width: 180px; cursor: pointer; }
#page-admin .adm-btn-primary {
  background: var(--accent); color: #fff; border-color: var(--accent);
  font-weight: 700;
}
#page-admin .adm-btn-primary:hover { opacity: .9; color: #fff; }
#page-admin .adm-btn-danger {
  background: transparent; color: #ef5350; border-color: rgba(239,83,80,.5);
}
#page-admin .adm-btn-danger:hover { border-color: #ef5350; color: #ef5350; }
#page-admin .adm-d-msg {
  margin: 16px 24px 0; font-size: 12px; line-height: 1.6;
  min-height: 18px;
}
#page-admin .adm-d-msg-ok   { color: #26a69a; }
#page-admin .adm-d-msg-err  {
  color: #ef5350; background: rgba(239,83,80,.08);
  border: 1px solid rgba(239,83,80,.3); border-radius: 8px;
  padding: 10px 14px;
}
#page-admin .adm-d-msg-warn { color: var(--text2); }

/* ---- 详情 Timeline（订单/订阅/档位历史合并按时间倒序）---- */
/*   2026-05-25 优化：block 布局，head（图标+时间）单独一行 → 主体
 *   占满列宽，notes 缩进。左侧彩色细条区分类型（绿订单/蓝订阅/橙档位）*/
#page-admin .adm-d-timeline {
  display: flex; flex-direction: column; gap: 8px;
  max-height: 360px; overflow-y: auto;
  padding-right: 4px;
}
#page-admin .adm-tl-row {
  display: block;
  padding: 9px 12px;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 12px; line-height: 1.55;
}
#page-admin .adm-tl-head {
  display: flex; align-items: center; gap: 7px;
  margin-bottom: 5px;
  font-size: 10.5px;
  color: var(--text3);
  font-family: var(--font-mono, monospace);
}
#page-admin .adm-tl-ico { color: var(--text2); display: inline-flex; align-items: center; }
#page-admin .adm-tl-time { letter-spacing: .3px; }
#page-admin .adm-tl-body {
  color: var(--text); word-break: break-word;
  display: flex; flex-wrap: wrap; align-items: center; gap: 4px 6px;
}
#page-admin .adm-tl-body strong { font-weight: 700; }
#page-admin .adm-tl-note {
  margin-top: 5px; font-size: 11px;
  color: var(--text2); padding: 2px 0 2px 8px;
  border-left: 2px solid var(--border2);
  line-height: 1.5;
}
/* 类型微调（左边一条彩色细条用于一眼区分）*/
#page-admin .adm-tl-order { border-left: 3px solid rgba(38,166,154,.6); }
#page-admin .adm-tl-sub   { border-left: 3px solid rgba(59,130,246,.6); }
#page-admin .adm-tl-tier  { border-left: 3px solid rgba(243,156,18,.6); }
/* 聚合卡：会员开通/续费/降档（order+sub+tier 合一）*/
#page-admin .adm-tl-grp   { border-left: 3px solid rgba(124,77,255,.7); }
#page-admin .adm-tl-subline {
  margin-top: 4px; font-size: 11px;
  color: var(--text2); line-height: 1.55;
}

/* badge 扩展（timeline 用） */
#page-admin .adm-tl-body .adm-badge { margin-left: 4px; }   /* 跟前文留间隙 */
#page-admin .adm-badge-ok    { background: rgba(38,166,154,.16);  color: #26a69a; }
#page-admin .adm-badge-err   { background: rgba(239,83,80,.16);   color: #ef5350; }
#page-admin .adm-badge-warn  { background: rgba(243,156,18,.16);  color: #f39c12; }
#page-admin .adm-badge-muted { background: rgba(160,160,160,.16); color: var(--text3); }

@media (max-width: 860px) {
  #page-admin .adm-d-grid { grid-template-columns: 1fr; }
}

/* ============================================================
 * 数据看板 + 操作中心公告条（2026-05-18 窗口）
 *   - #page-admin 作用域：看板卡片/排行/曲线/公告管理 UI
 *   - #tj-sysnotice-bar：全站红条，body 顶层，不属任何 page，
 *     z-index 最高（蓝图 §4 B-1-b：真·全局）
 * 复用既有 CSS 变量（--text2/--accent/--border2 等），与现有
 *   admin 样式一致。纯增量追加，不改任何现有规则。
 * ============================================================ */

/* —— 数据看板 —— */
#page-admin .adm-dash-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
#page-admin .adm-dash-title { font-size: 15px; font-weight: 600; color: var(--text1); }
#page-admin .adm-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px; margin-bottom: 16px;
}
#page-admin .adm-card {
  border: 1px solid var(--border1); border-radius: 8px;
  padding: 14px 16px; background: var(--bg2);
}
#page-admin .adm-card-v { font-size: 26px; font-weight: 700; color: var(--text1); }
#page-admin .adm-card-t { font-size: 13px; color: var(--text2); margin-top: 4px; }
#page-admin .adm-card-sub { font-size: 11px; color: var(--text3); margin-top: 4px; }
#page-admin .adm-card-stub { opacity: .55; }
#page-admin .adm-rank-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px;
}
#page-admin .adm-rank-box {
  border: 1px solid var(--border1); border-radius: 8px;
  padding: 12px 14px; background: var(--bg2);
}
#page-admin .adm-rank-h {
  font-size: 13px; font-weight: 600; color: var(--text2);
  margin-bottom: 8px;
}
#page-admin .adm-rank-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 0; font-size: 13px; border-bottom: 1px solid var(--border1);
}
#page-admin .adm-rank-row:last-child { border-bottom: none; }
#page-admin .adm-rank-name {
  color: var(--text1); overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap; max-width: 70%;
}
#page-admin .adm-rank-v { color: var(--text2); font-variant-numeric: tabular-nums; }
#page-admin .adm-trend-box { margin-bottom: 14px; }
#page-admin .adm-bars {
  display: flex; align-items: flex-end; gap: 2px; height: 90px;
  padding-top: 6px;
}
#page-admin .adm-bar-col {
  flex: 1; height: 100%; display: flex; align-items: flex-end;
}
#page-admin .adm-bar {
  width: 100%; background: var(--accent); border-radius: 2px 2px 0 0;
  min-height: 2px; transition: height .2s;
}
#page-admin .adm-dash-foot {
  font-size: 12px; color: var(--text3); margin-top: 8px;
  padding: 8px; border: 1px dashed var(--border1); border-radius: 6px;
}

/* —— 操作中心 · 公告管理 —— */
#page-admin .adm-notice-cur {
  padding: 10px 14px; border-radius: 6px; font-size: 13px;
  margin-bottom: 14px; border: 1px solid var(--border1);
}
#page-admin .adm-notice-none { color: var(--text3); }
#page-admin .adm-notice-info    { background: rgba(66,165,245,.12); color: #42a5f5; }
#page-admin .adm-notice-warn    { background: rgba(255,193,7,.12);  color: #e0a800; }
#page-admin .adm-notice-critical{ background: rgba(239,83,80,.14);  color: #ef5350; }
#page-admin .adm-notice-form {
  border: 1px solid var(--border1); border-radius: 8px;
  padding: 14px; background: var(--bg2); margin-bottom: 6px;
}
#page-admin .adm-notice-ta {
  width: 100%; min-height: 60px; resize: vertical; margin: 8px 0;
  font-family: inherit;
}
#page-admin .adm-notice-row {
  border: 1px solid var(--border1); border-radius: 6px;
  padding: 10px 12px; margin-bottom: 8px; background: var(--bg2);
}
#page-admin .adm-notice-row-top {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; margin-bottom: 6px;
}
#page-admin .adm-notice-row-top .adm-btn { margin-left: auto; }
#page-admin .adm-notice-row-body { font-size: 13px; color: var(--text1); }

/* ================================================================
 * 视频管理 Tab（Part 2 - 2026-05-23 窗口 Q 续）
 * ================================================================ */

/* —— 左右分栏布局 —— */
#page-admin .adm-videos-layout {
  display: flex; gap: 20px; margin-top: 16px;
}
#page-admin .adm-videos-left {
  width: 280px; flex-shrink: 0;
  background: var(--bg2); border-radius: 8px; padding: 16px;
  max-height: calc(100vh - 220px); overflow-y: auto;
}
#page-admin .adm-videos-right {
  flex: 1; background: var(--bg2); border-radius: 8px; padding: 16px;
  max-height: calc(100vh - 220px); overflow-y: auto;
}

/* —— 分类列表（左侧栏）—— */
#page-admin .adm-vid-cat-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px; font-weight: 600; font-size: 14px;
}
#page-admin .adm-vid-cat-list { }
#page-admin .adm-vid-cat-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px; border-radius: 6px; cursor: pointer;
  margin-bottom: 6px; transition: transform 0.2s ease, background 0.2s, opacity 0.2s;
  border: 1px solid transparent;
}
#page-admin .adm-vid-cat-row:hover {
  background: rgba(255,255,255,0.05);
}
#page-admin .adm-vid-cat-row.active {
  background: rgba(59, 130, 246, 0.15);
  border-color: #3b82f6;
}
#page-admin .adm-vid-cat-row.dragging {
  opacity: 0.4;
}
#page-admin .adm-vid-cat-row .grip {
  color: var(--text3); cursor: grab; font-size: 14px; user-select: none;
}
#page-admin .adm-vid-cat-row .grip:active {
  cursor: grabbing;
}
#page-admin .adm-vid-cat-color {
  width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
}
#page-admin .adm-vid-cat-info {
  flex: 1; min-width: 0;
}
#page-admin .adm-vid-cat-name {
  font-size: 14px; font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
#page-admin .adm-vid-cat-meta {
  font-size: 12px; color: var(--text-muted);
}
#page-admin .adm-vid-cat-actions {
  display: flex; gap: 2px; opacity: 0; transition: opacity 0.2s;
}
#page-admin .adm-vid-cat-row:hover .adm-vid-cat-actions {
  opacity: 1;
}

/* —— 图标按钮（复刻 Replay 风格：无背景、灰色、hover 变亮）—— */
#page-admin .adm-vid-icon-btn {
  width: 28px; height: 28px; background: none; border: none; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #787b86; transition: 0.15s;
  font-size: 14px; padding: 0;
}
#page-admin .adm-vid-icon-btn:hover {
  background: rgba(255,255,255,0.08); color: #d1d4dc;
}
#page-admin .adm-vid-icon-danger:hover {
  color: #ef5350;
}

/* —— 颜色选择器 —— */
#page-admin .adm-color-picker {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px;
}
#page-admin .adm-color-swatch {
  width: 32px; height: 32px; border-radius: 4px; cursor: pointer;
  border: 2px solid transparent; transition: transform 0.2s, border-color 0.2s;
}
#page-admin .adm-color-swatch:hover {
  transform: scale(1.1);
}
#page-admin .adm-color-swatch.active {
  border-color: #fff; transform: scale(1.15);
}

/* —— 视频列表（右侧主区）—— */
#page-admin .adm-vid-toolbar {
  display: flex; gap: 12px; margin-bottom: 16px;
}
#page-admin .adm-vid-toolbar input {
  flex: 1;
}
#page-admin .adm-vid-list {
  display: flex; flex-direction: column; gap: 12px;
}
#page-admin .adm-vid-row {
  display: flex; gap: 12px; padding: 12px; border-radius: 6px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
  transition: transform 0.2s ease, background 0.2s, opacity 0.2s;
}
#page-admin .adm-vid-row:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.1);
}
#page-admin .adm-vid-row.dragging {
  opacity: 0.4;
}
#page-admin .adm-vid-row .grip {
  color: var(--text3); cursor: grab; font-size: 14px; user-select: none;
  display: flex; align-items: center;
}
#page-admin .adm-vid-row .grip:active {
  cursor: grabbing;
}
#page-admin .grip-disabled {
  color: rgba(120, 123, 134, 0.3) !important;
  cursor: not-allowed !important;
}
#page-admin .adm-vid-filter-hint {
  padding: 8px 12px; margin-bottom: 12px; border-radius: 6px;
  background: rgba(243, 156, 18, 0.1); border: 1px solid rgba(243, 156, 18, 0.3);
  color: #f39c12; font-size: 12px;
}
#page-admin .adm-vid-thumb {
  width: 120px; height: 68px; object-fit: cover; border-radius: 4px; flex-shrink: 0;
}
#page-admin .adm-vid-thumb-empty {
  width: 120px; height: 68px; display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.05); color: var(--text-muted);
  font-size: 12px; border-radius: 4px; flex-shrink: 0;
}
#page-admin .adm-vid-row-info {
  flex: 1; min-width: 0;
}
#page-admin .adm-vid-row-title {
  font-weight: 500; margin-bottom: 4px;
  /* 标题不再内嵌徽章；过长截断为两行省略号，不挤压右侧列 */
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
  overflow: hidden;
}
#page-admin .adm-vid-row-meta {
  font-size: 13px; color: var(--text-muted);
}
/* 右侧列：徽章行在上、按钮行在下 */
#page-admin .adm-vid-row-side {
  flex-shrink: 0; display: flex; flex-direction: column;
  align-items: flex-end; justify-content: center; gap: 8px;
}
#page-admin .adm-vid-row-badges {
  display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; white-space: nowrap;
}
#page-admin .adm-vid-row-actions {
  display: flex; gap: 2px; align-items: center;
  opacity: 0; transition: opacity 0.2s;
}
#page-admin .adm-vid-row:hover .adm-vid-row-actions {
  opacity: 1;
}

/* —— 视频表单 —— */
#page-admin .adm-vid-form {
  padding: 20px;
}
#page-admin .adm-vid-form h3 {
  margin-top: 0; margin-bottom: 20px;
}
#page-admin .adm-vid-form label {
  display: block; margin-bottom: 16px;
  font-size: 14px; font-weight: 500;
}
#page-admin .adm-vid-form label input,
#page-admin .adm-vid-form label textarea,
#page-admin .adm-vid-form label select {
  margin-top: 6px;
}
#page-admin .adm-vid-url-group {
  display: flex; gap: 8px; margin-top: 6px;
}
#page-admin .adm-vid-url-group input {
  flex: 1;
}
#page-admin .adm-vid-url-hint {
  font-size: 12px; color: var(--text-muted);
  margin-top: 4px; font-weight: 400;
}
#page-admin .adm-field-hint {
  font-size: 12px; color: var(--text-muted);
  margin-top: 4px; font-weight: 400; font-style: italic;
}
#page-admin .adm-vid-oembed-preview {
  margin-bottom: 16px;
}
#page-admin .adm-oembed-card {
  display: flex; gap: 12px; padding: 12px;
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 6px;
}
#page-admin .adm-oembed-thumb {
  width: 160px; height: 90px; object-fit: cover; border-radius: 4px;
}
#page-admin .adm-oembed-info {
  flex: 1;
}
#page-admin .adm-oembed-title {
  font-weight: 600; margin-bottom: 4px;
}
#page-admin .adm-oembed-author {
  font-size: 13px; color: var(--text-muted); margin-bottom: 4px;
}
#page-admin .adm-oembed-hint {
  font-size: 12px; color: var(--text-muted); font-style: italic;
}
/* F2 自定义封面预览 */
#page-admin .adm-vid-thumb-preview{display:flex;align-items:center;gap:10px;margin:8px 0;padding:8px;border:1px solid #2a323d;border-radius:8px}
#page-admin .adm-vid-thumb-img{width:120px;height:68px;object-fit:cover;border-radius:6px;background:#1e2530;flex-shrink:0}
#page-admin .adm-vid-thumb-status{font-size:12px;color:var(--text-muted);flex:1}
#page-admin .adm-vid-thumb-remove{flex-shrink:0}
/* F3 批量上传面板 */
#page-admin .adm-batch-panel{max-width:620px}
#page-admin .adm-batch-queue{border:1px solid #2a323d;border-radius:8px;padding:10px;margin:10px 0}
#page-admin .adm-batch-stats{font-size:12px;color:var(--text-muted);margin-bottom:8px}
#page-admin .adm-batch-items{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto;margin-bottom:8px}
#page-admin .adm-batch-item{display:flex;align-items:center;gap:8px;font-size:12px;padding:4px 6px;border-radius:6px;background:#161b22}
#page-admin .adm-batch-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#c8d2dc}
#page-admin .adm-batch-item-size{color:#5a6675;flex-shrink:0}
#page-admin .adm-batch-item-st{flex-shrink:0;width:56px;text-align:right;color:var(--text-muted)}
#page-admin .adm-batch-item-prog{flex-shrink:0;width:90px;height:6px;background:#1e2530;border-radius:3px;overflow:hidden;display:inline-block}
#page-admin .adm-batch-item--done .adm-batch-item-st{color:#2dd4bf}
#page-admin .adm-batch-item--error .adm-batch-item-st{color:#ef5350}
#page-admin .adm-batch-item--cancelled .adm-batch-item-st{color:#eab308}
#page-admin .adm-batch-total-text{font-size:12px;color:var(--text-muted);margin-top:6px}
#page-admin .adm-batch-cleanup{font-size:12px;color:var(--text-muted);margin:8px 0}
#page-admin .adm-batch-cleanup a{color:#2dd4bf}
/* #3/#7 列表批量操作条 + 行勾选 */
#page-admin .adm-vid-batchbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:6px 8px;margin:6px 0;border:1px solid #2a323d;border-radius:8px;background:#161b22}
#page-admin .adm-vid-batchbar-all{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}
#page-admin .adm-vid-batchbar-count{font-size:12px;color:var(--text-muted);margin-right:auto}
#page-admin .adm-vid-check{flex-shrink:0;width:16px;height:16px;cursor:pointer}
#page-admin .adm-vid-form-actions {
  display: flex; gap: 12px; margin-top: 24px; padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.1);
}

/* ── Bunny Stream 视频管理 (2026-05-26) ──────────────────── */

/* Bunny 编辑态信息卡 (GUID + 状态 + 手动刷新) */
#page-admin .adm-vid-bunny-info {
  background: rgba(255, 165, 0, 0.08);
  border: 1px solid rgba(255, 165, 0, 0.3);
  border-radius: 6px;
  padding: 12px 14px;
  margin: 10px 0 16px;
  font-size: 13px;
  line-height: 1.7;
}
#page-admin .adm-vid-bunny-info code {
  background: rgba(0, 0, 0, 0.3);
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 12px;
}

/* TUS 上传进度状态条 */
#page-admin .adm-vid-upload-status {
  margin-top: 12px;
  padding: 12px;
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.3);
  border-radius: 6px;
}
#page-admin .adm-vid-upload-progress {
  width: 100%;
  height: 12px;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 8px;
}
#page-admin .adm-vid-upload-bar {
  height: 100%;
  background: linear-gradient(90deg, #3b82f6, #8b5cf6);
  width: 0%;
  transition: width 0.2s ease;
}
#page-admin .adm-vid-upload-text {
  font-size: 12.5px;
  color: var(--text2);
  margin-bottom: 8px;
  font-family: var(--font-mono, monospace);
}

/* 状态徽章颜色变体 (Bunny encoding / pending / error) */
#page-admin .adm-badge.adm-st-warn {
  background: rgba(251, 191, 36, 0.18);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.4);
}
#page-admin .adm-badge.adm-st-err {
  background: rgba(239, 68, 68, 0.18);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.4);
}

/* —— 响应式适配 —— */
@media (max-width: 768px) {
  #page-admin .adm-videos-layout {
    flex-direction: column;
  }
  #page-admin .adm-videos-left {
    width: 100%; max-height: 300px;
  }
  #page-admin .adm-videos-right {
    max-height: calc(100vh - 550px);
  }
}

/* —— 全站红条（GLOBAL：不在 #page-admin 内，body 顶层）—— */
#tj-sysnotice-bar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 2147483600;            /* 高于一切（含 modal）；公告是最高优先级提示 */
  display: flex; align-items: center; justify-content: center; gap: 9px;
  /* 2026-06-07: 参考"回放浏览模式横幅"的高级感 — 半透明同色底 + 同色亮字 + 细底边 + 字间距 */
  padding: 9px 18px; font-size: 13px; font-weight: 600; letter-spacing: 1px;
  box-shadow: 0 2px 12px rgba(0,0,0,.3);
  animation: tjSysNoticeIn .25s ease;
}
@keyframes tjSysNoticeIn { from { transform: translateY(-100%); } to { transform: translateY(0); } }
/* 2026-06-07: 图标固定 18px 盒 + 右侧等宽幻影(::after) 对称抵消 → 正文真正水平居中
   （原 [图标][正文] 整组居中，正文被图标占位推右约半个图标宽，短文本时"首字居中、整体偏右"） */
#tj-sysnotice-bar .tj-sysnotice-ico { font-size: 15px; flex: 0 0 18px; text-align: center; }
#tj-sysnotice-bar::after { content: ''; flex: 0 0 18px; }
#tj-sysnotice-bar .tj-sysnotice-body {
  line-height: 1.4; text-align: center;
  max-width: calc(100% - 60px);
  overflow: hidden; text-overflow: ellipsis;
}
/* 2026-06-07: 半透明同色底 + 亮色字 + 细底边（图标/正文 inherit 同色，统一高级质感，仿回放浏览模式横幅） */
.tj-sysnotice-info     { background: rgba(33,118,209,0.14); color: #5aa2ec; border-bottom: 1px solid rgba(33,118,209,0.5); }
.tj-sysnotice-warn     { background: rgba(243,156,18,0.13); color: #f39c12; border-bottom: 1px solid rgba(243,156,18,0.5); }
.tj-sysnotice-critical { background: rgba(229,57,53,0.15);  color: #ef5350; border-bottom: 1px solid rgba(229,57,53,0.55); }

@media (max-width: 860px) {
  #page-admin .adm-rank-wrap { grid-template-columns: 1fr; }
  #page-admin .adm-cards { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); }
  #tj-sysnotice-bar { font-size: 12.5px; padding: 8px 12px; }
}

/* ============================================================
 * 阶段②播报图片（追加段，2026-05-20）
 * 收敛在 #page-broadcast 作用域 + 全局 .bc-lightbox（仅 fixed 全屏蒙层）
 * ============================================================ */
#page-broadcast .img-btn{
  background:transparent;border:1px solid var(--border);color:var(--text2);
  border-radius:6px;padding:0 8px;cursor:pointer;font-size:16px;line-height:1;
  flex-shrink:0;height:32px;align-self:flex-end;margin-bottom:0
}
#page-broadcast .img-btn:hover{color:var(--accent);border-color:var(--accent)}
#page-broadcast #bc-composer.drag-over{
  outline:2px dashed var(--accent);outline-offset:-2px;
  background:rgba(230,126,34,0.06)
}
#page-broadcast .img-preview{
  display:flex;align-items:center;gap:10px;margin-top:8px;padding:8px;
  border:1px solid var(--border);border-radius:6px;background:var(--bg2)
}
#page-broadcast .img-preview .ip-thumb{
  flex:0 0 60px;width:60px;height:60px;
  min-width:0;min-height:0;
  border-radius:4px;overflow:hidden;background:var(--bg);
  display:flex;align-items:center;justify-content:center
}
#page-broadcast .img-preview .ip-thumb img{
  width:60px;height:60px;
  max-width:60px;max-height:60px;
  object-fit:cover;display:block
}
#page-broadcast .img-preview .ip-info{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:4px
}
#page-broadcast .img-preview .ip-name{
  font-size:12px;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
#page-broadcast .img-preview .ip-status{font-size:11px;color:var(--text2)}
#page-broadcast .img-preview .ip-status.ok{color:#27ae60}
#page-broadcast .img-preview .ip-status.err{color:#e74c3c}
#page-broadcast .img-preview .ip-retry{
  background:transparent;border:1px solid var(--accent);color:var(--accent);
  font-size:11px;padding:2px 8px;border-radius:4px;cursor:pointer;margin-left:8px
}
#page-broadcast .img-preview .ip-retry:hover{background:rgba(230,126,34,0.12)}
#page-broadcast .img-preview .ip-x{
  flex-shrink:0;
  background:transparent;border:none;color:var(--text2);
  font-size:18px;cursor:pointer;padding:0 4px;line-height:1
}
#page-broadcast .img-preview .ip-x:hover{color:#e74c3c}
#page-broadcast .msg .mimg{
  margin-top:6px;
  width:fit-content;max-width:240px
}
#page-broadcast .msg .mimg img{
  width:auto;height:auto;
  max-width:240px;max-height:160px;
  border-radius:6px;border:1px solid var(--border);
  cursor:zoom-in;display:block;background:var(--bg);
  object-fit:contain
}
#page-broadcast .msg .mimg img:hover{opacity:0.92;border-color:var(--accent)}

/* lightbox：全屏蒙层，DOM 挂在 document.body，不在 #page-broadcast 内 */
.bc-lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:9999;
  display:flex;align-items:center;justify-content:center;
  cursor:zoom-out;animation:bc-lbIn 0.18s ease-out
}
@keyframes bc-lbIn{from{opacity:0}to{opacity:1}}
.bc-lightbox .bc-lb-img{
  max-width:95vw;max-height:95vh;display:block;cursor:default;
  box-shadow:0 8px 40px rgba(0,0,0,0.5);border-radius:4px
}
.bc-lightbox .bc-lb-x{
  position:fixed;top:20px;right:24px;width:40px;height:40px;
  border-radius:50%;background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.3);color:#fff;
  font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center
}
.bc-lightbox .bc-lb-x:hover{background:rgba(255,255,255,0.2)}

/* ── ADMIN-ONLY-PREVIEW: 第一阶段未上线功能,仅 admin 可见 ──
   (2026-05-21 UI 改版新增。将来某功能正式上线时,从对应
   HTML 元素的 class 列表中删除 admin-only-preview 即可。)
   注意：CSS 选择器顺序在文件末尾，权重高于通用 .nav-item 默认显示规则。 */
body:not(.role-admin) .admin-only-preview{display:none !important}

/* ── 期3 developer 分级: 顶栏 4 tab(交易日志/数据统计/深度研报/交易者画像) + Settings
   仅 developer 可见,admin 级与普通用户都不显示(这些功能开发中)。
   注意(LL-X1): 这些项挂 admin-only(-preview),对 role-admin 有 !important 显示规则
   (style.css:159 #topnav .nav-item.admin-only flex / :3632 .admin-only revert)。故必须
   用 id + 足够 specificity 压过它:每条 = (0,1,3~4,1) > 竞争的 (0,1,3,1)。
   只点这 5 个 id, 不含 #nav-admin(管理后台 sub-admin 保留可见)。
   真机需以 sub-admin 账号 getComputedStyle 实测 5 项 display==='none' 且 nav-admin 可见。 */
body.role-admin:not(.role-developer) #nav-daily.nav-item,
body.role-admin:not(.role-developer) #nav-stats.nav-item,
body.role-admin:not(.role-developer) #nav-report.nav-item,
body.role-admin:not(.role-developer) #nav-persona.nav-item,
body.role-admin:not(.role-developer) #nav-settings.nav-item.admin-only{display:none !important}

/* 期3: 用户下拉菜单里的 admin-only 项(调试·模拟版本视角 / 浅色主题 / English导航)
   也仅 developer 可见, sub-admin 隐藏。(0,1,5,1) 压过 style.css:161 的 flex !important。 */
body.role-admin:not(.role-developer) #topnav .tn-menu .tn-menu-item.admin-only{display:none !important}

/* ============================================================
 * 2026-05-21 播报 / 答疑 工具栏重构 (UI v2)
 *   - 播报: 删除原 .page-header 大标题, 改为 44px 工具栏 + 单独的 tip-row
 *   - 答疑: 工具栏化, 卡片内 padding 收紧对齐播报卡片密度
 *   - 两者 chip 字号 / padding / 圆角 完全一致 (各写各的 class, 不抽公共类)
 * ============================================================ */

/* ── 播报工具栏 ── */
#page-broadcast .bc-toolbar {
  flex-shrink:0; display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:0 20px; height:44px;
  background:var(--bg2); border-bottom:1px solid var(--border);
}
#page-broadcast .bc-toolbar-left  {
  display:flex; align-items:center; gap:8px; flex:1; min-width:0;
  overflow-x:auto;
  scrollbar-width:none;  /* Firefox: 隐藏横向滚动条 */
}
#page-broadcast .bc-toolbar-left::-webkit-scrollbar { display:none; }
#page-broadcast .bc-toolbar-right {
  display:flex; align-items:center; gap:10px; flex-shrink:0;
}

/* 2026-05-21 重构: .cat-bar 在新工具栏内重置 (覆盖旧规则的 padding/border-bottom/background) */
#page-broadcast .bc-toolbar .cat-bar {
  padding:0; border-bottom:none; background:transparent;
  flex-wrap:nowrap; gap:8px;
}

/* ── 播报 cat-chip 视觉重写 (与答疑 qa-cat-chip 数值完全相同) ── */
#page-broadcast .cat-chip {
  font-family:'Space Grotesk','Microsoft YaHei',sans-serif;
  font-size:12px; color:var(--text2); background:transparent;
  border:1px solid var(--border); border-radius:6px;
  padding:5px 12px; cursor:pointer; transition:all .15s;
  display:inline-flex; align-items:center; gap:6px;
  user-select:none; white-space:nowrap; line-height:1.4;
  letter-spacing:0.2px; font-weight:500;
}
#page-broadcast .cat-chip:hover { color:var(--text); border-color:var(--text3); background:transparent; }
#page-broadcast .cat-chip.on    {
  color:var(--accent); border-color:var(--accent); background:rgba(230,126,34,0.08);
  font-weight:500;  /* 2026-05-22 修(§12-4): 显式压制旧规则 .cat-chip.on{font-weight:700}, 与答疑 .qa-cat-chip.active 字重对齐 */
}
#page-broadcast .cat-chip .cdot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
#page-broadcast .cat-chip.all   { padding:5px 14px; border-style:solid; }  /* "全部" 无圆点, 稍宽; 强制实线覆盖旧 dashed */
#page-broadcast .cat-chip.all.on {
  background:rgba(230,126,34,0.08); border-color:var(--accent); color:var(--accent);
}
/* 取消旧规则在 on 状态下给圆点加的白圈光晕 (新视觉下不和谐) */
#page-broadcast .cat-chip.on .cdot { box-shadow:none; }
#page-broadcast .cat-chip .tier-mini {
  font-family:var(--font-mono); font-size:9px; color:var(--text3);
  margin-left:2px; opacity:0.7;
}
/* 工具栏内的 admin 齿轮按钮: 保留旧的圆形 + hover 旋转风格,
   只把尺寸从 30x30 缩到 26x26 配合 44px 工具栏 (3px*2 留呼吸) */
#page-broadcast .bc-toolbar .gear-btn {
  width:26px; height:26px; font-size:13px;
}

/* ── 播报工具栏右段: 连接状态 / 日历 / 回到今天 ── */
/* live-pill 改成小灰点 + 灰字, 所有人可见, 点闪烁 */
#page-broadcast .bc-toolbar .live-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:1px;
  text-transform:uppercase; color:var(--text3);
  border:none; background:transparent; padding:0;
}
#page-broadcast .bc-toolbar .live-pill.history { color:var(--text3); }
#page-broadcast .bc-toolbar .live-dot {
  width:6px; height:6px; border-radius:50%; background:var(--text2);
  animation:bc-livePulse 1.6s ease-in-out infinite;
}
#page-broadcast .bc-toolbar .live-pill.history .live-dot {
  background:var(--text3); animation:none;
}
@keyframes bc-livePulse {
  0%, 100% { opacity:0.35; }
  50%      { opacity:1; }
}

#page-broadcast .bc-toolbar .datepick {
  display:flex; align-items:center; gap:6px;
}
#page-broadcast .bc-toolbar .date-trigger {
  display:inline-flex; align-items:center; gap:6px;
  background:transparent; border:1px solid var(--border);
  border-radius:6px; padding:4px 10px;
  color:var(--text2); font-family:var(--font-mono); font-size:11px;
  cursor:pointer; transition:all .15s; position:relative;
  user-select:none;
}
#page-broadcast .bc-toolbar .date-trigger:hover { color:var(--text); border-color:var(--text3); }
#page-broadcast .bc-toolbar .date-trigger .date-label { letter-spacing:0.5px; }
#page-broadcast .bc-toolbar .date-trigger input[type=date] {
  position:absolute; inset:0; width:100%; height:100%;
  opacity:0; border:none; padding:0; margin:0; cursor:pointer;
}
#page-broadcast .bc-toolbar .today-btn {
  background:transparent; border:1px solid var(--border);
  color:var(--text2); font-family:'Space Grotesk','Microsoft YaHei',sans-serif;
  font-size:11px; letter-spacing:0.3px;
  padding:4px 10px; border-radius:6px; cursor:pointer;
  transition:all .15s;
}
#page-broadcast .bc-toolbar .today-btn:hover { color:var(--accent); border-color:var(--accent); }

/* ── 播报今日提示行 (单独一行, 淡化样式) ── */
#page-broadcast .bc-tip-row {
  flex-shrink:0; display:flex; align-items:center; gap:10px;
  padding:7px 20px; background:rgba(230,126,34,0.04);
  border-bottom:1px solid var(--border);
  font-size:12px;
}
#page-broadcast .bc-tip-row .tip-tag {
  font-family:var(--font-mono); font-size:10px; letter-spacing:1.2px;
  color:var(--accent); font-weight:600; white-space:nowrap;
  text-transform:none;
}
#page-broadcast .bc-tip-row .tip-body {
  flex:1; color:var(--text2); min-width:0; line-height:1.5;
}
#page-broadcast .bc-tip-row .tip-body.empty { color:var(--text3); font-style:italic; }
#page-broadcast .bc-tip-row .tip-edit {
  background:transparent; border:1px solid var(--border); color:var(--text2);
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.8px;
  padding:3px 9px; border-radius:4px; cursor:pointer;
  white-space:nowrap; flex-shrink:0; transition:all .15s;
}
#page-broadcast .bc-tip-row .tip-edit:hover { color:var(--accent); border-color:var(--accent); }
#page-broadcast .bc-tip-row input {
  flex:1; background:rgba(255,255,255,0.04); border:1px solid var(--border);
  border-radius:5px; color:var(--text); font-size:12px;
  padding:5px 10px; font-family:inherit; outline:none;
}

/* ============================================================
 * 答疑工具栏 + 卡片密度收紧
 * ============================================================ */
#page-qa .qa-toolbar {
  flex-shrink:0; display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:0 20px; height:44px;
  background:var(--bg2); border-bottom:1px solid var(--border);
}
#page-qa .qa-toolbar-left  {
  display:flex; align-items:center; gap:8px; flex:1; min-width:0;
  overflow-x:auto;
  scrollbar-width:none;
}
#page-qa .qa-toolbar-left::-webkit-scrollbar { display:none; }
#page-qa .qa-toolbar-right {
  display:flex; align-items:center; gap:10px; flex-shrink:0;
}

/* ── QA 答疑 - Admin 分类管理拖拽 ── */
#qa-cat-list .qa-cat-row {
  transition: transform 0.2s ease, opacity 0.2s ease;
}
#qa-cat-list .qa-cat-row .grip {
  color: var(--text3); cursor: grab; font-size: 14px; user-select: none;
}
#qa-cat-list .qa-cat-row .grip:active {
  cursor: grabbing;
}
#qa-cat-list .qa-cat-row.dragging {
  opacity: 0.4;
}

/* ============================================================
 * 市场分析上传 — 月历 + 抽屉（admin 后台 v5.5.1 任务）
 * 收敛到 #page-admin 作用域防撞主程序
 * ============================================================ */
#page-admin .adm-cal-wrap {
  display: flex; flex-direction: column; gap: 14px;
}
#page-admin .adm-cal-header {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
}
#page-admin .adm-cal-nav {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
#page-admin .adm-cal-title {
  font-size: 15px; font-weight: 600; color: var(--text);
  font-family: var(--font-mono, monospace);
  min-width: 120px; text-align: center;
}
#page-admin .adm-cal-tip {
  font-size: 11px; color: var(--text3);
  letter-spacing: .3px;
}
#page-admin .adm-cal-msg {
  min-height: 18px; font-size: 12px;
  color: var(--text2);
}
#page-admin .adm-cal-msg--warn { color: var(--accent, #f0b400); }
#page-admin .adm-cal-msg--err  { color: #ef5350; }
#page-admin .adm-cal-msg--ok   { color: #4caf50; }

#page-admin .adm-cal-grid-weekdays,
#page-admin .adm-cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px;
}
#page-admin .adm-cal-grid-weekdays > div {
  text-align: center; font-size: 11px; color: var(--text2);
  padding: 4px 0;
}
#page-admin .adm-cal-cell {
  min-height: 96px;
  border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg2);
  padding: 10px 12px;
  display: flex; flex-direction: column; justify-content: space-between;
  cursor: pointer; user-select: none;
  transition: transform .12s, border-color .12s;
}
#page-admin .adm-cal-cell:hover {
  border-color: var(--accent); transform: translateY(-1px);
}
#page-admin .adm-cal-cell--empty {
  background: transparent; border: 1px dashed var(--border);
  cursor: default;
}
#page-admin .adm-cal-cell--empty:hover {
  border-color: var(--border); transform: none;
}
/* （旧 today outline 已废，今日样式见 today 角标段落，避免与 active 冲突）*/
#page-admin .adm-cal-cell-day {
  font-size: 14px; font-weight: 600; color: var(--text);
  font-family: var(--font-mono, monospace);
}
#page-admin .adm-cal-cell-bars {
  font-size: 10px; color: var(--text2);
  font-family: var(--font-mono, monospace);
}
#page-admin .adm-cal-cell-bars--empty { color: var(--text3); }

/* 状态色（与 legend dot 共用） */
#page-admin .adm-cal-cell--published {
  background: rgba(76, 175, 80, .12);
  border-color: rgba(76, 175, 80, .35);
}
#page-admin .adm-cal-cell--draft {
  background: rgba(240, 180, 0, .12);
  border-color: rgba(240, 180, 0, .35);
}
#page-admin .adm-cal-cell--retracted {
  background: rgba(239, 83, 80, .10);
  border-color: rgba(239, 83, 80, .30);
}
#page-admin .adm-cal-cell--none {
  background: var(--bg2);
  border-color: var(--border);
}
/* 今日：左上角小角标，不抢边框 */
#page-admin .adm-cal-cell--today {
  outline: none;
}
#page-admin .adm-cal-cell--today::after {
  content: '今';
  position: absolute; top: 4px; right: 6px;
  font-size: 9px; font-weight: 700; letter-spacing: 1px;
  color: var(--accent); opacity: .85;
  pointer-events: none;
}
#page-admin .adm-cal-cell { position: relative; }

/* 当前选中格子（抽屉打开时高亮）：用粗实线边框，跟今日角标完全分开 */
#page-admin .adm-cal-cell--active {
  border-color: var(--accent) !important;
  border-width: 2px !important;
  padding: 9px 11px;   /* 边框 +1px 时补偿 padding 防内容跳动 */
  box-shadow: 0 0 0 2px rgba(230, 126, 34, .18);
}

/* ---- 抽屉（嵌入式，月历下方展开） ---- */
#page-admin .adm-cal-drawer {
  margin-top: 16px;
  border: 1px solid var(--border); border-radius: 10px;
  background: var(--bg2); padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
}
#page-admin .adm-cal-drawer-err {
  color: #ef5350; padding: 12px; font-size: 12px;
}
#page-admin .adm-cal-drawer-head {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 10px;
}
#page-admin .adm-cal-drawer-title {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
#page-admin .adm-cal-drawer-date {
  font-family: var(--font-mono, monospace);
  font-size: 16px; font-weight: 600; color: var(--text);
}
#page-admin .adm-cal-drawer-symbol {
  font-family: var(--font-mono, monospace);
  font-size: 12px; color: var(--text2);
  padding: 2px 8px; background: var(--bg3); border-radius: 4px;
}
#page-admin .adm-cal-status-badge {
  font-size: 11px; padding: 3px 10px; border-radius: 12px;
  letter-spacing: .5px; font-weight: 600;
}
#page-admin .adm-cal-status-published {
  background: rgba(76, 175, 80, .18); color: #66bb6a;
}
#page-admin .adm-cal-status-draft {
  background: rgba(240, 180, 0, .18); color: #f0b400;
}
#page-admin .adm-cal-status-retracted {
  background: rgba(239, 83, 80, .15); color: #ef5350;
}
#page-admin .adm-cal-status-none {
  background: var(--bg3); color: var(--text3);
}

#page-admin .adm-cal-meta-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 6px 16px; font-size: 12px;
  padding: 10px 12px; background: var(--bg); border-radius: 8px;
  border: 1px solid var(--border);
}
#page-admin .adm-cal-meta-row {
  display: flex; gap: 8px; align-items: center;
}
#page-admin .adm-cal-meta-k {
  color: var(--text2); min-width: 64px;
}
#page-admin .adm-cal-meta-v {
  color: var(--text); font-family: var(--font-mono, monospace);
}

#page-admin .adm-cal-actions {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
#page-admin .adm-cal-actions label.adm-btn { cursor: pointer; }

/* 拖拽放置区（包按钮组 + 提示文字） */
#page-admin .adm-cal-dropzone {
  border: 2px dashed var(--border); border-radius: 10px;
  padding: 20px 18px;
  background: var(--bg);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  transition: border-color .15s, background .15s;
}
#page-admin .adm-cal-dropzone--over {
  border-color: var(--accent);
  background: rgba(230, 126, 34, .06);
}
#page-admin .adm-cal-dropzone-icon {
  font-size: 24px; opacity: .7;
}
#page-admin .adm-cal-dropzone-hint {
  font-size: 12px; color: var(--text2);
  text-align: center;
}

/* 危险操作区（独立于上传区，避免误触） */
#page-admin .adm-cal-danger-zone {
  margin-top: 8px;
  padding: 10px 14px;
  border: 1px solid rgba(239, 83, 80, .25);
  border-radius: 8px;
  background: rgba(239, 83, 80, .04);
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
}
#page-admin .adm-cal-danger-hint {
  font-size: 11px; color: #ef5350;
  letter-spacing: .3px;
}
#page-admin .adm-cal-upload-msg {
  font-size: 12px; color: var(--text2); margin-left: 4px;
}
#page-admin .adm-cal-upload-msg--warn { color: #f0b400; }
#page-admin .adm-cal-upload-msg--err  { color: #ef5350; }
#page-admin .adm-cal-upload-msg--ok   { color: #66bb6a; }

#page-admin .adm-cal-preview-wrap {
  border: 1px solid var(--border); border-radius: 8px;
  overflow-x: auto; max-height: 360px; overflow-y: auto;
}
#page-admin .adm-cal-preview {
  width: 100%; border-collapse: collapse;
  font-size: 12px; min-width: 600px;
}
#page-admin .adm-cal-preview thead th {
  position: sticky; top: 0; background: var(--bg2);
  color: var(--text2); font-weight: 600; text-align: left;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
}
#page-admin .adm-cal-preview tbody td {
  padding: 7px 12px; border-bottom: 1px solid var(--border);
  color: var(--text);
}
#page-admin .adm-cal-preview tbody tr:last-child td { border-bottom: none; }
#page-admin .adm-cal-prev-time {
  font-family: var(--font-mono, monospace);
  white-space: nowrap; color: var(--text);
}
#page-admin .adm-cal-prev-label { white-space: nowrap; }
#page-admin .adm-cal-prev-note { color: var(--text2); }
#page-admin .adm-cal-label-chip {
  display: inline-block; padding: 2px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 600;
  background: rgba(100, 149, 237, .15);
  color: cornflowerblue;
}
#page-admin .adm-cal-label-empty { color: var(--text3); }
#page-admin .adm-cal-prev-more {
  text-align: center; padding: 8px; font-size: 11px;
  color: var(--text3);
}
#page-admin .adm-cal-preview-empty {
  padding: 36px 16px; text-align: center;
  font-size: 12px; color: var(--text2);
  border: 1px dashed var(--border); border-radius: 8px;
}

/* ============================================================
 * plan v3 付款体系（2026-05-26 起，HANDOVER §5.1）
 *   - tier=0 隔离付费门 / T4 占位 / Trial 顶栏黄条 / past_due 红条
 *   - payment-success / 订阅管理 / 邀请码 section / 月年 toggle
 * 复用 #landing-screen .pcard 4 卡布局（已存在），本块只补"plan v3 新增"
 * ============================================================ */

/* ── tier-0 隔离付费门：T0 用户看不到任何标 feature-requires-paid 的入口 ── */
.feature-requires-paid { /* 默认显示，靠 body.tier-0 隐藏 */ }
body.tier-0 .feature-requires-paid { display: none !important; }
/* 封禁也隐藏 */
body.is-banned .feature-requires-paid { display: none !important; }

/* ── T4 占位锁标：T4/admin 解锁，其余档显示锁标 ── */
.feature-locked-t4 {
  opacity: 0.55;
  position: relative;
}
.feature-locked-t4::after {
  content: '';
  display: inline-block;
  width: 0.9em; height: 0.9em;
  margin-left: 4px;
  vertical-align: -1px;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d4a04a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
}
body.tier-4 .feature-locked-t4,
body.role-admin .feature-locked-t4 { opacity: 1; }
body.tier-4 .feature-locked-t4::after,
body.role-admin .feature-locked-t4::after { display: none; }
body.is-banned .feature-locked-t4 { display: none !important; }

/* ── Trial 期顶栏黄条（UX1）── */
.trial-expiring-banner {
  display: none;
  padding: 10px 20px;
  background: rgba(243, 156, 18, 0.12);
  border-bottom: 1px solid rgba(243, 156, 18, 0.4);
  color: var(--text);
  font-size: 13px;
  text-align: center;
  line-height: 1.5;
}
.trial-expiring-banner .trial-remaining-days { font-weight: 700; color: var(--accent); }
.trial-expiring-banner a { color: var(--accent); text-decoration: underline; margin-left: 6px; cursor: pointer; }
body.is-trial .trial-expiring-banner { display: block; }

/* ── past_due 顶栏红条（C1 + UX4）── */
.past-due-banner {
  display: none;
  padding: 10px 20px;
  background: rgba(231, 76, 60, 0.12);
  border-bottom: 1px solid rgba(231, 76, 60, 0.4);
  color: var(--text);
  font-size: 13px;
  text-align: center;
  line-height: 1.5;
}
.past-due-banner .past-due-days-left { font-weight: 700; color: #e74c3c; }
.past-due-banner a { color: #e74c3c; text-decoration: underline; margin-left: 6px; cursor: pointer; }
body.is-past-due .past-due-banner { display: block; }

/* ── payment-success toast section（UX2 + UX6）── */
#payment-success {
  position: fixed; inset: 0;
  display: none;
  align-items: center; justify-content: center;
  background: rgba(0, 0, 0, 0.55);
  z-index: 99998;
}
#payment-success.is-shown { display: flex; }
.payment-success-toast {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 36px 44px;
  max-width: 420px;
  text-align: center;
  box-shadow: 0 18px 40px rgba(0,0,0,0.5);
}
.payment-success-toast h2 {
  margin: 0 0 12px;
  font-size: 22px;
  color: var(--accent);
}
.payment-success-toast p { margin: 0; color: var(--text2); font-size: 14px; line-height: 1.6; }
.payment-success-toast .ps-spinner {
  display: inline-block; width: 14px; height: 14px;
  border: 2px solid var(--border); border-top-color: var(--accent);
  border-radius: 50%;
  animation: ps-spin 0.7s linear infinite;
  margin-right: 6px; vertical-align: -2px;
}
@keyframes ps-spin { to { transform: rotate(360deg); } }

/* ── Settings「订阅管理」section（C2 + UX6）── */
.subscription-management {
  margin-bottom: 24px;
  padding: 18px 20px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
}
.subscription-management h3 {
  margin: 0 0 14px;
  font-size: 15px;
  color: var(--text);
  font-weight: 600;
}
.subscription-management .current-sub-info {
  background: var(--bg3);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 14px;
  font-size: 13px;
  line-height: 1.8;
  color: var(--text2);
}
.subscription-management .current-sub-info span[data-bind] { color: var(--text); font-weight: 500; }
.subscription-management .sub-actions {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.sub-action-btn {
  padding: 9px 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
}
.sub-action-btn:hover { border-color: var(--accent); color: var(--accent); }
.sub-action-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.sub-action-btn.primary:hover { background: var(--accent2); }
.sub-action-btn.danger { color: #e74c3c; border-color: rgba(231,76,60,0.3); }
.sub-action-btn.danger:hover { background: rgba(231,76,60,0.08); border-color: #e74c3c; }
.subscription-management .sub-cancel-note {
  margin-top: 10px;
  font-size: 11.5px;
  color: var(--text3);
  line-height: 1.5;
}

/* ── Settings「我的邀请码」section（M1 + UX）── */
.referral-section {
  display: none;
  margin-bottom: 24px;
  padding: 18px 20px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
}
body.is-paid-member .referral-section { display: block; }
.referral-section h3 {
  margin: 0 0 14px;
  font-size: 15px;
  color: var(--text);
  font-weight: 600;
}
.referral-section .referral-code-display {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg3);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 12px;
}
.referral-section code {
  flex: 1;
  font-family: var(--font-mono, monospace);
  font-size: 16px;
  color: var(--accent);
  letter-spacing: 1px;
  font-weight: 600;
}
.referral-section .btn-copy-code {
  padding: 6px 12px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
}
.referral-section .btn-copy-code:hover { background: var(--accent2); }
.referral-section .referral-tip {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.6;
  margin: 0 0 16px;
}
.referral-section h4 {
  margin: 14px 0 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
}
.referral-section ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 12.5px;
}
.referral-section li {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  display: flex; justify-content: space-between; gap: 10px;
  color: var(--text2);
}
.referral-section li:last-child { border-bottom: none; }
.referral-section .ref-status-paid { color: #2ecc71; font-weight: 500; }
.referral-section .ref-status-pending { color: var(--accent2); font-weight: 500; }

/* ── 月年付 toggle（定价页用，跨 landing 与登录后页面）── */
.pricing-toggle {
  display: inline-flex;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px;
  margin: 0 auto 28px;
  gap: 0;
}
.pricing-toggle button {
  padding: 8px 22px;
  background: transparent;
  border: none;
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 999px;
  transition: all 0.15s;
}
.pricing-toggle button.active {
  background: var(--accent);
  color: #fff;
}
.pricing-toggle .save-badge {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  background: rgba(46, 204, 113, 0.15);
  color: #2ecc71;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 600;
}
.pricing-toggle button.active .save-badge {
  background: rgba(255,255,255,0.2);
  color: #fff;
}

/* ── 移动端响应式（plan v3 §5.4）── */
@media (max-width: 768px) {
  .subscription-management .sub-actions { flex-direction: column; }
  .sub-action-btn { width: 100%; }
  .referral-section .referral-code-display { flex-direction: column; align-items: stretch; }
  .referral-section .btn-copy-code { width: 100%; }
  .pricing-toggle { width: 100%; justify-content: center; }
  .pricing-toggle button { flex: 1; }
  .trial-expiring-banner,
  .past-due-banner { padding: 8px 12px; font-size: 12px; }
  .payment-success-toast { padding: 28px 24px; max-width: 90%; }
}

/* 2026-06-02 admin 首页交易日历 UI 重做：真周历网格 + 休市标记（landing 同色系） */
#page-admin .adm-lc-monthbar { display: flex; align-items: center; gap: 12px; margin: 12px 0 10px; }
#page-admin .adm-lc-monthbar b { font-family: var(--font-base); font-size: 15px; }

#page-admin .adm-lc-cal { display: flex; flex-direction: column; gap: 8px; }
#page-admin .adm-lc-head,
#page-admin .adm-lc-week {
  display: grid;
  grid-template-columns: repeat(5, 1fr) 0.62fr;
  gap: 8px;
}
#page-admin .adm-lc-head > div {
  text-align: center; font-size: 12px; color: var(--text2);
  font-family: var(--font-base); padding-bottom: 2px; letter-spacing: 1px;
}
#page-admin .adm-lc-head-tot { color: var(--text3) !important; }

#page-admin .adm-lc-cell {
  position: relative;
  background: #161b24;
  border: 1px solid #2a3340;
  border-radius: 8px;
  padding: 7px 8px;
  display: flex; flex-direction: column; gap: 6px;
  min-height: 86px;
}
#page-admin .adm-lc-empty { background: transparent; border: 1px dashed #232a34; min-height: 86px; }
#page-admin .adm-lc-cell-day {
  font-size: 12px; font-weight: 600; color: var(--text2); font-family: var(--font-base);
}
#page-admin .adm-lc-input { width: 100%; padding: 4px 6px; font-size: 13px; }
#page-admin .adm-lc-cell-actions { display: flex; gap: 4px; margin-top: auto; }
#page-admin .adm-lc-cell-actions .adm-btn-sm { flex: 1; padding: 3px 0; font-size: 11px; min-width: 0; }

/* 盈亏配色：淡底 + 边框 + 日期着色 */
#page-admin .adm-lc-pos { background: #11241e; border-color: #2fb98d44; }
#page-admin .adm-lc-neg { background: #271617; border-color: #f0625d44; }
#page-admin .adm-lc-pos .adm-lc-cell-day { color: #2fb98d; }
#page-admin .adm-lc-neg .adm-lc-cell-day { color: #f0625d; }

/* 休市/无交易：灰底 + 对角斜杠划掉 */
#page-admin .adm-lc-closed { background: #13171f; border-color: #2f3744; }
#page-admin .adm-lc-closed::after {
  content: ''; position: absolute; inset: 0; border-radius: 8px; pointer-events: none;
  background: linear-gradient(to top right, transparent calc(50% - 1px), #3f4856 calc(50% - 1px), #3f4856 calc(50% + 1px), transparent calc(50% + 1px));
}
#page-admin .adm-lc-closed .adm-lc-cell-day { color: #5a6573; text-decoration: line-through; }
#page-admin .adm-lc-closed-tag {
  flex: 1; display: flex; align-items: center; justify-content: center;
  color: #7a8694; font-size: 13px; font-family: var(--font-base); letter-spacing: 2px;
}
#page-admin .adm-lc-closed .adm-lc-cell-actions { position: relative; z-index: 1; }

/* 周计列 */
#page-admin .adm-lc-tot {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
  background: #12161e; border: 1px solid #232b36; border-radius: 8px; padding: 6px;
}
#page-admin .adm-lc-tot-lbl { font-size: 11px; color: var(--text3); font-family: var(--font-base); }
#page-admin .adm-lc-tot-val { font-size: 14px; font-weight: 700; color: var(--text2); }
#page-admin .adm-lc-tot.adm-lc-pos { background: #11241e; }
#page-admin .adm-lc-tot.adm-lc-neg { background: #271617; }
#page-admin .adm-lc-tot.adm-lc-pos .adm-lc-tot-val { color: #2fb98d; }
#page-admin .adm-lc-tot.adm-lc-neg .adm-lc-tot-val { color: #f0625d; }

#page-admin .adm-empty { color: var(--text3); padding: 20px; text-align: center; font-family: var(--font-base); }

/* 年化预览：stat 卡片排 */
#page-admin .adm-lc-annual { display: flex; flex-wrap: wrap; gap: 10px; }
#page-admin .adm-lc-stat {
  flex: 1; min-width: 128px;
  background: #12161e; border: 1px solid #232b36; border-radius: 8px; padding: 10px 13px;
}
#page-admin .adm-lc-stat-lbl { font-size: 11px; color: var(--text3); font-family: var(--font-base); margin-bottom: 5px; letter-spacing: .5px; }
#page-admin .adm-lc-stat-val { font-size: 18px; font-weight: 700; color: var(--text); font-family: var(--font-base); line-height: 1.1; }
#page-admin .adm-lc-stat-unit { font-size: 12px; font-weight: 500; color: var(--text2); }
#page-admin .adm-lc-stat.big { background: linear-gradient(135deg, #15202a, #12161e); border-color: #2a3744; }
#page-admin .adm-lc-stat.big .adm-lc-stat-val { font-size: 23px; }
#page-admin .adm-lc-stat-val.pos { color: #2fb98d; }
#page-admin .adm-lc-stat-val.neg { color: #f0625d; }
#page-admin .adm-lc-annual-note { font-size: 11px; color: var(--text3); margin-top: 8px; font-family: var(--font-base); }
#page-admin .adm-lc-annual-empty { font-size: 12px; color: var(--text2); font-family: var(--font-base); }
