/* ============================================================
   盈亏追踪 PnL Tracker v2 — 暗夜盘面美学
   ============================================================ */
:root{
  --bg:#0a0e14;
  --bg-2:#0d1320;
  --card:#101726;
  --card-2:#131c2e;
  --line:#1b2536;
  --line-2:#26334a;
  --text:#dde5f2;
  --dim:#8b97ae;
  --faint:#5b6680;
  --green:#00d68f;
  --red:#ff4d5e;
  --gold:#e8b34b;
  --green-soft:rgba(0,214,143,.12);
  --red-soft:rgba(255,77,94,.12);
  --gold-soft:rgba(232,179,75,.14);
  --glow-green:0 0 22px rgba(0,214,143,.35);
  --glow-red:0 0 22px rgba(255,77,94,.35);
  --glow-gold:0 0 16px rgba(232,179,75,.35);
  --sans:'Segoe UI','PingFang SC','Microsoft YaHei',system-ui,-apple-system,sans-serif;
  --mono:'Cascadia Mono','SF Mono',Consolas,'Courier New',monospace;
  --radius:14px;
  --radius-s:10px;
  --tab-h:58px;
  --safe-t:env(safe-area-inset-top,0px);
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-l:env(safe-area-inset-left,0px);
  --safe-r:env(safe-area-inset-right,0px);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{height:100%}
body{
  margin:0;min-height:100%;
  color:var(--text);
  font-family:var(--sans);
  font-size:15px;line-height:1.5;
  background:
    linear-gradient(rgba(43,58,84,.14) 1px,transparent 1px),
    linear-gradient(90deg,rgba(43,58,84,.14) 1px,transparent 1px),
    radial-gradient(1200px 600px at 80% -10%,rgba(232,179,75,.045),transparent 60%),
    var(--bg);
  background-size:34px 34px,34px 34px,auto,auto;
  background-attachment:fixed;
  overscroll-behavior-y:none;
}
::selection{background:rgba(232,179,75,.3)}
button{font-family:inherit;color:inherit}
input,select,textarea{font-family:inherit;color:inherit;font-size:15px}
a{color:var(--gold)}

/* ---------- 数字 ---------- */
.num,.mono{
  font-family:var(--mono);
  font-feature-settings:'tnum' 1;
  font-variant-numeric:tabular-nums;
  letter-spacing:-.01em;
}
.pos{color:var(--green)}
.neg{color:var(--red)}
.flat{color:var(--dim)}
.glow.pos{text-shadow:var(--glow-green)}
.glow.neg{text-shadow:var(--glow-red)}
.glow.flat{text-shadow:none}

/* ============================================================
   布局骨架
   ============================================================ */
#app{display:flex;min-height:100vh}
#sidebar{display:none}
#main{flex:1;min-width:0;max-width:1200px;margin:0 auto;width:100%;
  padding:calc(8px + var(--safe-t)) 14px calc(var(--tab-h) + var(--safe-b) + 18px);
}

/* ---------- 顶栏 ---------- */
#topbar{
  display:flex;align-items:center;gap:8px;
  padding:6px 0 10px;
  position:sticky;top:0;z-index:30;
  background:linear-gradient(var(--bg) 78%,transparent);
}
.chips{
  display:flex;gap:8px;overflow-x:auto;flex:1;min-width:0;
  scrollbar-width:none;padding:4px 0;
}
.chips::-webkit-scrollbar{display:none}
.chip{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;min-height:44px;
  border-radius:999px;border:1px solid var(--line-2);
  background:var(--card);color:var(--dim);
  font-size:13px;cursor:pointer;white-space:nowrap;
  transition:all .18s ease;
}
.chip .num{font-size:12px}
.chip.active{
  border-color:var(--gold);color:var(--gold);
  background:var(--gold-soft);
  box-shadow:0 0 0 1px rgba(232,179,75,.25),var(--glow-gold);
}
.date-btn{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;
  min-height:44px;padding:7px 12px;border-radius:999px;
  border:1px solid var(--line-2);background:var(--card);
  color:var(--dim);font-size:12.5px;cursor:pointer;
}
.date-btn.on{color:var(--gold);border-color:var(--gold)}
.offline-bar{
  margin:0 0 10px;padding:8px 12px;border-radius:var(--radius-s);
  background:var(--red-soft);border:1px solid rgba(255,77,94,.35);
  color:var(--red);font-size:12.5px;text-align:center;
}

/* ---------- 视图与入场动画 ---------- */
#view{min-height:60vh}
.view-enter>*{opacity:0;animation:fadeUp .45s cubic-bezier(.22,.8,.3,1) forwards}
.view-enter>*:nth-child(1){animation-delay:.02s}
.view-enter>*:nth-child(2){animation-delay:.07s}
.view-enter>*:nth-child(3){animation-delay:.12s}
.view-enter>*:nth-child(4){animation-delay:.17s}
.view-enter>*:nth-child(5){animation-delay:.22s}
.view-enter>*:nth-child(6){animation-delay:.27s}
.view-enter>*:nth-child(7){animation-delay:.32s}
.view-enter>*:nth-child(n+8){animation-delay:.36s}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .view-enter>*{animation:none;opacity:1}
}

/* ---------- 底部 tab 栏 ---------- */
#tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  display:flex;height:calc(var(--tab-h) + var(--safe-b));
  padding:0 var(--safe-r) var(--safe-b) var(--safe-l);
  background:rgba(12,17,26,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:none;border:0;cursor:pointer;
  color:var(--faint);font-size:10.5px;position:relative;
  min-height:44px;padding:0;
}
.tab svg{width:23px;height:23px}
.tab.active{color:var(--gold)}
.tab.active::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:30px;height:3px;border-radius:0 0 3px 3px;
  background:var(--gold);box-shadow:var(--glow-gold);
}

