:root{--ink: #172033;--ink-soft: #3a4256;--page: #f3f5f8;--surface: #ffffff;--line: #e5e8ee;--line-strong: #cfd4dd;--muted: #6a7182;--muted-2: #9aa0af;--accent: #2f56e6;--accent-press: #2444c9;--due: #c2410c;--due-bg: #fdf1e8;--clear: #15803d;--clear-bg: #e9f6ee;--danger: #c02a20;--mono: ui-monospace, "SF Mono", Menlo, monospace;--sans: -apple-system, system-ui, "Segoe UI", Roboto, sans-serif;--bar-h: 62px;--top-h: 56px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--ink);background:var(--page);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased}.num,.money{font-variant-numeric:tabular-nums;font-family:var(--mono)}h1,h2,h3{margin:0;font-weight:680;letter-spacing:-.01em}button{font-family:inherit}.shell{max-width:480px;margin:0 auto;min-height:100%;background:var(--page);position:relative;display:flex;flex-direction:column;box-shadow:0 0 0 1px var(--line)}.topbar{height:var(--top-h);position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--surface);border-bottom:1px solid var(--line)}.topbar .title{font-size:18px;font-weight:700}.topbar .back{background:none;border:0;font-size:26px;line-height:1;color:var(--ink);padding:4px 6px 6px;margin-left:-6px;cursor:pointer}.topbar .year{margin-left:auto;font-size:12px;color:var(--muted);background:var(--page);border:1px solid var(--line);padding:5px 9px;border-radius:999px}.scroll{flex:1;padding:14px 14px calc(var(--bar-h) + 20px);overflow-y:auto}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--bar-h);background:var(--surface);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(4,1fr);z-index:30;padding-bottom:env(safe-area-inset-bottom,0)}.tabbar button{background:none;border:0;cursor:pointer;color:var(--muted-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:11px;font-weight:600}.tabbar button .ic{font-size:21px;line-height:1}.tabbar button.active{color:var(--accent)}.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}.card+.card{margin-top:14px}.card-head{padding:14px 16px;border-bottom:1px solid var(--line);font-weight:680;font-size:15px;display:flex;align-items:center;justify-content:space-between}.card-pad{padding:16px}.section-label{font-size:13px;color:var(--muted);font-weight:600;margin:20px 2px 8px;text-transform:uppercase;letter-spacing:.03em}.section-label:first-child{margin-top:4px}.row{display:flex;align-items:center;gap:12px;padding:15px 16px;border-bottom:1px solid var(--line);background:var(--surface);cursor:pointer;min-height:60px;width:100%;text-align:left;border-left:0;border-right:0;border-top:0}.row:last-child{border-bottom:0}.row:active{background:#f7f9fc}.row .grow{flex:1;min-width:0}.row .name{font-weight:600;font-size:16px}.row .sub{font-size:13px;color:var(--muted);margin-top:2px}.row .chev{color:var(--muted-2);font-size:20px}.row .r-amt{font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:600}.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.avatar.due{background:var(--due)}.avatar.muted{background:#aeb4c1}.badge{display:inline-block;font-size:13px;font-weight:700;padding:4px 10px;border-radius:999px;font-variant-numeric:tabular-nums}.badge.due{background:var(--due-bg);color:var(--due)}.badge.clear{background:var(--clear-bg);color:var(--clear)}.badge.neutral{background:var(--page);color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid var(--line-strong);background:var(--surface);color:var(--ink);min-height:50px;padding:0 18px;border-radius:12px;cursor:pointer;font-size:16px;font-weight:650;width:100%}.btn:active{transform:scale(.99)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:active{background:var(--accent-press)}.btn.ghost{border-color:transparent;background:transparent;color:var(--accent);min-height:44px}.btn.danger{color:var(--danger);border-color:#e7c3bf}.btn.sm{min-height:40px;font-size:14px;padding:0 14px;width:auto}.btn:disabled{opacity:.45}.btn-row{display:flex;gap:10px}.btn-row .btn{width:auto;flex:1}.sticky-action{position:sticky;bottom:0;padding:12px 0 4px;background:linear-gradient(to top,var(--page) 70%,transparent);margin-top:8px}.fab-note{text-align:center;font-size:13px;color:var(--muted);margin-top:10px}.field{margin-bottom:16px}.field label{display:block;font-size:14px;color:var(--ink);font-weight:600;margin-bottom:7px}input,select,textarea{width:100%;min-height:50px;padding:12px 14px;font-size:16px;font-family:inherit;border:1.5px solid var(--line-strong);border-radius:12px;background:var(--surface);color:var(--ink)}textarea{min-height:76px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f56e61f}.hint{font-size:13px;color:var(--muted);margin-top:6px}.two,.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tile{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 15px}.tile.wide{grid-column:1 / -1}.tile .k{font-size:13px;color:var(--muted);font-weight:600}.tile .v{font-size:26px;font-weight:720;margin-top:4px;font-family:var(--mono);font-variant-numeric:tabular-nums}.tile .v.due{color:var(--due)}.tile .v.clear{color:var(--clear)}.chip{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:1.5px solid var(--line-strong);background:var(--surface);color:var(--ink);padding:13px 15px;border-radius:12px;cursor:pointer;margin-bottom:10px;font-size:15px;min-height:54px}.chip .ck{width:24px;height:24px;border-radius:7px;border:2px solid var(--line-strong);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px}.chip.on{border-color:var(--accent);background:#f4f7ff}.chip.on .ck{background:var(--accent);border-color:var(--accent)}.chip .grow{flex:1}.chip .c-fee{font-family:var(--mono);font-size:14px;color:var(--muted)}.att{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}.att .grow{flex:1;font-weight:600}.att .toggle{display:flex;border:1.5px solid var(--line-strong);border-radius:10px;overflow:hidden}.att .toggle button{border:0;background:var(--surface);padding:9px 16px;font-weight:700;font-size:14px;color:var(--muted);cursor:pointer}.att .toggle button.p.on{background:var(--clear);color:#fff}.att .toggle button.a.on{background:var(--due);color:#fff}.err{background:#fdecea;color:var(--danger);border:1px solid #f2c8c4;padding:12px 14px;border-radius:12px;font-size:14px;margin-bottom:14px}.ok{background:var(--clear-bg);color:var(--clear);border:1px solid #bfe4cc;padding:12px 14px;border-radius:12px;font-size:14px;margin-bottom:14px}.empty{text-align:center;padding:44px 20px;color:var(--muted)}.empty .big{font-size:40px;margin-bottom:8px}.empty h3{margin-bottom:6px}.empty p{margin:0 0 18px}.toast{position:fixed;bottom:calc(var(--bar-h) + 16px);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 20px;border-radius:999px;font-size:14px;font-weight:600;z-index:60;box-shadow:0 8px 24px #00000040}.slot{display:grid;grid-template-columns:1fr 76px 34px;gap:8px;align-items:center;margin-bottom:10px}.slot input{min-height:46px}.slot .del{min-height:46px;border:1.5px solid #e7c3bf;color:var(--danger);background:var(--surface);border-radius:10px;cursor:pointer;font-size:18px}.slot-total{display:flex;justify-content:space-between;padding:12px 14px;border-radius:10px;font-weight:700;margin:6px 0 4px}.slot-total.good{background:var(--clear-bg);color:var(--clear)}.slot-total.bad{background:var(--due-bg);color:var(--due)}.login{min-height:100%;display:flex;align-items:center;justify-content:center;background:var(--ink);padding:22px}.login .box{background:var(--surface);border-radius:20px;padding:30px 24px;width:100%;max-width:380px}.login h1{font-size:22px}.login .sub{color:var(--muted);margin:4px 0 22px}.quick{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.quick button{border:1.5px solid var(--line-strong);background:var(--surface);border-radius:14px;padding:16px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:7px;font-weight:650;font-size:14px;color:var(--ink)}.quick button .ic{font-size:24px}.quick button:active{background:#f7f9fc}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
