:root{--ink:#0f1f17;--ink2:#06231b;--muted:#5c7167;--muted2:#8aa396;--line:#dbebe0;--line2:#e2efe6;--bg:#f3f6f4;--card:#ffffff;--soft:#eef6f0;--em:#12925a;--em2:#16a34a;--emd:#0f7a4a;--mint:#2dd4a7;--danger:#dc2626;--r:16px;--sb:248px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Manrope,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}button{font-family:inherit;cursor:pointer}.center{min-height:100vh;display:flex;align-items:center;justify-content:center}.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--em);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:12px;font-weight:700;font-size:15px;border:1px solid transparent;background:var(--em);color:#fff}.btn:hover{background:var(--emd)}.btn.block{width:100%}.btn.ghost{background:#fff;color:var(--ink);border-color:var(--line)}.btn.ghost:hover{background:var(--soft);border-color:var(--em)}.btn.danger{background:#fff;color:var(--danger);border-color:#f3c9c9}.btn.danger:hover{background:#fef2f2}.btn.sm{padding:8px 13px;font-size:13.5px;border-radius:10px}.gbtn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px;border-radius:12px;font-weight:700;font-size:15.5px;color:var(--ink);background:#fff;border:1px solid var(--line)}.gbtn:hover{background:var(--soft)}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(80% 60% at 70% 8%,#e2efe6,transparent),var(--bg)}.login .card{background:#fff;border:1px solid var(--line);border-radius:24px;max-width:420px;width:100%;padding:38px 30px;text-align:center;box-shadow:0 30px 60px -30px #0f1f174d}.brand{display:inline-flex;align-items:center;gap:10px}.brand b{font-size:21px;font-weight:800;letter-spacing:-.02em}.pill{display:inline-block;background:var(--soft);color:var(--em);font-size:12px;font-weight:800;padding:5px 12px;border-radius:999px}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sb);flex-shrink:0;background:#fff;border-right:1px solid var(--line);padding:22px 16px;position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;gap:6px}.sidebar .logo{display:flex;align-items:center;gap:10px;padding:6px 10px 18px}.sidebar .logo b{font-size:18px;font-weight:800}.navlink{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:var(--muted);font-weight:600;font-size:15px}.navlink:hover{background:var(--soft);color:var(--ink)}.navlink.active{background:var(--soft);color:var(--em);font-weight:700}.navlink svg{width:20px;height:20px}.sidebar .spacer{flex:1}.main{flex:1;margin-left:var(--sb);display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:20;background:#f3f6f4d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:14px 26px;display:flex;align-items:center;justify-content:space-between;gap:14px}.monthnav{display:flex;align-items:center;gap:10px;font-weight:700}.monthnav button{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:16px}.monthnav button:hover{border-color:var(--em);color:var(--em)}.monthnav .m{min-width:120px;text-align:center}.userchip{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--ink)}.content{padding:24px 26px 96px;max-width:1080px;width:100%}.page-h{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}.page-sub{color:var(--muted);font-size:15px;margin-bottom:20px}.bottomnav{display:none}.grid{display:grid;gap:16px}.cols-2{grid-template-columns:1fr 1fr}.cols-3{grid-template-columns:repeat(3,1fr)}.card2{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px}.card2 .k{font-size:13px;font-weight:600;color:var(--muted)}.card2 .v{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-top:3px}.v.pos{color:var(--em)}.v.neg{color:var(--danger)}.section-h{font-size:16px;font-weight:800;margin:26px 0 12px}.scorecard{display:flex;gap:22px;align-items:center;flex-wrap:wrap}.gauge{flex-shrink:0}.score-meta .status{font-size:20px;font-weight:800}.score-meta .desc{color:var(--muted);font-size:14.5px;margin-top:4px;max-width:360px;line-height:1.5}.tips{margin-top:14px;display:flex;flex-direction:column;gap:8px}.tip{background:var(--soft);border:1px solid var(--line2);border-radius:11px;padding:10px 13px;font-size:14px;color:var(--ink2)}.catrow{display:flex;align-items:center;gap:12px;margin-bottom:12px}.catrow .ic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--soft);font-size:16px;flex-shrink:0}.catrow .bar{flex:1;height:8px;background:var(--line2);border-radius:999px;overflow:hidden}.catrow .bar>span{display:block;height:100%;border-radius:999px}.catrow .val{font-weight:700;font-size:14px;min-width:90px;text-align:right}.muted{color:var(--muted)}.empty{color:var(--muted);font-size:14.5px;padding:14px 0;text-align:center}.trend{display:flex;align-items:flex-end;gap:14px;height:120px;padding-top:8px}.trend .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%}.trend .barT{width:70%;max-width:46px;background:linear-gradient(180deg,var(--mint),var(--em));border-radius:8px 8px 0 0;min-height:4px}.trend .lbl{font-size:12px;color:var(--muted);font-weight:600}.trend .sc{font-size:12px;font-weight:800}.txrow{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line2)}.txrow .ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--soft);flex-shrink:0}.txrow .info{flex:1;min-width:0}.txrow .t{font-weight:700;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txrow .s{font-size:12.5px;color:var(--muted)}.txrow .amt{font-weight:800;font-size:15px}.amt.income{color:var(--em)}.amt.expense{color:var(--ink)}.amt.investment{color:var(--mint)}.txrow .x{color:var(--muted2);background:none;border:none;font-size:18px;padding:4px}.txrow .x:hover{color:var(--danger)}.tag-prev{font-size:10.5px;font-weight:800;color:#9a6b00;background:#fff7e6;padding:2px 7px;border-radius:999px;margin-left:6px}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}.field input,.field select{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:11px;font-size:16px;font-family:inherit;background:#fff;color:var(--ink);outline:none}.field input:focus,.field select:focus{border-color:var(--em);box-shadow:0 0 0 3px #12925a24}.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.seg{display:flex;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:4px}.seg button{flex:1;padding:9px;border:none;background:none;border-radius:9px;font-weight:700;font-size:13.5px;color:var(--muted)}.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px #0f1f171f}.modal-bd{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f1f1780;display:flex;align-items:flex-end;justify-content:center;padding:0}.modal{background:#fff;width:100%;max-width:460px;border-radius:22px 22px 0 0;padding:22px 20px 26px;max-height:92vh;overflow:auto;animation:up .25s ease}@keyframes up{0%{transform:translateY(20px);opacity:.6}to{transform:none;opacity:1}}.modal h3{font-size:18px;font-weight:800;margin-bottom:16px}.modal .close{position:absolute}.err{color:var(--danger);font-size:13.5px;margin:8px 0}.fab{position:fixed;right:20px;bottom:84px;z-index:30;width:56px;height:56px;border-radius:50%;background:var(--em);color:#fff;border:none;font-size:28px;box-shadow:0 12px 28px -8px #12925a99}.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#0f1f17,#134e4a);color:#fff;border-radius:14px;padding:14px 18px;margin-bottom:18px;flex-wrap:wrap}.banner p{font-size:14.5px;color:#d7e7df}.banner .btn{background:var(--mint);color:#0f1f17}.banner .btn:hover{background:#fff}.paywall{max-width:460px;margin:40px auto;background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px 28px;text-align:center}.paywall .price{font-size:38px;font-weight:800;letter-spacing:-.02em;margin:8px 0}.paywall ul{list-style:none;padding:0;margin:18px 0;text-align:left;display:flex;flex-direction:column;gap:10px}.paywall li{display:flex;gap:10px;font-size:15px;color:var(--ink2)}.tools{display:flex;flex-wrap:wrap;gap:10px}.toolchip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;font-size:13.5px;font-weight:700}.toolchip:hover{border-color:var(--em);color:var(--em)}@media (max-width:860px){.sidebar{display:none}.main{margin-left:0}.content{padding:18px 16px 96px}.cols-2{grid-template-columns:1fr 1fr}.cols-3{grid-template-columns:1fr}.topbar{padding:12px 16px}.bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:#fff;border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:11px;font-weight:700;flex:1;padding:4px}.bottomnav a.active{color:var(--em)}.bottomnav svg{width:22px;height:22px}}@media (max-width:480px){.cols-2,.row2{grid-template-columns:1fr}}