/* ---------- FAB ---------- */
.fab{
  position:fixed;right:calc(18px + var(--safe-r));
  bottom:calc(var(--tab-h) + var(--safe-b) + 18px);
  z-index:39;width:56px;height:56px;border-radius:50%;
  border:0;cursor:pointer;
  background:linear-gradient(135deg,#f0c264,var(--gold));
  color:#1a1406;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(232,179,75,.4),0 2px 6px rgba(0,0,0,.5);
  transition:transform .15s ease;
}
.fab:active{transform:scale(.92)}

/* ============================================================
   通用组件
   ============================================================ */
.card{
  background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;margin-bottom:14px;
  box-shadow:0 4px 18px rgba(0,0,0,.28);
}
.card h3{
  margin:0 0 12px;font-size:13px;font-weight:600;color:var(--dim);
  letter-spacing:.08em;display:flex;align-items:center;gap:8px;justify-content:space-between;
}
.card h3 .h-actions{display:flex;gap:6px;align-items:center}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  min-height:44px;padding:9px 18px;border-radius:var(--radius-s);
  border:1px solid var(--line-2);background:var(--card-2);
  color:var(--text);font-size:14px;cursor:pointer;
  transition:all .15s ease;white-space:nowrap;
}
.btn:hover{border-color:var(--gold);color:var(--gold)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.primary{
  background:linear-gradient(135deg,#f0c264,var(--gold));
  border-color:transparent;color:#1a1406;font-weight:600;
}
.btn.primary:hover{filter:brightness(1.08);color:#1a1406}
.btn.danger{border-color:rgba(255,77,94,.5);color:var(--red);background:var(--red-soft)}
.btn.danger:hover{border-color:var(--red)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--dim)}
.btn.ghost:hover{color:var(--gold)}
/* 移动端触控目标 ≥44px（DESIGN 总原则）；桌面端在 ≥768px 断点恢复紧凑尺寸 */
.btn.sm{min-height:44px;padding:5px 12px;font-size:12.5px;border-radius:8px}

.badge{
  display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;
  font-size:11.5px;font-weight:600;letter-spacing:.04em;
}
.badge.long{background:var(--green-soft);color:var(--green)}
.badge.short{background:var(--red-soft);color:var(--red)}
.badge.inst{background:var(--gold-soft);color:var(--gold);font-family:var(--mono)}
.badge.tag{background:rgba(91,102,128,.18);color:var(--dim);font-weight:400}
/* 进场判断徽章：行情状态（中性蓝）+ 方向判断（多头绿/空头红，微多微空弱化） */
.badge.state{background:rgba(91,140,255,.14);color:#8fb0ff}
.badge.b-bull{background:var(--green-soft);color:var(--green)}
.badge.b-bear{background:var(--red-soft);color:var(--red)}
.badge.b-bull-w{background:rgba(0,214,143,.07);color:rgba(0,214,143,.62)}
.badge.b-bear-w{background:rgba(255,77,94,.07);color:rgba(255,77,94,.62)}
.q-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;
  font-family:var(--mono);font-size:12px;font-weight:700;
}
.q-A{background:var(--green-soft);color:var(--green)}
.q-B{background:var(--gold-soft);color:var(--gold)}
.q-C{background:rgba(139,151,174,.16);color:var(--dim)}
.q-D{background:var(--red-soft);color:var(--red)}

/* ---------- 表单 ---------- */
.field{margin-bottom:13px;min-width:0}
.field label{display:block;font-size:12px;color:var(--dim);margin-bottom:5px;letter-spacing:.04em}
.field input,.field select,.field textarea{
  width:100%;min-height:44px;padding:9px 12px;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);
  color:var(--text);outline:none;transition:border-color .15s;
}
.field textarea{min-height:70px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field input.num,.field input[inputmode=decimal]{font-family:var(--mono);font-feature-settings:'tnum' 1}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--dim) 50%),linear-gradient(135deg,var(--dim) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px;background-repeat:no-repeat}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
.form-grid .wide{grid-column:1/-1}
.seg{display:flex;border:1px solid var(--line-2);border-radius:var(--radius-s);overflow:hidden;background:var(--bg-2)}
.seg button{
  flex:1;min-height:42px;border:0;background:transparent;color:var(--dim);
  font-size:13.5px;cursor:pointer;transition:all .15s;
}
.seg button.on{background:var(--gold-soft);color:var(--gold);font-weight:600}
.seg button.on.green{background:var(--green-soft);color:var(--green)}
.seg button.on.red{background:var(--red-soft);color:var(--red)}
.seg button.on.green-weak{background:rgba(0,214,143,.07);color:rgba(0,214,143,.66)}
.seg button.on.red-weak{background:rgba(255,77,94,.07);color:rgba(255,77,94,.66)}

/* 进场逻辑标签多选（录入/编辑表单） */
.logic-chips{display:flex;flex-wrap:wrap;gap:8px;padding:2px 0 10px}
.logic-add{display:flex;gap:8px}
.chip.managing{border-style:dashed;border-color:var(--red)}
.chip .chip-x{font-size:15px;line-height:1;color:var(--red);margin-left:2px}
.logic-add input{flex:1;min-width:0}
.logic-add .btn{flex:0 0 auto}

/* 录入表单「复制上一笔」（仅新录入显示，表单顶部右侧小按钮） */
.copy-last-row{display:flex;justify-content:flex-end;margin:-2px 0 10px}

/* 录入表单「更多字段」折叠区（错误复盘/标签/备注；进场理由与附件不折叠） */
.more-fields{margin-bottom:13px}
.more-toggle{
  display:flex;align-items:center;gap:7px;width:100%;
  min-height:44px;padding:9px 12px;
  background:var(--bg-2);border:1px dashed var(--line-2);border-radius:var(--radius-s);
  color:var(--dim);font-size:13px;cursor:pointer;
  transition:color .15s,border-color .15s;
}
.more-toggle:hover{color:var(--gold);border-color:var(--gold)}
.more-arrow{display:inline-block;font-size:11px;transition:transform .18s ease}
.more-fields.open .more-arrow{transform:rotate(90deg)}
.more-fields .more-body{display:none;padding-top:12px}
.more-fields.open .more-body{display:block}

/* ---------- bottom sheet ---------- */
.sheet-backdrop{
  position:fixed;inset:0;z-index:90;background:rgba(4,7,12,.62);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  opacity:0;transition:opacity .22s ease;
}
.sheet-backdrop.in{opacity:1}
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:91;
  max-height:88vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#141d30,var(--card));
  border:1px solid var(--line-2);border-bottom:0;
  border-radius:20px 20px 0 0;
  padding-bottom:var(--safe-b);
  transform:translateY(105%);
  transition:transform .3s cubic-bezier(.22,.9,.3,1);
  box-shadow:0 -10px 40px rgba(0,0,0,.55);
  touch-action:none;
}
.sheet.in{transform:translateY(0)}
.sheet-handle{
  padding:10px 0 6px;display:flex;justify-content:center;cursor:grab;flex:0 0 auto;
}
.sheet-handle::before{
  content:'';width:42px;height:4.5px;border-radius:3px;background:var(--line-2);
}
.sheet-title{
  flex:0 0 auto;padding:2px 18px 12px;font-size:16px;font-weight:600;
  display:flex;align-items:center;justify-content:space-between;
}
.sheet-title .x{
  background:none;border:0;color:var(--faint);font-size:21px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 8px;min-width:44px;min-height:44px;margin:-8px -10px -8px 0;
}
.sheet-body{flex:1;overflow-y:auto;padding:2px 18px 20px;touch-action:pan-y;overscroll-behavior:contain}
.sheet-actions{display:flex;gap:10px;padding-top:8px}
.sheet-actions .btn{flex:1}
@media (min-width:768px){
  .sheet{
    left:50%;right:auto;bottom:auto;top:50%;width:560px;max-height:84vh;
    border-radius:var(--radius);border-bottom:1px solid var(--line-2);
    transform:translate(-50%,-46%) scale(.96);opacity:0;
    transition:transform .22s ease,opacity .22s ease;
  }
  .sheet.in{transform:translate(-50%,-50%) scale(1);opacity:1}
  .sheet-handle{display:none}
  .sheet-title{padding-top:16px}
}

