:root{--color-primary: #007aff;--color-primary-hover: #0066d6;--color-primary-bg: #eaf2ff;--color-success: #34c759;--color-success-bg: #e7f8ec;--color-danger: #ff3b30;--color-danger-bg: #ffeceb;--color-warning: #ff9500;--color-warning-bg: #fff3e0;--color-text: #1c1c1e;--color-text-secondary: #4b4b50;--color-text-light: #8e8e93;--color-bg: #f2f2f7;--color-card: #ffffff;--color-border: #e9e9ee;--color-border-strong: #d9d9df;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 22px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(17, 17, 26, .04), 0 1px 3px rgba(17, 17, 26, .04);--shadow-md: 0 2px 8px rgba(17, 17, 26, .06), 0 1px 3px rgba(17, 17, 26, .05);--shadow-lg: 0 10px 30px rgba(17, 17, 26, .1);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font-page-title: 24px;--font-section: 17px;--font-body: 14px;--font-sm: 13px;--font-xs: 12px;--sidebar-w: 240px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:var(--font-body);line-height:1.45;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit}.muted{color:var(--color-text-light);font-size:var(--font-sm)}.section-title{font-size:var(--font-section);font-weight:600;letter-spacing:-.01em}.row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.stack>*+*{margin-top:var(--space-4)}.grid{display:grid;gap:var(--space-4)}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.amount-income,.amount-expense,.amount-neutral{font-weight:650;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.amount-income{color:var(--color-success)}.amount-expense{color:var(--color-danger)}.amount-neutral{color:var(--color-text-secondary)}.card{background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-5)}.card+.card{margin-top:var(--space-4)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.card-hint{color:var(--color-text-light);font-size:var(--font-sm)}.stat-value{font-size:30px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin:6px 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:38px;padding:0 16px;border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-card);color:var(--color-text);font-size:var(--font-body);font-weight:550;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease,transform .05s ease;white-space:nowrap}.btn:hover{background:var(--color-bg)}.btn:active{transform:translateY(.5px)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-primary-bg)}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-ghost{border-color:transparent;background:transparent;color:var(--color-primary)}.btn-ghost:hover{background:var(--color-primary-bg)}.btn-danger{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-danger:hover{background:#e0352b}.btn-sm{height:30px;padding:0 12px;font-size:var(--font-sm)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.input,.select{height:40px;padding:0 12px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-card);font-size:var(--font-body);color:var(--color-text);width:100%;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.input::placeholder{color:var(--color-text-light)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-4)}.field>label{font-size:var(--font-sm);color:var(--color-text-secondary);font-weight:550}.seg{display:inline-flex;background:var(--color-bg);border-radius:var(--radius-sm);padding:3px;gap:3px}.seg-item{border:none;background:transparent;color:var(--color-text-secondary);height:32px;padding:0 16px;border-radius:8px;font-size:var(--font-sm);font-weight:550;cursor:pointer}.seg-item.active{background:var(--color-card);color:var(--color-text);box-shadow:var(--shadow-sm)}.seg-item:disabled{cursor:not-allowed}.list-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:14px 0;border-bottom:1px solid var(--color-border)}.list-row:last-child{border-bottom:none}.list-row-main{display:flex;align-items:center;gap:var(--space-3);min-width:0}.list-icon{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-pill);background:var(--color-primary-bg);display:flex;align-items:center;justify-content:center;font-size:20px}.list-title{font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-sub{display:flex;align-items:center;gap:var(--space-2);margin-top:2px;color:var(--color-text-light);font-size:var(--font-sm)}.list-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.tag{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-xs);font-weight:550;padding:2px 10px;border-radius:var(--radius-pill);background:var(--color-primary-bg);color:var(--color-primary)}.tag.ok{background:var(--color-success-bg);color:var(--color-success)}.tag.warning{background:var(--color-warning-bg);color:var(--color-warning)}.tag.over{background:var(--color-danger-bg);color:var(--color-danger)}.bar{height:8px;border-radius:var(--radius-pill);background:var(--color-bg);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius-pill);background:var(--color-primary);transition:width .3s ease}.bar-fill.warning{background:var(--color-warning)}.bar-fill.over{background:var(--color-danger)}.layout{display:flex;min-height:100%}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--color-card);border-right:1px solid var(--color-border);padding:var(--space-5) var(--space-3);display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;letter-spacing:-.01em;padding:4px 10px 12px}.sidebar-brand .brand-mark{width:28px;height:28px;border-radius:8px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-weight:550;cursor:pointer;transition:background .12s ease,color .12s ease}.nav-link .nav-icon{font-size:17px;width:22px;text-align:center}.nav-link:hover{background:var(--color-bg)}.nav-link.active{background:var(--color-primary-bg);color:var(--color-primary)}.nav-spacer{flex:1}.content{flex:1;min-width:0;padding:var(--space-8) 40px;width:100%}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-actions{display:flex;gap:var(--space-2);flex-shrink:0}.page-title{font-size:var(--font-page-title);font-weight:700;letter-spacing:-.02em;margin:0}.page-subtitle{color:var(--color-text-light);font-size:var(--font-sm);margin-top:2px}.ledger-switch{width:100%;margin-bottom:var(--space-3)}.avatar{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-pill);background:var(--color-primary-bg);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.avatar-sm{width:34px;height:34px;font-size:14px}.avatar-lg{width:56px;height:56px;font-size:22px}.avatar.c1{background:#eaf2ff;color:#007aff}.avatar.c2{background:#e7f8ec;color:#2aa84a}.avatar.c3{background:#fff3e0;color:#e0820a}.avatar.c4{background:#ffeceb;color:#e0352b}.avatar.c5{background:#f3eaff;color:#7c4ddb}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text)}.sidebar-user:hover{background:var(--color-bg)}.sidebar-user.active{background:var(--color-primary-bg)}.sidebar-user-name{font-weight:600;font-size:var(--font-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:44px 20px;color:var(--color-text-light);gap:6px}.empty-icon{font-size:40px;opacity:.7}.empty-text{font-size:var(--font-sm)}.loading{color:var(--color-text-light);padding:40px;text-align:center}.spinner{width:22px;height:22px;border:2.5px solid var(--color-border-strong);border-top-color:var(--color-primary);border-radius:50%;animation:zc-spin .7s linear infinite;margin:0 auto}@keyframes zc-spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#eee 25%,#f5f5f7 37%,#eee 63%);background-size:400% 100%;animation:zc-shimmer 1.4s ease infinite;border-radius:var(--radius-sm)}@keyframes zc-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 50% 0%,#eaf2ff 0%,var(--color-bg) 55%)}.login-card{width:380px;text-align:center;padding:40px 36px;box-shadow:var(--shadow-lg)}.login-brand{display:inline-flex;align-items:center;gap:8px;font-size:20px;font-weight:700;margin-bottom:4px}.login-brand .brand-mark{width:30px;height:30px;border-radius:9px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px}.login-qr{margin:24px auto 12px;display:inline-flex;padding:16px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
