:root{--paper: #f7f6f2;--card: #ffffff;--ink: #22302c;--ink-2: #5b6b66;--ink-3: #97a5a0;--line: #e4e2da;--celadon: #3e7a68;--celadon-deep: #2c5c4e;--celadon-mist: #eaf2ee;--cinnabar: #b5483c;--cinnabar-mist: #f9ece9;--gold: #a8842c;--radius: 10px;--shadow: 0 1px 3px rgba(34, 48, 44, .07), 0 4px 16px rgba(34, 48, 44, .05);--font-num: "SF Mono", ui-monospace, "PingFang SC", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,PingFang SC,Microsoft YaHei,sans-serif;background:var(--paper);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}.app{display:flex;height:100%}.sidebar{width:196px;flex-shrink:0;background:var(--celadon-deep);display:flex;flex-direction:column;padding:18px 12px}.brand{color:#fff;font-size:17px;font-weight:700;letter-spacing:2px;padding:8px 12px 22px;display:flex;align-items:baseline;gap:8px}.brand small{font-size:11px;font-weight:400;opacity:.55;letter-spacing:0}.nav-item{display:flex;align-items:center;gap:10px;color:#ffffffb8;text-decoration:none;padding:10px 12px;border-radius:8px;margin-bottom:2px;font-size:13.5px;transition:all .15s}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff24;color:#fff;font-weight:600}.nav-item .icon{font-size:16px;width:20px;text-align:center}.sidebar .spacer{flex:1}.sidebar .foot{color:#fff6;font-size:11px;padding:8px 12px}.main{flex:1;overflow-y:auto;padding:22px 26px 60px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}.page-head h1{font-size:19px;font-weight:700;letter-spacing:1px}.page-head .sub{color:var(--ink-3);font-size:12px;margin-top:3px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px}.card h2{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--ink-2)}table.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;color:var(--ink-3);font-weight:500;font-size:12px;padding:8px 10px;border-bottom:1px solid var(--line);white-space:nowrap}.tbl td{padding:9px 10px;border-bottom:1px solid var(--line)}.tbl tr:last-child td{border-bottom:none}.tbl tr.clickable{cursor:pointer}.tbl tr.clickable:hover td{background:var(--celadon-mist)}.tbl td.num,.tbl th.num{text-align:right;font-family:var(--font-num);font-variant-numeric:tabular-nums}.tbl tr.total td{font-weight:700;border-top:2px solid var(--ink)}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--celadon);color:#fff;border:none;cursor:pointer;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;transition:background .15s}.btn:hover{background:var(--celadon-deep)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.ghost{background:transparent;color:var(--celadon);border:1px solid var(--celadon)}.btn.ghost:hover{background:var(--celadon-mist)}.btn.danger{background:var(--cinnabar)}.btn.danger:hover{background:#93392f}.btn.sm{padding:5px 11px;font-size:12px;border-radius:6px}input,select,textarea{font:inherit;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:7px;padding:7px 10px;outline:none;transition:border .15s}input:focus,select:focus,textarea:focus{border-color:var(--celadon)}input.num{text-align:right;font-family:var(--font-num)}label.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--ink-2)}.tag{display:inline-block;padding:2px 9px;border-radius:99px;font-size:11.5px;font-weight:500;white-space:nowrap}.tag.draft{background:#f3efdf;color:#8a7426}.tag.posted{background:var(--celadon-mist);color:var(--celadon-deep)}.tag.reversed{background:var(--cinnabar-mist);color:var(--cinnabar)}.tag.open{background:var(--celadon-mist);color:var(--celadon-deep)}.tag.closed{background:#ececec;color:#666}.tag.pending{background:#f3efdf;color:#8a7426}.tag.voucher_created{background:var(--celadon-mist);color:var(--celadon-deep)}.tag.ignored{background:#ececec;color:#888}.tag.calculated{background:#f3efdf;color:#8a7426}.tag.filed{background:var(--celadon-mist);color:var(--celadon-deep)}.tag.paid{background:#e8ecf7;color:#3b5398}.amount{font-family:var(--font-num);font-variant-numeric:tabular-nums}.amount.neg{color:var(--cinnabar)}.kpi{display:flex;gap:14px;flex-wrap:wrap}.kpi .item{flex:1;min-width:150px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}.kpi .item .lbl{font-size:12px;color:var(--ink-3);margin-bottom:6px}.kpi .item .val{font-size:22px;font-weight:700;font-family:var(--font-num)}.kpi .item .val small{font-size:12px;font-weight:400;color:var(--ink-3)}.check-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px dashed var(--line)}.check-row:last-child{border-bottom:none}.check-pass{color:var(--celadon);font-weight:700}.check-fail{color:var(--cinnabar);font-weight:700}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.empty{text-align:center;color:var(--ink-3);padding:38px 0;font-size:13px}.err-banner{background:var(--cinnabar-mist);color:var(--cinnabar);border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13px}.ok-banner{background:var(--celadon-mist);color:var(--celadon-deep);border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13px}.entry-grid td{padding:4px 6px}.entry-grid input,.entry-grid select{width:100%}.balance-bar{display:flex;gap:24px;justify-content:flex-end;padding:10px 6px;font-family:var(--font-num);font-size:13px}.balance-bar .ok{color:var(--celadon);font-weight:600}.balance-bar .bad{color:var(--cinnabar);font-weight:600}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c262273;display:flex;align-items:center;justify-content:center;z-index:50;padding:18px}.modal{background:var(--card);border-radius:14px;padding:22px;width:100%;max-width:720px;max-height:88vh;overflow-y:auto}.modal h3{font-size:16px;margin-bottom:14px}.tabbar{display:none}@media(max-width:768px){.sidebar{display:none}.main{padding:14px 14px 84px}.tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);padding:6px 0 calc(6px + env(safe-area-inset-bottom));z-index:40}.tabbar a{flex:1;text-align:center;text-decoration:none;color:var(--ink-3);font-size:10.5px;display:flex;flex-direction:column;gap:2px}.tabbar a .icon{font-size:19px}.tabbar a.active{color:var(--celadon);font-weight:600}.kpi .item{min-width:calc(50% - 7px)}.card{padding:14px;overflow-x:auto}}@media print{.sidebar,.tabbar,.toolbar,.btn{display:none!important}.main{padding:0}.card{box-shadow:none}}