/* ---------- 对话框 ---------- */
.dlg-backdrop{
  position:fixed;inset:0;z-index:95;background:rgba(4,7,12,.66);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;transition:opacity .18s;
}
.dlg-backdrop.in{opacity:1}
.dlg{
  width:100%;max-width:380px;background:linear-gradient(180deg,#141d30,var(--card));
  border:1px solid var(--line-2);border-radius:var(--radius);
  padding:20px;transform:scale(.94);transition:transform .18s;
  box-shadow:0 18px 50px rgba(0,0,0,.6);
}
.dlg-backdrop.in .dlg{transform:scale(1)}
.dlg h4{margin:0 0 8px;font-size:16px}
.dlg p{margin:0 0 16px;color:var(--dim);font-size:13.5px;white-space:pre-line}
.dlg .dlg-input{width:100%;margin-bottom:14px}
.dlg-actions{display:flex;gap:10px}
.dlg-actions .btn{flex:1}

/* ---------- toast ---------- */
#toast-root{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(var(--tab-h) + var(--safe-b) + 16px);
  /* 置顶于所有弹层（sheet 91 / dlg 95 / overlay 110）：suggest 弹层内删除常用项的反馈不被遮挡 */
  z-index:130;display:flex;flex-direction:column;gap:8px;align-items:center;
  width:min(92vw,420px);pointer-events:none;
}
.toast{
  pointer-events:auto;display:flex;align-items:center;gap:10px;
  width:100%;padding:11px 16px;border-radius:12px;
  background:rgba(16,24,38,.96);border:1px solid var(--line-2);
  font-size:13.5px;box-shadow:0 8px 30px rgba(0,0,0,.5);
  animation:toastIn .25s cubic-bezier(.22,.9,.3,1);
  position:relative;overflow:hidden;
}
.toast.out{animation:toastOut .22s ease forwards}
.toast.success{border-color:rgba(0,214,143,.45)}
.toast.success .t-dot{background:var(--green);box-shadow:var(--glow-green)}
.toast.error{border-color:rgba(255,77,94,.5)}
.toast.error .t-dot{background:var(--red);box-shadow:var(--glow-red)}
.toast.info .t-dot{background:var(--gold);box-shadow:var(--glow-gold)}
.t-dot{flex:0 0 8px;width:8px;height:8px;border-radius:50%}
.t-msg{flex:1;min-width:0}
.t-undo{
  flex:0 0 auto;background:var(--gold-soft);border:1px solid rgba(232,179,75,.4);
  color:var(--gold);border-radius:8px;padding:5px 14px;min-height:34px;
  font-size:13px;font-weight:600;cursor:pointer;
}
.t-bar{position:absolute;left:0;bottom:0;height:2px;background:var(--gold);transition:width .1s linear}
@keyframes toastIn{from{opacity:0;transform:translateY(14px)}to{opacity:1}}
@keyframes toastOut{to{opacity:0;transform:translateY(8px)}}

/* ---------- 空态 / 错误态 / 加载 ---------- */
.empty,.err-state{
  padding:42px 16px;text-align:center;color:var(--faint);font-size:13.5px;
}
.empty .e-ico,.err-state .e-ico{font-size:30px;opacity:.5;margin-bottom:8px}
.err-state .btn{margin-top:14px}
.skel{position:relative;overflow:hidden;background:var(--card);border-radius:var(--radius);border:1px solid var(--line)}
.skel::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(100deg,transparent 30%,rgba(139,151,174,.07) 50%,transparent 70%);
  animation:shimmer 1.4s infinite;
}
@keyframes shimmer{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.loading-row{display:flex;justify-content:center;padding:26px;color:var(--faint);font-size:13px}

/* ============================================================
   仪表盘
   ============================================================ */
.hero{
  text-align:center;padding:26px 16px 22px;
}
.hero .h-label{font-size:12px;color:var(--dim);letter-spacing:.22em;margin-bottom:6px}
.hero .h-num{
  font-family:var(--mono);font-feature-settings:'tnum' 1;
  font-size:clamp(38px,11vw,56px);font-weight:700;line-height:1.1;
  letter-spacing:-.02em;
}
.hero .h-sub{margin-top:10px;font-size:12.5px;color:var(--faint);display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .h-sub .num{color:var(--dim)}
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.kpi{
  background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 14px;
}
.kpi .k-label{font-size:11px;color:var(--faint);letter-spacing:.1em;margin-bottom:4px}
.kpi .k-val{font-family:var(--mono);font-feature-settings:'tnum' 1;font-size:21px;font-weight:600}
.kpi .k-sub{font-size:10.5px;color:var(--faint);margin-top:2px;font-family:var(--mono)}
.kpi.hl{border-color:rgba(232,179,75,.4)}
.kpi.hl .k-val{color:var(--gold)}
.chart-wrap{position:relative}
canvas.chart{width:100%;display:block;touch-action:pan-y}
.chart-tip{
  position:absolute;z-index:5;pointer-events:none;
  background:rgba(10,14,20,.94);border:1px solid var(--line-2);
  border-radius:8px;padding:6px 10px;font-size:12px;line-height:1.45;
  white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.5);
  font-family:var(--mono);font-feature-settings:'tnum' 1;
  transform:translate(-50%,-110%);transition:opacity .1s;
}
.cal-nav{display:flex;align-items:center;gap:4px}
.cal-nav .btn{min-height:44px;min-width:44px;padding:2px 11px}
.cal-nav .cal-month{font-family:var(--mono);font-size:13px;color:var(--text);min-width:76px;text-align:center}

/* ============================================================
   记录页
   ============================================================ */
.filter-bar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.filter-bar .search{
  flex:1;min-width:130px;display:flex;align-items:center;gap:8px;
  background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-s);
  padding:0 12px;min-height:44px;
}
.filter-bar .search input{flex:1;background:none;border:0;outline:none;color:var(--text);min-width:0}
.filter-bar .search svg{flex:0 0 auto;color:var(--faint)}
.filter-inline{display:none;gap:8px;flex-wrap:wrap}
.filter-inline select,.filter-inline input{
  min-height:44px;background:var(--card);border:1px solid var(--line-2);
  border-radius:var(--radius-s);color:var(--text);padding:6px 10px;outline:none;
}
.fcount{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:17px;height:17px;border-radius:9px;background:var(--gold);
  color:#1a1406;font-size:10.5px;font-weight:700;margin-left:4px;
}
.list-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--faint);margin:2px 2px 8px;font-family:var(--mono)}

