/* 债务账本 · 淡蓝主题 v2（终极形态）
   状态色铁律：琥珀=待确认（只用小圆点） 绿=已确认/结清 红=仅删除与错误
   动效白名单：格子闪淡 / 卡片收起 / 对勾描线 / hover，全部一次性，无循环 */
:root{
  --bg:#eef3f9; --card:#ffffff; --ink:#27364a; --ink-soft:#6b7c93;
  --line:#e3eaf3; --hair:rgba(107,124,147,.18);
  --blue:#3f72c4; --blue-soft:#eaf1fb; --blue-deep:#2f5aa8;
  --red:#d9695b; --red-soft:#fcecea; --green:#37a679; --green-soft:#e6f6ef;
  --amber:#d99a2b; --amber-soft:#fbf2dc;
  --shadow:0 1px 3px rgba(40,70,120,.05),0 2px 12px rgba(40,70,120,.06);
  --radius:14px;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;color:var(--ink);background:var(--bg);
  font-family:-apple-system,"PingFang SC",system-ui,"Microsoft YaHei","Segoe UI",sans-serif;
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
b{font-weight:700}
button{font-family:inherit}

/* 顶栏 ---------------------------------------------------------------- */
.topbar{display:flex;align-items:center;gap:22px;padding:0 22px;height:56px;
  background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand a{font-weight:800;font-size:16px;color:var(--blue-deep);letter-spacing:.5px}
.mainnav{display:flex;gap:4px}
.mainnav a{padding:6px 13px;border-radius:8px;color:var(--ink-soft);font-weight:600;font-size:14px;position:relative}
.mainnav a:hover{background:var(--blue-soft);color:var(--blue-deep)}
.badge{display:inline-block;min-width:16px;height:16px;line-height:16px;text-align:center;
  background:var(--amber);color:#fff;border-radius:8px;font-size:11px;font-weight:700;
  padding:0 4px;margin-left:4px;vertical-align:2px}
.badge.hide{display:none}
.userbox{margin-left:auto;display:flex;align-items:center;gap:13px}
.who{font-weight:700}
.usermenu{position:relative}
.usermenu summary{list-style:none;cursor:pointer;font-weight:700;padding:5px 10px;border-radius:8px}
.usermenu summary::-webkit-details-marker{display:none}
.usermenu summary:hover{background:var(--blue-soft)}
.usermenu[open] summary{background:var(--blue-soft);color:var(--blue-deep)}
.usermenu-pop{position:absolute;right:0;top:36px;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 6px 22px rgba(40,70,120,.14);min-width:150px;padding:6px;z-index:40}
.usermenu-pop a{display:block;padding:8px 12px;border-radius:8px;font-size:13.5px;color:var(--ink)}
.usermenu-pop a:hover{background:var(--blue-soft);color:var(--blue-deep)}
.usermenu-pop .sep{border-top:1px solid var(--line);margin:5px 4px}
.logout{color:var(--ink-soft);font-size:13px;padding:5px 10px;border-radius:8px}
.logout:hover{background:var(--red-soft);color:var(--red)}

.wrap{max-width:1080px;margin:24px auto;padding:0 18px}
.foot{text-align:center;color:#9fb0c4;font-size:12px;padding:28px 10px 40px}
.muted{color:var(--ink-soft);font-weight:500;font-size:13px}
.old{color:var(--ink-soft);font-weight:500}
.tip{color:var(--ink-soft);font-size:13px;margin-top:14px}
.tip a{color:var(--blue);font-weight:600}
code{background:#eef2f7;padding:1px 7px;border-radius:5px;font-size:13px;color:var(--blue-deep)}

/* 仪表盘（全页唯一渐变） ------------------------------------------------ */
.dash{background:linear-gradient(135deg,#4a7fd0,#3f72c4 60%,#345fa8);color:#fff;
  border-radius:18px;padding:22px 26px;box-shadow:0 6px 22px rgba(52,95,168,.24);margin-bottom:16px}
.dash-label{font-size:14px;opacity:.92;font-weight:600}
.dash-amount{font-size:38px;font-weight:800;letter-spacing:-.5px;margin:2px 0;font-variant-numeric:tabular-nums}
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px;
  padding-top:13px;border-top:1px solid rgba(255,255,255,.22)}
.stat{display:flex;flex-direction:column}
.stat b{font-size:17px;font-weight:700;font-variant-numeric:tabular-nums}
.stat span{font-size:12px;opacity:.85;margin-top:1px}

/* 本月应还卡 ------------------------------------------------------------ */
.month-card{display:flex;align-items:baseline;gap:26px;flex-wrap:wrap;background:#fff;
  border-radius:var(--radius);box-shadow:var(--shadow);padding:13px 20px;margin-bottom:14px;
  font-variant-numeric:tabular-nums}
.month-card b{font-size:17px;margin-left:7px}
.mc-label{font-size:13px;color:var(--ink-soft);font-weight:600}
.mc-gap{color:#9a7414;font-weight:700;font-size:14px;margin-left:auto}
.mc-ok{color:var(--green);font-weight:700;font-size:14px;margin-left:auto}

/* 横幅（疑问 / 解锁申请 / 封本） ---------------------------------------- */
.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;
  border-radius:12px;padding:11px 16px;margin-bottom:12px;font-size:14px}
.banner.warn{background:var(--amber-soft);color:#7a5512;border:1px solid #f0dfb4}
.banner.ok{background:var(--green-soft);color:#1d6b4c;border:1px solid #cdebdd}
.banner-act{flex-shrink:0;border:none;background:#fff;color:inherit;font-weight:700;font-size:13px;
  padding:6px 13px;border-radius:9px;cursor:pointer;box-shadow:0 1px 3px rgba(40,70,120,.12)}
.banner-act:hover{filter:brightness(.97)}

/* 待确认改动卡 ---------------------------------------------------------- */
.changecard{background:#fff;border:1px solid #f0dfb4;border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 20px;margin-bottom:16px}
.cc-head{font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px}
.cc-list{margin:10px 0 4px;padding:0 0 0 2px;list-style:none}
.cc-list li{padding:7px 0;border-bottom:1px solid var(--hair);font-size:14.5px;line-height:1.7}
.cc-list li:last-child{border-bottom:none}
.cc-sum{margin:6px 0 2px;padding:10px 14px;background:#fafcff;border-radius:10px;
  font-size:14.5px;font-variant-numeric:tabular-nums}
.cc-sum b{font-size:16px}
.cc-actions{display:flex;align-items:center;gap:16px;margin-top:12px}
.cc-ok{min-width:200px;padding:11px 22px;font-size:15px}
.cc-doubt{border:none;background:transparent;color:var(--ink-soft);font-size:13.5px;
  cursor:pointer;padding:6px 4px}
.cc-doubt:hover{color:var(--amber)}
.cc-doubt-box{display:flex;gap:8px;margin-top:10px}
.cc-doubt-box input{flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px}
.cc-doubt-box input:focus{outline:none;border-color:var(--amber)}
.cc-done{text-align:center;padding:18px 0 10px;color:var(--green);font-weight:700}
.cc-done p{margin:8px 0 0}
.ck-c{stroke:var(--green);stroke-width:2;stroke-dasharray:151;stroke-dashoffset:151;
  animation:ck .5s ease-out forwards}
.ck-p{stroke:var(--green);stroke-width:3;stroke-linecap:round;stroke-dasharray:36;stroke-dashoffset:36;
  animation:ck .4s .3s ease-out forwards}
@keyframes ck{to{stroke-dashoffset:0}}

/* 工具条 / 状态行 -------------------------------------------------------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:4px 0 6px}
.toolbar h2{margin:0;font-size:18px}
.toolbar-btns{display:flex;gap:8px}
.status-strip{display:flex;align-items:center;justify-content:space-between;gap:10px;
  flex-wrap:wrap;margin:0 2px 10px;min-height:22px}
.mine-line{display:flex;align-items:center;gap:7px;font-size:13px;color:#9a7414;font-weight:600}
.mine-line.hide{display:none}
.copy-btn{border:1px solid #ecd9a8;background:#fff;color:#9a7414;font-size:12.5px;font-weight:700;
  padding:4px 11px;border-radius:8px;cursor:pointer}
.copy-btn:hover{background:var(--amber-soft)}
.save-tip{margin-left:auto;font-size:12.5px;color:var(--ink-soft)}
.save-tip.ok{color:var(--green);font-weight:600}
.save-tip.bad{color:var(--red);font-weight:600}
.msg{margin:4px 2px;font-size:13px;font-weight:600}
.msg.bad{color:var(--red)}
.msg.warn{color:#9a7414}

/* 琥珀点（待确认的唯一视觉语言） ------------------------------------------ */
.pdot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0}
.cell-dot{position:absolute;top:5px;right:5px}

/* 可编辑表格 ------------------------------------------------------------ */
.table-wrap{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}
.bill-table{width:100%;border-collapse:collapse;font-size:14px;min-width:680px}
.bill-table th{background:var(--blue-soft);color:var(--blue-deep);font-weight:700;font-size:12.5px;
  text-align:right;padding:10px 12px;white-space:nowrap}
.bill-table th.l{text-align:left}
.bill-table th.calc-h{background:#dce8f8}
.bill-table th.op-h{width:46px}
.bill-table td{padding:3px 5px;border-bottom:1px solid var(--hair);vertical-align:middle;position:relative}
.bill-table td.l{min-width:170px}
.bill-table input{width:100%;border:1px solid transparent;background:transparent;padding:9px 8px;
  font-size:14px;font-family:inherit;color:var(--ink);border-radius:8px;min-height:40px}
.bill-table input::placeholder{color:#b6c2d3}
.bill-table input:hover{background:#f3f8fd}
.bill-table input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 2px rgba(63,114,196,.12)}
.bill-table input:disabled{color:var(--ink-soft)}
.bill-table input.f-num{text-align:right;font-variant-numeric:tabular-nums}
.bill-table input.f-name{font-weight:600}
.name-td{vertical-align:top;padding-top:6px}
.bill-table td.l{min-width:210px}
.name-row{display:flex;align-items:center;gap:2px}
.drawer-toggle{display:flex;align-items:center;gap:7px;border:none;background:transparent;
  cursor:pointer;padding:3px 6px 3px 8px;border-radius:8px;text-align:left;width:100%;
  font-family:inherit;margin-top:1px}
.drawer-toggle:hover{background:var(--blue-soft)}
.dt-icon{color:#b6c2d3;font-size:12px;transition:transform .18s ease;flex-shrink:0;line-height:1}
.drawer-toggle.open .dt-icon{transform:rotate(90deg);color:var(--blue)}
.dt-label{font-size:11.5px;font-weight:700;color:var(--blue-deep);background:var(--blue-soft);
  padding:2px 9px;border-radius:7px;white-space:nowrap;flex-shrink:0}
.drawer-toggle:hover .dt-label{background:#dce8f8}
.row-plan{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bill-table td.calc{text-align:right;background:#eff5fc;color:var(--blue-deep);font-weight:700;
  padding:9px 12px;font-variant-numeric:tabular-nums;white-space:nowrap}
.bill-table td.calc.zero{color:var(--green)}
.bill-table tr.row:hover td{background:#fafcff}
.bill-table tr.row:hover td.calc{background:#e7f0fa}
td.flash{animation:cellflash .7s ease-out}
@keyframes cellflash{0%{background:var(--amber-soft)}100%{background:transparent}}
.ghost{position:absolute;right:7px;bottom:-1px;font-size:10.5px;color:#b0bccc;pointer-events:none;
  background:#fff;padding:0 3px;border-radius:4px}
.op-td{width:46px;text-align:center}
.del{width:28px;height:28px;border:none;background:transparent;color:#c0ccda;font-size:18px;
  cursor:pointer;border-radius:7px;line-height:1}
.del:hover{background:var(--red-soft);color:var(--red)}
.del.arm{width:auto;background:var(--red);color:#fff;font-size:12px;font-weight:700;padding:0 8px}

/* 行抽屉 ---------------------------------------------------------------- */
tr.drawer td{padding:0 10px 12px;background:#fafcff;border-bottom:1px solid var(--hair)}
.drawer-in{background:#f7fafd;border-radius:10px;padding:12px 16px}
.drawer-fields{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.drawer-fields label{display:flex;flex-direction:column;font-size:12px;font-weight:700;
  color:var(--ink-soft);gap:2px}
.drawer-fields label.wide{flex:1;min-width:200px}
.drawer-fields input{border:1px solid var(--line);background:#fff;border-radius:8px;
  padding:7px 10px;font-size:13.5px;min-height:34px;width:150px}
.drawer-fields label.wide input{width:100%}
.drawer-fields input.f-mini{width:90px;text-align:right;font-variant-numeric:tabular-nums}
.drawer-fields input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px rgba(63,114,196,.1)}
.drawer-meta{display:flex;align-items:center;gap:14px;margin-top:10px;min-height:20px}
.prog{font-size:12.5px}
.settle-btn{border:1px solid #cdebdd;background:#fff;color:var(--green);font-size:12.5px;
  font-weight:700;padding:5px 13px;border-radius:8px;cursor:pointer}
.settle-btn:hover{background:var(--green-soft)}
/* 抽屉里的还款安排 / 还款记录 */
.drawer-plans,.drawer-pays{margin-top:12px;border-top:1px dashed var(--line);padding-top:9px}
.dp-head{font-size:12.5px;font-weight:700;color:var(--ink-soft);display:flex;align-items:center;
  gap:10px;flex-wrap:wrap}
.dp-head .muted{font-weight:500}
.dp-btns{margin-left:auto;display:flex;gap:7px}
.mini-btn{border:1px solid var(--line);background:#fff;color:var(--ink-soft);font-size:12px;
  font-weight:700;padding:4px 11px;border-radius:8px;cursor:pointer}
.mini-btn:hover{border-color:var(--blue);color:var(--blue)}
.mini-btn.nego{border-color:#ecd9a8;color:#9a7414}
.mini-btn.nego:hover{background:var(--amber-soft)}
.plan-list,.pay-list{list-style:none;margin:7px 0 0;padding:0;font-size:13px}
.plan-row,.pay-row{display:flex;align-items:baseline;gap:10px;padding:5px 0;
  border-bottom:1px solid var(--hair);line-height:1.6;flex-wrap:wrap}
.plan-row:last-child,.pay-row:last-child{border-bottom:none}
.plan-row.dead,.pay-row.dead{color:#b0bccc;text-decoration:line-through}
.plan-row.dead .hist-st,.pay-row.dead .hist-st{text-decoration:none}
.plan-state{font-size:11px;font-weight:700;background:var(--blue-soft);color:var(--blue-deep);
  padding:1px 7px;border-radius:6px;margin-left:7px;white-space:nowrap}
.plan-ops{margin-left:auto;white-space:nowrap}
.prog{font-size:12.5px;margin:6px 0 0}
.void-box{display:inline-flex;gap:6px;margin-left:8px}
/* 抽屉内联小表单（协商/新安排/改分摊） */
.inline-form{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-top:9px}
.if-title{width:100%;font-size:12.5px;font-weight:700;color:#9a7414}
.inline-form label{display:flex;flex-direction:column;font-size:12px;font-weight:700;
  color:var(--ink-soft);gap:2px}
.inline-form input{border:1px solid var(--line);border-radius:8px;padding:6px 9px;font-size:13px;
  width:130px;font-variant-numeric:tabular-nums}
.inline-form input:focus{outline:none;border-color:var(--blue)}
.mini-submit{padding:7px 16px;font-size:13px}

.drawer-hist{margin-top:10px;border-top:1px dashed var(--line);padding-top:8px}
.hist-title{font-size:12px;font-weight:700;color:var(--ink-soft);margin-bottom:4px}
.hist-list{list-style:none;margin:0;padding:0;font-size:12.5px;color:var(--ink)}
.hist-list li{padding:3px 0;line-height:1.6}
.hist-ts{color:var(--ink-soft);font-variant-numeric:tabular-nums;margin-right:2px}
.hist-st{font-size:11px;font-weight:700;padding:1px 7px;border-radius:6px;margin-left:6px;white-space:nowrap}
.hist-st.ok{background:var(--green-soft);color:var(--green)}
.hist-st.auto{background:#f0f3f8;color:var(--ink-soft)}
.hist-st.wait{background:var(--amber-soft);color:#9a7414}

/* 已结清折叠组 ----------------------------------------------------------- */
.settled-head td{padding:0;border-bottom:1px solid var(--hair)}
.settled-toggle{width:100%;border:none;background:#fafbfd;color:var(--ink-soft);font-size:13px;
  font-weight:700;padding:10px 14px;cursor:pointer;text-align:left;display:flex;align-items:center;gap:7px}
.settled-toggle:hover{background:#f3f6fb}
.settled-toggle .chev2{transition:transform .18s ease;display:inline-block}
.settled-toggle.open .chev2{transform:rotate(90deg)}
.lock{color:var(--ink-soft);flex-shrink:0;vertical-align:-1px}
.settled-row td{color:var(--ink-soft);background:#fbfcfe;font-size:13.5px;padding:10px 12px}
.settled-row td.l{display:flex;align-items:center;gap:7px;font-weight:600}
.num-plain{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.unlock-link{border:none;background:transparent;color:var(--blue);font-size:12.5px;font-weight:600;
  cursor:pointer;padding:3px 7px;border-radius:6px}
.unlock-link:hover{background:var(--blue-soft)}
.unlock-input{width:150px;border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-size:12.5px}

/* 合计行 ----------------------------------------------------------------- */
.bill-table tfoot td{border-top:2px solid var(--line);border-bottom:none;font-weight:800;
  padding:12px;background:#fafcfe;text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.bill-table tfoot td.l{text-align:left}
.bill-table tfoot td.calc{background:var(--blue-soft);color:var(--blue-deep)}

/* 新改动刷新条 ------------------------------------------------------------ */
.fresh-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:26px;z-index:30;
  background:var(--blue-deep);color:#fff;font-size:13.5px;font-weight:600;padding:10px 22px;
  border-radius:22px;box-shadow:0 6px 18px rgba(47,90,168,.35);cursor:pointer}

/* 按钮 -------------------------------------------------------------------- */
.btn-primary{background:var(--blue);color:#fff;border:none;padding:9px 20px;border-radius:10px;
  font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(63,114,196,.26);transition:.15s}
.btn-primary:hover{background:var(--blue-deep)}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.6;cursor:default}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink-soft);padding:8px 15px;
  border-radius:10px;font-weight:600;cursor:pointer;font-size:14px}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}

/* 登录 -------------------------------------------------------------------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;width:380px;max-width:100%;padding:36px 32px;border-radius:18px;box-shadow:var(--shadow);text-align:center}
.login-logo{font-size:34px}
.login-card h1{margin:6px 0 2px;font-size:22px;color:var(--blue-deep)}
.login-sub{color:var(--ink-soft);margin:0 0 22px;font-size:13px}
.login-card form{text-align:left}
.login-card label{display:block;font-size:13px;font-weight:700;color:var(--ink-soft);margin:12px 0 5px}
.login-card input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#fbfcfe}
.login-card input:focus{outline:none;border-color:var(--blue);background:#fff}
.btn-block{display:block;width:100%;margin-top:20px;text-align:center;border:none}
.login-err{background:var(--red-soft);color:var(--red);padding:9px;border-radius:9px;font-size:13px;margin-bottom:8px;font-weight:600}
.login-hint{margin-top:22px;padding-top:18px;border-top:1px dashed var(--line);text-align:left}
.hint-title{font-size:12px;color:var(--ink-soft);margin-bottom:8px;font-weight:700}
.hint-row{display:block;font-size:13px;padding:7px 9px;color:var(--ink);border-radius:8px}
a.hint-row:hover{background:var(--blue-soft)}
.quick-go{float:right;color:var(--blue);font-weight:700;font-size:12px}
.role-tag{font-size:11px;color:var(--blue);background:var(--blue-soft);padding:1px 7px;border-radius:6px;margin-left:4px}

/* 往来页（证据链） ---------------------------------------------------------- */
.page-title{font-size:23px;margin:6px 0 4px}
.page-sub{color:var(--ink-soft);margin:0 0 20px;font-size:14px}
.back{display:inline-block;color:var(--ink-soft);margin-bottom:14px;font-weight:600}
.back:hover{color:var(--blue)}
.digest-row{display:flex;gap:10px;overflow-x:auto;margin-bottom:18px;padding-bottom:4px}
.digest-card{flex-shrink:0;background:#fff;border-radius:12px;box-shadow:var(--shadow);
  padding:10px 16px;font-size:12.5px;display:flex;flex-direction:column;gap:1px;
  font-variant-numeric:tabular-nums;min-width:140px}
.digest-card b{font-size:13px;color:var(--blue-deep)}
.dg-int{color:#9a7414;font-weight:600}
.tl-day{margin-bottom:18px}
.tl-date{font-size:12.5px;font-weight:700;color:var(--ink-soft);margin:0 4px 7px}
.tl-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.tl-row{display:flex;gap:10px;padding:11px 18px;border-bottom:1px solid var(--hair);
  font-size:13.5px;align-items:baseline;line-height:1.7}
.tl-row:last-child{border-bottom:none}
.tl-ts{color:var(--ink-soft);font-size:12.5px;white-space:nowrap;font-variant-numeric:tabular-nums}
.tl-icon{width:8px;height:8px;border-radius:50%;flex-shrink:0;align-self:center}
.tl-icon.c{background:var(--blue)}
.tl-icon.ok{background:var(--green)}
.tl-icon.auto{background:#b6c2d3}
.tl-icon.bad{background:var(--red)}
.tl-body{flex:1}
.empty{color:var(--ink-soft);text-align:center;padding:28px;background:#fff;border-radius:12px;box-shadow:var(--shadow)}

/* 结清单 -------------------------------------------------------------------- */
.closing-card{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:34px 38px;max-width:640px;margin:0 auto}
.closing-head{text-align:center;margin-bottom:22px}
.closing-logo{width:54px;height:54px;border-radius:50%;background:var(--green-soft);color:var(--green);
  font-size:28px;font-weight:800;line-height:54px;margin:0 auto 8px}
.closing-head h1{margin:0;font-size:24px;color:var(--ink)}
.closing-sub{color:var(--ink-soft);font-size:13px;margin:6px 0 0}
.closing-table{width:100%;border-collapse:collapse;font-size:14px}
.closing-table th{font-size:12px;color:var(--ink-soft);text-align:right;padding:8px 10px;border-bottom:1px solid var(--line)}
.closing-table th.l,.closing-table td.l{text-align:left}
.closing-table td{padding:9px 10px;text-align:right;border-bottom:1px solid var(--hair);font-variant-numeric:tabular-nums}
.closing-table tfoot td{font-weight:800;border-top:2px solid var(--line);border-bottom:none}
.closing-sign{display:flex;justify-content:space-around;margin-top:26px;padding-top:18px;border-top:1px dashed var(--line)}
.sign-item{text-align:center;display:flex;flex-direction:column;gap:2px}
.sign-item span{font-size:12px;color:var(--ink-soft)}
.closing-note{text-align:center;color:var(--ink-soft);font-size:13px;margin-top:18px}

/* 手机端：表格化卡片（单模板 + CSS，不做第二套页面） ------------------------- */
@media(max-width:640px){
  .wrap{margin:14px auto}
  .dash{padding:18px 20px}
  .dash-amount{font-size:32px}
  .dash-stats{grid-template-columns:repeat(2,1fr)}
  .cc-ok{flex:1;min-width:0;min-height:48px}
  .table-wrap{background:transparent;box-shadow:none;overflow:visible}
  .bill-table{min-width:0;display:block}
  .bill-table thead{display:none}
  .bill-table tbody{display:block}
  .bill-table tr{display:block}
  .bill-table tr.row{background:#fff;border-radius:12px;box-shadow:var(--shadow);
    padding:12px 14px;margin-bottom:10px;display:grid;
    grid-template-columns:repeat(3,1fr);gap:8px 10px;position:relative}
  .bill-table tr.row td{display:block;border-bottom:none;padding:0}
  .bill-table td.name-td{grid-column:1 / 3;display:flex;flex-direction:column;gap:3px}
  .drawer-toggle{width:auto;align-self:flex-start}
  .bill-table td.op-td{grid-column:3;text-align:right;width:auto}
  .bill-table tr.row td.num-td::before,.bill-table tr.row td.calc::before{
    content:attr(data-label);display:block;font-size:11px;color:var(--ink-soft);font-weight:700;margin:0 0 1px 2px}
  .bill-table td.calc{border-radius:8px;padding:6px 10px}
  .bill-table input{min-height:38px}
  .bill-table tr.row td,.bill-table tfoot td{min-width:0}
  .bill-table tr.row td.num-td,.bill-table tr.row td.calc,.bill-table tr.row td.num-td input{font-size:12.5px}
  .bill-table tfoot td{font-size:12px}
  .bill-table tfoot td b,.bill-table tfoot td{word-break:break-word}
  tr.drawer{background:#fff;border-radius:12px;box-shadow:var(--shadow);margin:-6px 0 10px;display:block}
  tr.drawer td{display:block;border-bottom:none;background:transparent;padding:4px 10px 10px}
  .drawer-fields input{width:130px}
  .settled-head{display:block}
  .settled-head td{display:block;border:none}
  .settled-toggle{border-radius:12px;background:#fff;box-shadow:var(--shadow)}
  .bill-table tr.settled-row{grid-template-columns:repeat(3,1fr);background:#fbfcfe}
  .settled-row td.l{grid-column:1 / 4}
  .settled-row .num-plain{text-align:left;font-size:12.5px}
  .settled-row .num-plain::before{content:attr(data-label);display:block;font-size:10.5px;color:#a9b6c6;font-weight:700}
  .bill-table tfoot{display:none}  /* 合计与顶部仪表盘重复，手机端隐藏，省空间也不破版 */
  .bill-table tr.row td.calc{min-width:0;overflow-wrap:anywhere;white-space:normal}
  .bill-table tr.row td{min-width:0}
  .cell-dot{top:14px;right:2px}
}
