*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--primary: #4f6ef7;--primary-dark: #3b5ce5;--danger: #ff3b30;--success: #34c759;--bg: #f5f6fa;--card: #ffffff;--text: #1a1a2e;--text-secondary: #8e8e93;--border: #e8eaef;--radius: 14px;--radius-sm: 10px}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}body{max-width:480px;margin:0 auto;min-height:100dvh;background:var(--card);box-shadow:0 0 0 1px var(--border)}a{color:var(--primary);text-decoration:none}input,select,textarea,button{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100dvh}.content{flex:1;padding:0 16px 16px;overflow-y:auto}.bottom-nav{display:flex;border-top:1px solid var(--border);background:var(--card);padding-bottom:max(env(safe-area-inset-bottom,0),4px)}.nav-item{flex:1;text-align:center;padding:6px 0 8px;font-size:10px;color:var(--text-secondary);cursor:pointer;background:none;border:none;transition:color .15s}.nav-item.active{color:var(--primary)}.nav-item svg{display:block;margin:0 auto 2px;width:24px;height:24px}.summary-card{background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius);padding:20px;color:#fff;margin:16px 0}.summary-card .label{font-size:12px;opacity:.75;margin-bottom:4px}.summary-card .balance{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.summary-card .card-main{display:flex;align-items:center;gap:0}.summary-card .card-item{flex:1}.summary-card .card-divider{width:1px;height:48px;background:#ffffff40;margin:0 16px;flex-shrink:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin:18px 0 10px}.section-header h3{font-size:15px;font-weight:600;color:var(--text)}.section-header a{font-size:12px;color:var(--text-secondary)}.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:8px}.cat-item{display:flex;flex-direction:column;align-items:center;padding:8px 0 6px;border-radius:var(--radius-sm);cursor:pointer;background:none;border:none;transition:background .15s}.cat-item:active{background:var(--bg)}.cat-item .icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:3px}.cat-item .name{font-size:10px;color:var(--text-secondary)}.record-item{display:flex;align-items:center;padding:12px 0;cursor:pointer;transition:background .15s}.record-item.clickable:hover{background:#00000005;border-radius:8px;padding-left:8px;padding-right:8px;margin-left:-8px;margin-right:-8px}.record-item+.record-item{border-top:1px solid var(--border)}.record-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:10px;font-size:15px;flex-shrink:0}.record-info{flex:1;min-width:0}.record-info .line1{display:flex;justify-content:space-between;align-items:center}.record-info .line1 .cat{font-size:13px;font-weight:500}.record-info .line1 .amt{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}.record-info .line2{display:flex;gap:8px;margin-top:2px}.record-info .line2 span{font-size:11px;color:var(--text-secondary)}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;align-items:stretch;justify-content:center}.modal-overlay.open{display:flex}.modal-sheet{background:var(--card);border-radius:0;width:100%;max-width:480px;padding:20px 16px max(30px,env(safe-area-inset-bottom,0));min-height:100dvh;overflow-y:auto;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.type-toggle{display:flex;background:var(--bg);border-radius:8px;padding:2px;margin-bottom:16px}.type-toggle button{flex:1;border:none;background:transparent;padding:8px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .15s}.type-toggle button.active{background:var(--card);font-weight:600;box-shadow:0 1px 4px #00000014}.form-group{margin-bottom:14px}.form-group label{font-size:12px;color:var(--text-secondary);display:block;margin-bottom:4px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;outline:none;background:var(--card)}.form-group input:focus{border-color:var(--primary)}.chip-group{display:flex;gap:6px;flex-wrap:wrap}.chip{padding:5px 14px;border-radius:20px;background:var(--bg);font-size:12px;cursor:pointer;border:none;transition:all .15s}.chip.active{background:var(--primary);color:#fff}.btn-primary{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px}.btn-primary:active{opacity:.9}.amount-input{display:flex;align-items:center;gap:4px}.amount-input .sign{font-size:24px;font-weight:600}.amount-input input{font-size:28px;font-weight:700;border:none;outline:none;width:100%;padding:4px 0;font-variant-numeric:tabular-nums}.amount-display{display:flex;align-items:baseline;justify-content:center;gap:2px;padding:16px 0 6px;margin-bottom:10px;min-height:52px}.amount-display .sign{font-size:28px;font-weight:600}.amount-display .digits{font-size:36px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:1px}.num-keypad{margin:0 -4px}.keypad-row{display:flex;gap:6px;margin-bottom:6px}.keypad-key{flex:1;height:52px;border:none;border-radius:12px;background:var(--bg);font-size:22px;font-weight:500;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.keypad-key:active{background:#e0e2ea}.key-dot{font-size:28px}.key-backspace{background:#e8eaf0}.key-backspace:active{background:#d0d3dd}.page{display:none}.page.active{display:block}.family-badge{display:inline-flex;align-items:center;gap:4px;background:#eef1ff;color:var(--primary);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.pie-canvas{width:120px;height:120px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.pie-hole{width:72px;height:72px;border-radius:50%;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center}.pie-hole-label{font-size:10px;color:#999;line-height:1.2}.pie-hole-val{font-size:14px;font-weight:700;color:var(--text);line-height:1.3}.pie-legend{flex:1;min-width:0}.legend-row{display:flex;align-items:center;gap:6px;margin-bottom:3px;font-size:11px;color:var(--text)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-name{flex-shrink:0;min-width:32px}.legend-pct{flex-shrink:0;width:38px;text-align:right;font-variant-numeric:tabular-nums;color:#888;font-size:10px}.legend-bar-track{flex:1;height:4px;border-radius:2px;background:#eee;min-width:20px}.legend-bar-fill{height:4px;border-radius:2px}.stats-filter-card{background:var(--card);border-radius:14px;padding:12px 14px;box-shadow:0 1px 4px #0000000a;margin-bottom:14px}.stats-filter-row{display:flex;align-items:center;gap:8px}.stats-year-select{flex-shrink:0;padding:4px 8px;border-radius:8px;border:1px solid #e8e8e8;font-size:12px;background:#f8f9fa;color:#333;outline:none;max-width:110px;cursor:pointer}.stats-date-row{display:flex;align-items:center;gap:6px;margin-top:10px}.stats-date-input{flex:1;padding:6px 10px;border-radius:8px;border:1px solid #e8e8e8;font-size:13px;background:#f8f9fa;color:#333;min-width:0;outline:none;font-family:inherit}.stats-date-sep{font-size:12px;color:#999;flex-shrink:0}.stats-summary-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;padding:18px 20px;color:#fff;margin-bottom:14px}.stats-summary-balance{text-align:center;margin-bottom:14px}.stats-summary-label{font-size:12px;opacity:.7;margin-bottom:2px}.stats-summary-amount{font-size:30px;font-weight:700;font-variant-numeric:tabular-nums}.stats-summary-row{display:flex;align-items:center}.stats-summary-item{flex:1;text-align:center}.stats-summary-val{font-size:17px;font-weight:600;font-variant-numeric:tabular-nums}.stats-summary-sub{font-size:11px;opacity:.6;margin-top:2px}.stats-summary-divider{width:1px;height:36px;background:#fff3;flex-shrink:0}.stats-empty{text-align:center;color:#bbb;padding:28px 0;font-size:13px;display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--card);border-radius:14px}.stats-pie-card{display:flex;align-items:center;gap:16px;margin-bottom:14px;background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px #0000000a}.stats-grid{display:flex;gap:8px}.stats-grid-item{flex:1;text-align:center;background:var(--card);border-radius:12px;padding:14px 8px;box-shadow:0 1px 4px #0000000a}.stats-grid-num{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}.stats-grid-label{font-size:11px;color:#999;margin-top:4px}.member-card{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.member-avatar{width:40px;height:40px;border-radius:50%;background:#eef1ff;color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:600;margin-right:10px;flex-shrink:0}.member-info{flex:1}.member-info .name{font-size:14px;font-weight:500}.member-info .meta{font-size:11px;color:var(--text-secondary)}.fab{position:fixed;bottom:80px;right:max(16px,calc(50% - 224px));width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:28px;font-weight:300;border:none;box-shadow:0 4px 16px #4f6ef773;cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .2s,box-shadow .2s}.fab:active{transform:scale(.92);box-shadow:0 2px 8px #4f6ef759}.quick-config{background:var(--bg);border-radius:var(--radius);padding:12px;margin-bottom:8px;animation:slideUp .2s ease}.config-hint{font-size:11px;color:var(--text-secondary);margin-bottom:8px;text-align:center}.config-grid .cat-item{position:relative}.config-grid .cat-item .check-mark{position:absolute;top:2px;right:6px;font-size:11px;color:#fff;background:var(--primary);width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.config-grid .cat-item.selected .icon{box-shadow:0 0 0 2px var(--primary)}.btn-done{display:block;margin:10px auto 0;padding:8px 28px;background:var(--primary);color:#fff;border:none;border-radius:20px;font-size:13px;cursor:pointer}.btn-done:active{opacity:.85}.flex-between{display:flex;justify-content:space-between;align-items:center}.text-secondary{color:var(--text-secondary)}