/* 行（移动卡片 / 桌面表格行 双形态，列位置全部显式指定） */
.thead{display:none}
.trow{
  position:relative;background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;margin-bottom:9px;cursor:pointer;
  display:grid;grid-template-columns:auto auto 1fr auto;gap:3px 10px;
  transition:border-color .15s,background .15s;
}
.trow:hover{border-color:var(--line-2)}
.trow.selected{border-color:var(--gold);background:rgba(232,179,75,.07)}
.trow .c-check{
  grid-column:1;grid-row:1/3;align-self:center;display:none;
  align-items:center;justify-content:center;
  min-width:44px;min-height:44px;margin:-6px 0 -6px -10px; /* 扩大触控热区，不放大视觉 */
}
.trow.selecting .c-check{display:flex}
.trow .c-date{grid-column:2;grid-row:1;align-self:center;font-family:var(--mono);font-size:12.5px;color:var(--dim);white-space:nowrap}
.trow .c-main{grid-column:3;grid-row:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}
.trow .c-pnl{
  grid-column:4;grid-row:1/3;align-self:center;text-align:right;
  font-family:var(--mono);font-feature-settings:'tnum' 1;
  font-size:19px;font-weight:700;
}
.trow .c-sub{
  grid-column:2/span 2;grid-row:2;font-size:12px;color:var(--faint);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--mono);
}
.trow .c-q{
  position:absolute;top:-7px;right:-7px;display:flex;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.55));
}
.trow .cell{display:none}

/* 批量操作条 */
.bulk-bar{
  position:sticky;top:54px;z-index:25;
  display:flex;align-items:center;gap:6px;
  background:rgba(20,29,48,.97);border:1px solid var(--gold);
  border-radius:var(--radius);padding:8px 10px;margin-bottom:10px;
  box-shadow:0 6px 24px rgba(0,0,0,.5),var(--glow-gold);
  flex-wrap:wrap;animation:fadeUp .2s ease;
}
.bulk-bar .b-count{font-size:13px;color:var(--gold);font-weight:600;margin-right:auto;padding:0 4px}
.bulk-bar .btn{min-height:44px;padding:5px 12px;font-size:12.5px}
.load-more{display:flex;justify-content:center;margin:6px 0 14px}

/* ============================================================
   统计页
   ============================================================ */
.dim-tabs{display:flex;gap:6px;overflow-x:auto;margin-bottom:12px;scrollbar-width:none;padding:2px 0}
.dim-tabs::-webkit-scrollbar{display:none}
.dim-tabs .chip{min-height:44px}
.stat-table{width:100%;border-collapse:collapse;font-size:13px}
.stat-table th{
  text-align:right;color:var(--faint);font-weight:500;font-size:11.5px;
  padding:7px 8px;border-bottom:1px solid var(--line);letter-spacing:.06em;
}
.stat-table th:first-child,.stat-table td:first-child{text-align:left}
.stat-table td{
  padding:8px;border-bottom:1px solid var(--line);text-align:right;
  font-family:var(--mono);font-feature-settings:'tnum' 1;
}
.stat-table tr:last-child td{border-bottom:0}
/* 进场逻辑×执行质量交叉表：列多，窄屏横向滚动；合计列左侧分隔线 */
.lq-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.lq-matrix{min-width:max-content}
.lq-matrix th,.lq-matrix td{white-space:nowrap}
.lq-matrix td.lq-empty{color:var(--faint)}
.lq-matrix th.lq-total,.lq-matrix td.lq-total{border-left:1px solid var(--line);font-weight:600}
.mini-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.mini-stats .kpi .k-val{font-size:18px}

/* ============================================================
   数据页
   ============================================================ */
.dropzone{
  border:1.5px dashed var(--line-2);border-radius:var(--radius);
  padding:30px 16px;text-align:center;color:var(--dim);cursor:pointer;
  transition:all .18s;font-size:13.5px;
}
.dropzone:hover,.dropzone.over{border-color:var(--gold);color:var(--gold);background:var(--gold-soft)}
.dropzone .dz-ico{margin-bottom:8px;opacity:.7}
.progress{height:6px;border-radius:3px;background:var(--bg-2);overflow:hidden;margin:12px 0 4px}
.progress .p-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gold),#f0c264);transition:width .2s;box-shadow:var(--glow-gold)}
.import-result{
  margin-top:12px;padding:12px;border-radius:var(--radius-s);
  background:var(--bg-2);border:1px solid var(--line);font-size:13px;
}
.import-result .num{font-weight:700}
.kv{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px solid var(--line);font-size:13px}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--faint)}
.kv .v{font-family:var(--mono);font-feature-settings:'tnum' 1;text-align:right;word-break:break-all}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* ============================================================
   设置页
   ============================================================ */
.acct-item{
  display:flex;align-items:center;gap:12px;
  padding:13px 4px;border-bottom:1px solid var(--line);
}
.acct-item:last-child{border-bottom:0}
.acct-item .a-dot{flex:0 0 9px;width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:var(--glow-gold)}
.acct-item.archived .a-dot{background:var(--faint);box-shadow:none}
.acct-item .a-main{flex:1;min-width:0}
.acct-item .a-name{font-weight:600;font-size:14.5px}
.acct-item.archived .a-name{color:var(--faint);text-decoration:line-through}
.acct-item .a-sub{font-size:11.5px;color:var(--faint);font-family:var(--mono)}
.acct-item .a-pnl{font-family:var(--mono);font-size:14px;font-weight:600;text-align:right}
.acct-item .a-act{display:flex;gap:4px}

.net-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:var(--glow-green);display:inline-block}
.net-dot.off{background:var(--red);box-shadow:var(--glow-red)}

/* ============================================================
   桌面端 ≥768px
   ============================================================ */
