:root{--color-bg: #f5f6f8;--color-surface: #ffffff;--color-text: #1f2937;--color-muted: #6b7280;--color-border: #e5e7eb;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-expense: #ef4444;--color-income: #16a34a;--color-transfer: #6b7280;--color-warning: #f59e0b;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-card: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .06);--font-sans: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:15px;line-height:1.5}#app{min-height:100vh}.app{max-width:720px;margin:0 auto;padding:24px 16px 48px;display:grid;gap:20px}.app__header{display:grid;gap:6px}.app__title{margin:0;font-size:28px;font-weight:700;letter-spacing:.5px}.app__subtitle{margin:0;color:var(--color-muted);font-size:13px}.app__tabs{display:flex;gap:4px;margin-top:8px;padding:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:fit-content}.app__tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;padding:8px 16px;border-radius:6px;color:var(--color-muted);font-weight:500;cursor:pointer}.app__tab.is-active{background:var(--color-primary);color:#fff}.app__main{display:grid;gap:16px}.app__footer{margin-top:16px;color:var(--color-muted);font-size:12px;text-align:center}.badges{display:grid;grid-template-columns:1fr 1fr;gap:12px}.badge{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-card)}.badge__label{color:var(--color-muted);font-size:13px;margin-bottom:6px}.badge__amount{font-size:24px;font-weight:700}.badge--expense .badge__amount{color:var(--color-expense)}.badge--income .badge__amount{color:var(--color-income)}.home-view{display:grid;gap:16px}.home-view__actions{display:flex}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:8px 14px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn:hover{background:#f9fafb}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover{background:var(--color-primary-dark)}.btn--ghost{background:transparent}.btn--lg{padding:12px 18px;font-size:16px}.btn--text{background:transparent;border:0;padding:4px 6px;color:var(--color-primary)}.btn--danger{color:var(--color-expense)}.entry-list{display:grid;gap:16px}.entry-group{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.entry-group__date{padding:10px 14px;font-size:13px;color:var(--color-muted);background:#fafbfc;border-bottom:1px solid var(--color-border)}.entry-group__items{list-style:none;margin:0;padding:0}.entry-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:12px 14px;border-bottom:1px solid var(--color-border)}.entry-card:last-child{border-bottom:0}.entry-card__main{display:grid;gap:4px;min-width:0}.entry-card__tag{font-size:13px;color:var(--color-muted);font-weight:500}.tag--expense{color:var(--color-expense)}.tag--income{color:var(--color-income)}.tag--transfer{color:var(--color-transfer)}.entry-card__note{font-size:14px;color:var(--color-text);word-break:break-all}.entry-card__note--empty{color:var(--color-muted);font-style:italic}.entry-card__side{text-align:right;display:grid;gap:6px;flex-shrink:0}.entry-card__amount{font-weight:700;font-size:16px}.entry-card__amount--expense{color:var(--color-expense)}.entry-card__amount--income{color:var(--color-income)}.entry-card__amount--transfer{color:var(--color-transfer)}.entry-card__actions{display:flex;gap:6px;justify-content:flex-end}.empty{background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:24px;text-align:center;color:var(--color-muted)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}.modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a80}.modal__panel{position:relative;width:100%;max-width:420px;background:var(--color-surface);border-radius:var(--radius-lg);padding:20px;display:grid;gap:14px;box-shadow:0 20px 40px #0000002e}.modal__header{display:flex;justify-content:space-between;align-items:center}.modal__header h2{margin:0;font-size:18px}.modal__footer{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.form-row{display:grid;gap:6px}.form-row label{font-size:13px;color:var(--color-muted)}.form-row input,.form-row select,.form-row textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 10px;font-size:14px;font-family:inherit;background:#fff;color:var(--color-text)}.form-row textarea{resize:vertical}.form-error{background:#fef2f2;border:1px solid #fecaca;color:var(--color-expense);padding:8px 10px;border-radius:var(--radius-md);font-size:13px}.segmented{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:#f9fafb}.segmented__btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:6px 12px;font-size:13px;background:transparent;color:var(--color-muted);cursor:pointer}.segmented__btn.is-active{background:var(--color-primary);color:#fff}.segmented--inline{margin-bottom:8px}.charts-view{display:grid;gap:16px}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-card)}.chart-card__title{margin:0 0 12px;font-size:16px}.chart-card__canvas{position:relative;height:260px}.csv-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;display:grid;gap:12px}.csv-panel__title{margin:0;font-size:18px}.csv-panel__hint{margin:0;color:var(--color-muted);font-size:13px}.csv-panel__actions{display:flex;gap:8px;flex-wrap:wrap}.alert{border-radius:var(--radius-md);padding:10px 12px;font-size:14px;list-style:none;margin:0}.alert--success{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}.alert--warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}.alert--error{background:#fef2f2;border:1px solid #fecaca;color:var(--color-expense);padding-left:24px}.alert--error li{list-style:disc;margin:2px 0 2px 8px}
