:root{--bg: #f2f3f7;--card: #ffffff;--line: #ebedf2;--text: #181b22;--muted: #9095a1;--muted2: #c2c6d0;--primary: #4f46e5;--primary-soft: #eef0fe;--green: #15a35a;--red: #e23b4e;--amber: #e0930b;--shadow: 0 2px 8px rgba(20, 24, 40, .05), 0 1px 2px rgba(20, 24, 40, .04);--shadow-lg: 0 8px 28px rgba(20, 24, 40, .12)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);font-size:15px;-webkit-font-smoothing:antialiased}#root{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);box-shadow:0 0 40px #0000000a}.appbar{position:sticky;top:0;z-index:20;background:linear-gradient(135deg,#5b54f0,#4f46e5 60%,#6366f1);color:#fff;padding:calc(12px + env(safe-area-inset-top)) 18px 14px;display:flex;align-items:center;gap:10px}.appbar .logo{font-size:20px}.appbar .title{font-size:16px;font-weight:700;letter-spacing:.5px}.appbar .sub{margin-left:auto;font-size:12px;opacity:.85}.app{padding:16px 14px 92px}h1{font-size:20px;margin:6px 2px 16px;font-weight:700}h2{font-size:13px;margin:22px 4px 10px;color:var(--muted);font-weight:600;letter-spacing:.3px}h2 .small{color:var(--muted2);font-weight:500}.card{background:var(--card);border-radius:18px;padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}.hero{border-radius:20px;padding:20px;margin-bottom:14px;color:#fff;box-shadow:var(--shadow-lg)}.hero.pos{background:linear-gradient(135deg,#16a34a,#15a35a 55%,#0f9d58)}.hero.neg{background:linear-gradient(135deg,#f04458,#e23b4e 55%,#d92d54)}.hero .k{font-size:13px;opacity:.9}.hero .v{font-size:36px;font-weight:800;margin:6px 0 2px;letter-spacing:-.5px}.hero .sub{font-size:12.5px;opacity:.92;display:flex;align-items:center;gap:5px}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.metric{background:var(--card);border-radius:16px;padding:14px;box-shadow:var(--shadow)}.metric .k{font-size:12px;color:var(--muted)}.metric .v{font-size:21px;font-weight:700;margin-top:5px;letter-spacing:-.3px}.metric .v.pos{color:var(--green)}.metric .v.neg{color:var(--red)}.metric.full{grid-column:1 / -1}.metric .sub{font-size:11px;color:var(--muted2);margin-top:3px}.row{display:flex;justify-content:space-between;align-items:center}.muted{color:var(--muted)}.small{font-size:12px}label{display:block;font-size:12.5px;color:var(--muted);margin:12px 2px 5px;font-weight:500}input,select,textarea{width:100%;padding:12px 13px;border:1.5px solid transparent;border-radius:12px;font-size:15px;background:#f5f6f9;color:var(--text);transition:border-color .15s,background .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:#fff}textarea{resize:vertical;min-height:56px}.field-row{display:flex;gap:11px}.field-row>div{flex:1}.seg{display:flex;gap:8px}.seg.seg3 button{font-size:13px;padding:13px 4px}.seg button{flex:1;padding:12px 6px;border:1.5px solid var(--line);background:#fff;border-radius:12px;font-size:14px;color:var(--text);font-weight:500;transition:all .15s}.seg button.on{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px #4f46e54d}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:9px 16px;border:1.5px solid var(--line);background:#fff;border-radius:999px;font-size:13.5px;color:var(--text)}.chip.on{background:var(--primary-soft);color:var(--primary);border-color:var(--primary);font-weight:600}button.primary{width:100%;padding:15px;background:var(--primary);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;margin-top:18px;box-shadow:0 6px 16px #4f46e547}button.primary:disabled{opacity:.6}button.ghost{background:#f4f5f8;border:none;border-radius:9px;padding:7px 12px;font-size:13px;color:var(--text);font-weight:500}button.ghost.danger{color:var(--red);background:#fdecee}.mini-select{width:auto;padding:7px 10px;font-size:13px;background:#f4f5f8;border-radius:9px}.err{background:#fdecee;color:var(--red);padding:11px 13px;border-radius:12px;font-size:13px;margin:12px 0}.ok{background:#eafaf0;color:var(--green);padding:11px 13px;border-radius:12px;font-size:13px;margin:12px 0}.warn{background:#fff8ec;color:var(--amber);padding:11px 13px;border-radius:12px;font-size:13px;margin:12px 0;border:1px solid #fde68a}.day-head{font-size:12.5px;color:var(--muted);margin:18px 6px 8px;font-weight:500}.tx{background:var(--card);border-radius:16px;padding:14px;margin-bottom:10px;box-shadow:var(--shadow);transition:transform .08s}.tx:active{transform:scale(.99)}.tx .top{display:flex;justify-content:space-between;align-items:flex-start}.tx-left{min-width:0}.tx .cust{display:inline-block;font-size:12px;color:var(--primary);background:var(--primary-soft);padding:2px 9px;border-radius:999px;margin-bottom:6px}.tx .merchant{font-weight:600;font-size:15.5px}.badge{font-size:11px;padding:3px 9px;border-radius:999px;color:var(--muted);background:#f4f5f8}.badge.cat{color:var(--muted)}.badge.t0{background:#eef0fe;color:#4338ca}.badge.t1{background:#eafaf0;color:#15803d}.badge.t2{background:#fff4e6;color:#c2410c}.tx .amt{text-align:right;white-space:nowrap;padding-left:8px}.tx .amt .claim{color:var(--green);font-weight:700;font-size:15px}.tx .amt .spent{color:var(--muted);font-size:12.5px;margin-top:2px}.tx .amt .pl{display:inline-block;font-size:12px;font-weight:700;margin-top:5px;padding:2px 9px;border-radius:999px}.tx .amt .pl.pos{color:var(--green);background:#eafaf0}.tx .amt .pl.neg{color:var(--red);background:#fdecee}.tx .amt .pl.flat{color:var(--muted);background:#f4f5f8}.tx .note{background:#f7f8fa;padding:7px 10px;border-radius:9px}.sheet{animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 0 calc(8px + env(safe-area-inset-bottom))}.tabbar button{flex:1;background:none;border:none;padding:4px;font-size:11px;color:var(--muted2);transition:color .15s}.tabbar button.on{color:var(--primary);font-weight:600}.tabbar .ico{font-size:21px;display:block;margin-bottom:3px;filter:grayscale(.4)}.tabbar button.on .ico{filter:none}.center{text-align:center;color:var(--muted);padding:48px 0}.upload-card{padding:14px}.up-row{display:flex;gap:12px}.up-tile{flex:1;text-align:center}.up-box{position:relative;width:100%;aspect-ratio:1 / 1;border-radius:12px;border:1.5px dashed var(--muted2);background:#fafbfc;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.up-box.busy{border-style:solid;color:var(--primary);font-size:13px;background:var(--primary-soft)}.up-box.has{border-style:solid;border-color:var(--line)}.up-box img{width:100%;height:100%;object-fit:cover}.up-ico{font-size:30px;color:var(--muted2)}.up-clear{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;border:none;font-size:15px;line-height:1}.up-label{font-size:12.5px;color:var(--text);margin-top:7px;font-weight:500}.up-hint{color:var(--muted2);margin-left:5px;font-weight:400}.ocr-msg{margin-top:10px;font-size:12.5px;color:var(--green);background:#eafaf0;padding:8px 11px;border-radius:10px}.cycle-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:2px 0 14px}.cycle-nav button{background:#fff;border:none;box-shadow:var(--shadow);border-radius:10px;padding:9px 12px;font-size:13px;color:var(--primary);font-weight:500}.cycle-nav button:disabled{color:var(--muted2)}.cycle-nav .cur{font-size:13.5px;font-weight:600;color:var(--text)}.batch-card{cursor:pointer}.pick-row{display:flex;align-items:center;gap:10px;padding:9px 0;font-size:13.5px;color:var(--text);border-bottom:1px solid var(--line);margin:0}.pick-row:last-of-type{border-bottom:none}.pick-row .claim{color:var(--green);font-weight:600}