@media (min-width:768px){
  #tabbar{display:none}
  #sidebar{
    display:flex;flex-direction:column;flex:0 0 200px;
    position:sticky;top:0;height:100vh;
    border-right:1px solid var(--line);
    background:rgba(11,16,25,.7);
    padding:18px 12px calc(14px + var(--safe-b));
  }
  .brand{display:flex;align-items:center;gap:10px;padding:4px 10px 22px}
  .brand-mark{
    width:26px;height:26px;border-radius:7px;flex:0 0 auto;
    background:
      linear-gradient(to top right,transparent 46%,var(--gold) 47%,var(--gold) 53%,transparent 54%),
      linear-gradient(135deg,#1d2840,#10182a);
    border:1px solid rgba(232,179,75,.5);box-shadow:var(--glow-gold);
  }
  .brand-name{font-weight:700;letter-spacing:.12em;font-size:15px}
  #side-nav{display:flex;flex-direction:column;gap:4px}
  #side-nav .tab{
    flex-direction:row;justify-content:flex-start;gap:11px;
    padding:11px 13px;border-radius:var(--radius-s);font-size:14px;
    color:var(--dim);
  }
  #side-nav .tab svg{width:20px;height:20px}
  #side-nav .tab.active{background:var(--gold-soft);color:var(--gold)}
  #side-nav .tab.active::before{
    left:0;top:50%;transform:translateY(-50%);
    width:3px;height:22px;border-radius:0 3px 3px 0;
  }
  .side-foot{margin-top:auto;display:flex;align-items:center;gap:8px;padding:8px 10px;font-size:11px;color:var(--faint);font-family:var(--mono)}
  #main{padding:14px 28px 40px}
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .mini-stats{grid-template-columns:repeat(4,1fr)}
  .fab{bottom:calc(26px + var(--safe-b))}
  #toast-root{bottom:24px}
  .bulk-bar{top:60px}
  .filter-inline{display:flex}
  /* 桌面端保留「筛选」按钮：行情状态/方向判断/进场逻辑/标签/排序/日期等
     维度只在筛选抽屉里有入口（inline 仅常用四项），隐藏按钮会让这些维度
     在桌面端完全不可用、也无法清除窄窗口下设置的筛选 */

  /* 表格形态：9 列 = 选/日期/品种方向+判断徽章/数量/价格/手续费/净盈亏/时段/质量 */
  .thead,.trow{
    display:grid;
    grid-template-columns:34px 96px minmax(150px,1.25fr) 54px 1fr 76px 112px 84px 44px;
    gap:0 8px;align-items:center;
  }
  .thead{
    padding:8px 14px;font-size:11px;color:var(--faint);letter-spacing:.08em;
    border-bottom:1px solid var(--line);margin-bottom:6px;
  }
  .thead .th{cursor:pointer;user-select:none;white-space:nowrap}
  .thead .th.sortable:hover{color:var(--gold)}
  .thead .th .arrow{color:var(--gold)}
  .thead .th.r{text-align:right}
  .trow{padding:9px 14px;margin-bottom:4px;border-radius:var(--radius-s)}
  .trow .c-check{display:flex;grid-row:1;grid-column:1}
  .trow .c-date{grid-row:1}
  .trow .c-date .c-time{display:none}
  .trow .c-main{grid-row:1;flex-wrap:nowrap;overflow:hidden}
  .trow .c-sub{display:none}
  .trow .cell{
    display:block;font-family:var(--mono);font-feature-settings:'tnum' 1;
    font-size:12.5px;color:var(--dim);
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;
  }
  .trow .c-qty{grid-column:4;text-align:right}
  .trow .c-prices{grid-column:5}
  .trow .c-fee{grid-column:6;text-align:right}
  .trow .c-pnl{grid-row:1;grid-column:7;font-size:14.5px}
  .trow .c-session{grid-column:8}
  .trow .c-q{position:static;display:flex;grid-row:1;grid-column:9;justify-content:center;filter:none}

  /* 桌面端（鼠标）恢复紧凑尺寸；44px 触控目标只在移动端强制 */
  .chip{min-height:36px}
  .date-btn{min-height:36px}
  .btn.sm{min-height:34px}
  .cal-nav .btn{min-height:32px;min-width:0}
  .bulk-bar .btn{min-height:38px}
  .dim-tabs .chip{min-height:38px}
  .sheet-title .x{min-width:0;min-height:0;margin:0}
  .trow .c-check{min-width:0;min-height:0;margin:0}
}
@media (min-width:1100px){
  #sidebar{flex-basis:220px}
  .kpi-grid{grid-template-columns:repeat(6,1fr)}
}

/* ============================================================
   自绘表单控件（复选框 / 下拉 / 日期 / 时间）
   ============================================================ */

/* ---------- 复选框 ---------- */
.cck{
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent;
}
.cck-box{
  width:20px;height:20px;flex:0 0 auto;
  border:1.7px solid var(--line-2);border-radius:6px;
  background:var(--bg-2);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s,background .15s,box-shadow .15s;
}
.cck-mark{
  width:16px;height:16px;color:#0a0e14;
  stroke-dasharray:24;stroke-dashoffset:24;
  transition:stroke-dashoffset .2s ease;
}
.cck.on .cck-box{
  border-color:var(--gold);
  background:linear-gradient(135deg,#f0c264,var(--gold));
  box-shadow:var(--glow-gold);
}
.cck.on .cck-mark{stroke-dashoffset:0}
.cck:hover .cck-box{border-color:var(--gold)}
.cck:focus-visible .cck-box{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}

/* ---------- 触发按钮（下拉 / 日期 / 时间 共用基底） ---------- */
.sel,.dp,.tp{display:block;width:100%;min-width:0}
.sel-btn,.dp-btn,.tp-btn{
  width:100%;min-height:44px;padding:9px 12px;
  display:flex;align-items:center;gap:8px;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);
  color:var(--text);font-size:15px;text-align:left;cursor:pointer;
  transition:border-color .15s;
}
.sel-btn.open,.dp-btn.open,.tp-btn.open,
.sel-btn:focus-visible,.dp-btn:focus-visible,.tp-btn:focus-visible{
  border-color:var(--gold);outline:none;
}
.sel-val,.dp-val,.tp-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sel-val.ph,.dp-val.ph,.tp-val.ph{color:var(--faint)}
.sel-caret{width:18px;height:18px;flex:0 0 auto;color:var(--dim);transition:transform .18s}
.sel-btn.open .sel-caret{transform:rotate(180deg)}
.dp-ico,.tp-ico{width:18px;height:18px;flex:0 0 auto;color:var(--dim)}
.dp-val,.tp-val{font-family:var(--mono);font-feature-settings:'tnum' 1}

/* 时间字段：可编辑快输输入框 + 时钟图标按钮（214000 → 21:40:00） */
.tp-field{cursor:text}
.tp-field:focus-within{border-color:var(--gold)}
.tp-icobtn{
  background:none;border:0;padding:0;margin:0;line-height:0;
  color:var(--dim);cursor:pointer;flex:0 0 auto;
}
.tp-icobtn:hover{color:var(--gold)}
.tp-field .tp-input{
  flex:1;min-width:0;background:none;border:0;outline:none;
  color:var(--text);font-size:15px;padding:0;
  font-family:var(--mono);font-feature-settings:'tnum' 1;
}
.tp-field .tp-input::placeholder{color:var(--faint);font-family:var(--font-text,inherit)}

/* ---------- 弹层骨架（桌面 popover / 移动 sheet） ---------- */
.ov-backdrop{
  position:fixed;inset:0;z-index:110;
  opacity:0;transition:opacity .18s ease;
}
.ov-backdrop.in{opacity:1}
.ov-backdrop.ov-sheet-mode{
  background:rgba(4,7,12,.55);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
  display:flex;align-items:flex-end;
}
.ov-panel{
  background:linear-gradient(180deg,#141d30,var(--card));
  border:1px solid var(--line-2);
  box-shadow:0 14px 44px rgba(0,0,0,.6);
  display:flex;flex-direction:column;overflow:hidden;
}
.ov-panel-pop{
  position:fixed;border-radius:var(--radius);max-height:min(420px,80vh);
  transform:translateY(-4px);opacity:0;
  transition:opacity .15s ease,transform .15s ease;
}
.ov-backdrop.in .ov-panel-pop{transform:translateY(0);opacity:1}
.ov-panel-sheet{
  width:100%;border-bottom:0;border-radius:18px 18px 0 0;
  max-height:78vh;padding-bottom:var(--safe-b);
  transform:translateY(102%);
  transition:transform .28s cubic-bezier(.22,.9,.3,1);
}
.ov-backdrop.in .ov-panel-sheet{transform:translateY(0)}
.ov-sheet-head{padding:8px 0 4px;display:flex;flex-direction:column;align-items:center;flex:0 0 auto}
.ov-handle{width:40px;height:4.5px;border-radius:3px;background:var(--line-2)}
.ov-sheet-title{padding:8px 18px 6px;font-size:15px;font-weight:600;align-self:flex-start}
.ov-body{overflow-y:auto;overscroll-behavior:contain;flex:1;min-height:0}

/* ---------- 下拉选项列表 ---------- */
.sel-list{padding:5px;display:flex;flex-direction:column;gap:1px}
.sel-opt{
  display:flex;align-items:center;gap:8px;width:100%;
  min-height:42px;padding:8px 12px;
  background:transparent;border:0;border-radius:8px;
  color:var(--text);font-size:14.5px;text-align:left;cursor:pointer;
  transition:background .12s;
}
.sel-opt-lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sel-opt:hover,.sel-opt.hl{background:var(--card-2)}
.sel-opt.on{color:var(--gold)}
.sel-tick{width:17px;height:17px;flex:0 0 auto;color:var(--gold);opacity:0;transition:opacity .12s}
.sel-opt.on .sel-tick{opacity:1}
@media (max-width:767px){.sel-opt{min-height:48px;font-size:15px}}

/* ---------- 日历 ---------- */
.dp-cal{padding:10px 12px 12px}
.dp-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dp-arrow{
  min-width:38px;min-height:38px;border:1px solid var(--line-2);border-radius:8px;
  background:var(--bg-2);color:var(--dim);font-size:20px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .12s;
}
.dp-arrow:hover{border-color:var(--gold);color:var(--gold)}
.dp-title{font-family:var(--mono);font-size:14px;color:var(--text)}
.dp-wd{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));margin-bottom:4px}
.dp-wd span{text-align:center;font-size:11.5px;color:var(--faint);padding:4px 0}
.dp-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:38px;gap:2px}
.dp-cell{
  height:38px;border:0;background:transparent;border-radius:8px;
  color:var(--text);font-family:var(--mono);font-size:13.5px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;
}
.dp-cell.empty{cursor:default}
.dp-cell:not(.empty):hover{background:var(--card-2)}
.dp-cell.today{color:var(--gold);box-shadow:inset 0 0 0 1px var(--line-2)}
.dp-cell.sel{
  background:linear-gradient(135deg,#f0c264,var(--gold));color:#0a0e14;font-weight:700;
  box-shadow:var(--glow-gold);
}
.dp-cell.sel.today{box-shadow:var(--glow-gold)}
.dp-foot{display:flex;justify-content:flex-end;margin-top:8px}
.dp-clear{
  background:none;border:0;color:var(--dim);font-size:13px;cursor:pointer;
  padding:6px 8px;min-height:36px;border-radius:8px;
}
.dp-clear:hover{color:var(--gold)}

/* ---------- 时间滚动列 ---------- */
.tp-box{padding:8px 14px 12px}
.tp-cols{display:flex;align-items:stretch;gap:6px;justify-content:center}
.tp-col{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center}
.tp-col-lbl{font-size:11.5px;color:var(--faint);padding:2px 0 4px}
.tp-scroll{
  width:100%;height:184px;overflow-y:auto;overscroll-behavior:contain;
  border:1px solid var(--line);border-radius:10px;background:var(--bg-2);
  padding:4px;scrollbar-width:thin;
}
.tp-scroll::-webkit-scrollbar{width:5px}
.tp-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:3px}
.tp-colon{align-self:center;color:var(--faint);font-family:var(--mono);padding-top:18px}
.tp-num{
  width:100%;min-height:44px;border:0;background:transparent;border-radius:7px;
  color:var(--dim);font-family:var(--mono);font-size:15px;cursor:pointer;
  transition:background .1s,color .1s;
}
.tp-num:hover{background:var(--card-2);color:var(--text)}
.tp-num.on{background:var(--gold-soft);color:var(--gold);font-weight:700}
.tp-actions{display:flex;gap:10px;margin-top:12px}
.tp-actions button{
  flex:1;min-height:42px;border-radius:var(--radius-s);cursor:pointer;font-size:14px;
}
.tp-clear{background:var(--card-2);border:1px solid var(--line-2);color:var(--dim)}
.tp-clear:hover{border-color:var(--line-2);color:var(--text)}
.tp-ok{background:linear-gradient(135deg,#f0c264,var(--gold));border:0;color:#0a0e14;font-weight:600}

/* ---------- 可输入组合框（suggest，替代原生 datalist） ---------- */
.sug{display:block;width:100%;min-width:0;position:relative}
.sug-input{
  width:100%;min-height:44px;padding:9px 12px;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);
  color:var(--text);font-size:15px;outline:none;transition:border-color .15s;
}
.sug-input:focus,.sug-input.open{border-color:var(--gold)}
.sug-input::placeholder{color:var(--faint)}
.sug-opt{position:relative}
.sug-del{
  flex:0 0 auto;min-width:34px;min-height:34px;margin:-4px -6px -4px 0;
  display:inline-flex;align-items:center;justify-content:center;
  border:0;background:transparent;border-radius:7px;
  color:var(--faint);font-size:17px;line-height:1;cursor:pointer;
  transition:color .12s,background .12s;
}
.sug-del:hover{color:var(--red);background:var(--red-soft)}
.sug-add{
  display:flex;align-items:center;gap:8px;width:100%;min-height:44px;
  padding:10px 14px;margin-top:2px;
  background:transparent;border:0;border-top:1px solid var(--line);
  color:var(--gold);font-size:13.5px;text-align:left;cursor:pointer;
  transition:background .12s;
}
.sug-add:hover{background:var(--gold-soft)}
.sug-empty{padding:16px 12px;color:var(--faint);font-size:13px;text-align:center}
.sug-search-wrap{padding:10px 14px 6px;flex:0 0 auto}
.sug-search{
  width:100%;min-height:46px;padding:10px 12px;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);
  color:var(--text);font-size:15px;outline:none;
}
.sug-search:focus{border-color:var(--gold)}
@media (max-width:767px){
  .sug-del{min-width:44px;min-height:44px}
}

/* 录入表单 R-multiple 实时预览（风险 Ticks 字段下方） */
.risk-hint{
  margin-top:5px;font-family:var(--mono);font-feature-settings:'tnum' 1;
  font-size:11.5px;color:var(--dim);
}
.risk-hint .pos,.risk-hint .neg{font-weight:600}

/* 桌面端内联筛选里的自绘下拉：紧凑宽度 */
.filter-inline .sel{width:auto}
.filter-inline .sel-btn{min-height:38px;padding:6px 10px;font-size:13.5px;background:var(--card)}
.filter-inline .sug{width:auto}
.filter-inline .sug-input{min-height:38px;padding:6px 10px;font-size:13.5px;background:var(--card)}
@media (max-width:767px){.filter-inline{display:none}}

/* 行内复选框命中区（移动端 44px 触控） */
.trow .c-check .cck{min-width:44px;min-height:44px}
@media (min-width:768px){.trow .c-check .cck{min-width:0;min-height:0}}

/* ============================================================
   截图附件区（批 C1：交易编辑 / 当日复盘共用）
   ============================================================ */
.badge.att{background:rgba(91,102,128,.18);color:var(--dim);font-weight:400;font-family:var(--mono)}
.att-area{display:block;min-width:0}
.att-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));
  gap:8px;margin-bottom:8px;
}
.att-thumb{
  position:relative;aspect-ratio:1;border:1px solid var(--line-2);
  border-radius:10px;overflow:hidden;background:var(--bg-2);
}
.att-thumb img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}
.att-thumb .att-del{
  position:absolute;top:0;right:0;
  min-width:34px;min-height:34px;border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  background:rgba(6,9,14,.62);color:#fff;font-size:17px;line-height:1;
  border-radius:0 0 0 10px;backdrop-filter:blur(2px);
  transition:background .12s,color .12s;
}
.att-thumb .att-del:hover{background:rgba(255,77,94,.8)}
.att-thumb .att-flag{
  position:absolute;left:0;right:0;bottom:0;padding:2px 6px;
  background:rgba(6,9,14,.66);color:var(--gold);font-size:10.5px;text-align:center;
}
.att-thumb.uploading{display:flex;align-items:flex-end;justify-content:center}
.att-prog{position:absolute;left:8px;right:8px;top:50%;height:5px;border-radius:3px;background:var(--bg);overflow:hidden}
.att-prog-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gold),#f0c264);transition:width .15s;box-shadow:var(--glow-gold)}
.att-zone{
  display:flex;align-items:center;justify-content:center;gap:8px;
  min-height:52px;padding:12px;border:1.5px dashed var(--line-2);border-radius:10px;
  color:var(--dim);font-size:12.5px;cursor:pointer;text-align:center;
  transition:all .18s;
}
.att-zone:hover,.att-zone.over,.att-zone:focus-visible{
  border-color:var(--gold);color:var(--gold);background:var(--gold-soft);outline:none;
}
@media (max-width:767px){.att-thumb .att-del{min-width:44px;min-height:44px}}

/* ============================================================
   lightbox（全屏图片查看）
   ============================================================ */
.lb-backdrop{
  position:fixed;inset:0;z-index:120;
  background:rgba(4,7,12,.95);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s ease;
  overscroll-behavior:contain;
}
.lb-backdrop.in{opacity:1}
.lb-img{
  max-width:96vw;max-height:86vh;object-fit:contain;
  transition:transform .18s ease;touch-action:none;user-select:none;
  cursor:zoom-in;border-radius:4px;
}
.lb-img.zoomed{transform:scale(2);cursor:zoom-out}
.lb-btn{
  position:fixed;z-index:121;min-width:44px;min-height:44px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line-2);border-radius:50%;
  background:rgba(16,23,38,.78);color:var(--text);
  font-size:24px;line-height:1;cursor:pointer;
  transition:border-color .15s,color .15s;
}
.lb-btn:hover{border-color:var(--gold);color:var(--gold)}
.lb-close{top:calc(14px + var(--safe-t));right:calc(14px + var(--safe-r))}
.lb-prev{left:calc(10px + var(--safe-l));top:50%;transform:translateY(-50%)}
.lb-next{right:calc(10px + var(--safe-r));top:50%;transform:translateY(-50%)}
.lb-meta{
  position:fixed;left:0;right:0;bottom:calc(14px + var(--safe-b));
  text-align:center;color:var(--dim);font-size:12px;z-index:121;
  pointer-events:none;padding:0 60px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.lb-meta .lb-count{color:var(--gold)}

/* ============================================================
   当日复盘 sheet（批 C2）
   ============================================================ */
.j-summary{
  display:flex;gap:10px;margin-bottom:14px;
}
.j-kpi{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-s);
  padding:9px 12px;
}
.j-kpi .k{font-size:11px;color:var(--faint);letter-spacing:.06em}
.j-kpi .v{font-size:16.5px;font-weight:600}
.j-stars{display:flex;align-items:center;gap:2px}
.j-star{
  min-width:44px;min-height:44px;border:0;background:transparent;
  color:var(--line-2);font-size:25px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;
  transition:color .12s,transform .1s;
}
.j-star:hover{transform:scale(1.12)}
.j-star.on{color:var(--gold);text-shadow:var(--glow-gold)}
.j-star-hint{margin-left:8px;font-size:12px;color:var(--dim);font-family:var(--mono)}
.cal-legend{margin-top:8px;font-size:11px;color:var(--faint);text-align:right}

/* 数据页 Obsidian 导出块 */
.ob-export{border-top:1px solid var(--line);margin-top:14px}

/* 待复盘清单 */
.rv-list{display:flex;flex-direction:column;gap:8px}
.rv-row{
  display:flex;align-items:center;gap:8px;width:100%;min-height:44px;
  padding:8px 10px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-s);color:var(--text);cursor:pointer;
  font-family:inherit;font-size:13px;text-align:left;
  transition:border-color .15s;
}
.rv-row:hover{border-color:var(--gold)}
.rv-date{font-family:var(--mono);font-size:12.5px;color:var(--dim);white-space:nowrap}
.rv-qty{font-family:var(--mono);font-size:12.5px;color:var(--dim)}
.rv-pnl{margin-left:auto;font-family:var(--mono);font-feature-settings:'tnum' 1;font-size:14.5px;font-weight:700;white-space:nowrap}
.rv-more{padding:8px 2px 0;text-align:center;font-size:12px;color:var(--faint);font-family:var(--mono)}
.rv-empty{padding:8px 2px;text-align:center;font-size:13px;color:var(--faint)}
.rv-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;font-size:13px}
.rv-summary .rv-pnl{margin-left:0}
.rv-reason{
  margin-bottom:12px;padding:9px 12px;font-size:12.5px;line-height:1.5;color:var(--dim);
  background:var(--bg-2);border-left:3px solid var(--gold);border-radius:6px;
}
/* 设置页:复盘规则+品种手续费 */
.switch{position:relative;display:inline-flex;flex:0 0 auto;cursor:pointer}
.switch input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer}
.switch .track{display:block;width:46px;height:26px;border-radius:999px;background:var(--bg-2);border:1px solid var(--line-2);position:relative;transition:all .18s ease}
.switch .track::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--dim);transition:all .18s ease}
.switch input:checked+.track{background:var(--gold-soft);border-color:var(--gold);box-shadow:0 0 0 1px rgba(232,179,75,.25)}
.switch input:checked+.track::after{left:23px;background:var(--gold)}
.rr-quals{flex:0 1 auto;padding:0}
.fee-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line)}
.fee-row .f-inst{flex:1;min-width:0;font-family:var(--mono);font-size:13.5px;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis}
.fee-row .f-fee{width:104px;min-height:40px;padding:7px 10px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);color:var(--text);outline:none;text-align:right;font-family:var(--mono);font-feature-settings:'tnum' 1}
.fee-row .f-fee:focus{border-color:var(--gold)}
.fee-add{margin-top:10px}
.fee-add input{min-height:44px;padding:9px 12px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-s);color:var(--text);outline:none}
.fee-add input:focus{border-color:var(--gold)}
.fee-add #fee-val{flex:0 0 112px;text-align:right;font-family:var(--mono);font-feature-settings:'tnum' 1}

/* ===== 复盘体验优化(round3) ===== */
/* 仪表盘 tab 待复盘角标:金色计数点(main.js setReviewBadge 写入;hidden=0 时隐藏)。
   显式 [hidden] 规则是必需的——自身 display 会覆盖 UA 的 [hidden]{display:none} */
.tab-badge{
  position:absolute;top:3px;left:calc(50% + 7px);
  display:inline-flex;align-items:center;justify-content:center;
  min-width:16px;height:16px;padding:0 4px;border-radius:8px;
  background:var(--gold);box-shadow:var(--glow-gold);
  color:#1a1406;font-size:10px;font-weight:700;line-height:1;
  font-family:var(--mono);pointer-events:none;
}
.tab-badge[hidden]{display:none}
@media (min-width:768px){
  #side-nav .tab-badge{position:static;margin-left:auto}
}
/* 「还有 N 笔…」就地展开按钮:沿用 .rv-more 文案样式,仅去掉 UA 按钮壳 */
button.rv-more.as-btn{
  display:block;width:100%;min-height:44px;background:none;border:0;
  cursor:pointer;transition:color .15s;
}
button.rv-more.as-btn:hover{color:var(--gold)}

/* ===== T6 触控可达性(设置页开关/手续费行)+ 待复盘行窄屏韧性 ===== */
/* 开关:≥44px 命中区(伪元素居中外扩,不改视觉尺寸;.switch 是 position:relative 的 label) */
.switch::before{
  content:'';position:absolute;left:50%;top:50%;
  width:max(100%,44px);height:max(100%,44px);
  transform:translate(-50%,-50%);
}
/* 开关键盘焦点环:与 .cck:focus-visible 同款;须排在 .switch input:checked+.track 之后(同特异性靠源顺序覆盖) */
.switch input:focus-visible+.track{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
/* 待复盘行:窄屏允许换行;日期可收缩省略,盈亏换行后靠 margin-left:auto 仍右对齐 */
.rv-row{flex-wrap:wrap;row-gap:2px}
.rv-row .rv-date{flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}
.rv-row .rv-pnl{flex:0 0 auto}
/* 移动端:品种手续费行输入框命中区提到 44px */
@media (max-width:767px){
  .fee-row .f-fee{min-height:44px}
}

/* ===== A 分析深化:分时段表现卡 / 进场逻辑期望值排行 / 权益曲线图例 ===== */
/* 分时段表现:美/欧/亚 平铺,自适应列宽 */
.sess-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:10px}
.sess-tile{
  background:var(--card-2);border:1px solid var(--line);border-radius:12px;
  padding:11px 10px;text-align:center;
}
.sess-tile .s-name{font-size:12px;color:var(--text);letter-spacing:.05em;margin-bottom:4px}
.sess-tile .s-net{font-family:var(--mono);font-feature-settings:'tnum' 1;font-size:18px;font-weight:600}
.sess-tile .s-sub{font-size:10.5px;color:var(--faint);margin-top:3px;font-family:var(--mono)}

/* 进场逻辑期望值排行:最高/最低两块 */
.lq-exp{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:12px}
.le-tile{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.le-tag{font-size:10.5px;color:var(--faint);letter-spacing:.08em;margin-bottom:3px}
.le-logic{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.le-val{font-family:var(--mono);font-feature-settings:'tnum' 1;font-size:17px;font-weight:600;margin-top:2px}
.le-val .le-unit{font-size:11px;color:var(--faint);margin-left:1px}
.le-sub{font-size:10.5px;color:var(--faint);margin-top:2px;font-family:var(--mono)}

/* 权益曲线图例标记 */
.cal-legend .lg-peak{color:var(--gold)}
.cal-legend .lg-dd{color:var(--red)}

/* ===== B 录入/复盘体验:模式行 / 简洁录入 / 自动角标 / 内联校验 ===== */
/* 录入表单顶部模式行:复制上一笔(左) + 简洁/完整切换(右) */
.entry-mode-row{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.entry-mode-row #t-compact-toggle{margin-left:auto}

/* 简洁录入:折叠进阶字段(仍在 DOM,自动计算照常) */
.form-grid.compact .adv{display:none}

/* 「自动」角标:贴在字段右上角(JS 给对应 .field 设 position:relative);[hidden] 时不显示 */
.auto-badge{
  position:absolute;top:0;right:0;
  font-size:9px;line-height:1;color:var(--gold);
  background:var(--gold-soft);border:1px solid rgba(232,179,75,.4);
  padding:2px 5px;border-radius:999px;letter-spacing:.05em;pointer-events:none;
}

/* 内联校验:必填项缺失时红框 + 轻微抖动(suggest=.sug>.sug-input;datepicker=.dp>.dp-btn) */
.sug.invalid .sug-input,.dp.invalid .dp-btn{border-color:var(--red);box-shadow:0 0 0 2px var(--red-soft)}
.sug.invalid,.dp.invalid{animation:invalid-shake .28s}
@keyframes invalid-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

/* ===== 只读演示模式(demo 子域名):顶部横幅 + 隐藏写入控件(api 层已拦截写请求,此处仅去引导) ===== */
.ro-banner{
  padding:7px 14px;text-align:center;font-size:12.5px;font-weight:600;letter-spacing:.03em;
  color:#1a1406;background:var(--gold);
}
.readonly #fab{display:none!important}
.readonly .bulk-bar{display:none!important}
.readonly #t-save,.readonly #t-del{display:none!important}
.readonly #t-logic-add,.readonly #t-logic-manage{display:none!important}
.readonly .dz{display:none!important}
