@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-primary:#f5f2ec;--bg-secondary:#ede9e1;--bg-card:#fffefb;--bg-card-hover:#faf8f3;--bg-input:#f0ede6;--bg-modal-overlay:#1e1c1873;--text-primary:#1c1b18;--text-secondary:#7a756c;--text-tertiary:#a8a29e;--border:#1c1b1814;--border-strong:#1c1b1826;--accent:#3d6b50;--accent-light:#3d6b501a;--income:#3d6b50;--income-bg:#3d6b5014;--expense:#c4524a;--expense-bg:#c4524a14;--recurring:#b8860b;--recurring-bg:#b8860b14;--savings:#4a7194;--savings-bg:#4a719414;--shadow-sm:0 1px 3px #1c1b180a;--shadow-md:0 4px 12px #1c1b180f;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--nav-height:72px}[data-theme=dark]{--bg-primary:#0f1210;--bg-secondary:#161a17;--bg-card:#1c211e;--bg-card-hover:#232925;--bg-input:#252b27;--bg-modal-overlay:#0009;--text-primary:#e8e5df;--text-secondary:#8a857c;--text-tertiary:#5a564f;--border:#ffffff0f;--border-strong:#ffffff1f;--accent:#5e9b73;--accent-light:#5e9b731f;--income:#5e9b73;--income-bg:#5e9b731a;--expense:#d4726a;--expense-bg:#d4726a1a;--recurring:#d4a843;--recurring-bg:#d4a8431a;--savings:#6b9cc4;--savings-bg:#6b9cc41a;--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 12px #0000004d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;margin:0;font-family:Noto Sans KR,Outfit,sans-serif}#root{max-width:480px;min-height:100dvh;margin:0 auto;position:relative}.num{font-variant-numeric:tabular-nums;font-family:JetBrains Mono,monospace}.en{font-family:Outfit,sans-serif}.page{padding:0 20px 100px;animation:.3s pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.header{z-index:100;background:var(--bg-primary);justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.header-title{color:var(--accent);letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.35rem;font-weight:700}.icon-btn{background:var(--bg-card);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.icon-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);background:var(--bg-card);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,8px);z-index:1000;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;font-family:inherit;font-size:.65rem;font-weight:500;text-decoration:none;transition:color .2s;display:flex;position:relative}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--accent)}.nav-item:before{content:"";background:var(--accent);border-radius:1px;width:24px;height:2px;transition:transform .3s cubic-bezier(.22,1,.36,1);position:absolute;top:-1px;left:50%;transform:translate(-50%)scaleX(0)}.nav-item.active:before{transform:translate(-50%)scaleX(1)}.card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:18px}.summary-grid{grid-template-columns:1fr 1fr;gap:10px;margin:16px 0;display:grid}.summary-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:16px}.summary-card .label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:8px;font-size:.72rem;font-weight:500;display:flex}.summary-card .label .dot{border-radius:50%;width:6px;height:6px}.summary-card .amount{font-family:JetBrains Mono,monospace;font-size:1.2rem;font-weight:600}.summary-card.income .dot{background:var(--income)}.summary-card.income .amount{color:var(--income)}.summary-card.expense .dot{background:var(--expense)}.summary-card.expense .amount{color:var(--expense)}.budget-bar{cursor:pointer}.budget-header{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.budget-header .title{font-size:.85rem;font-weight:600}.budget-header .remain{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:500}.progress-track{background:var(--bg-secondary);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), #7bc47f);border-radius:4px;height:100%;transition:width .6s}.progress-fill.over{background:linear-gradient(90deg, var(--expense), #e8927a)}.section-title{justify-content:space-between;align-items:center;margin:24px 0 12px;font-size:.95rem;font-weight:600;display:flex}.section-title .more{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.72rem}.tx-list{flex-direction:column;gap:2px;display:flex}.tx-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:12px;padding:12px 4px;transition:background .15s;display:flex}.tx-item:last-child{border-bottom:none}.tx-item:hover{background:var(--bg-card-hover);border-radius:var(--radius-sm)}.tx-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex}.tx-icon.income{background:var(--income-bg)}.tx-icon.expense{background:var(--expense-bg)}.tx-info{flex:1;min-width:0}.tx-info .name{text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:500;overflow:hidden}.tx-info .meta{color:var(--text-tertiary);margin-top:2px;font-size:.7rem}.tx-amount{text-align:right;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.88rem;font-weight:600}.tx-amount.income{color:var(--income)}.tx-amount.expense{color:var(--expense)}.upcoming-item{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:12px;margin-bottom:6px;padding:12px;display:flex}.upcoming-item .day-badge{border-radius:var(--radius-sm);background:var(--recurring-bg);width:40px;height:40px;color:var(--recurring);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:600;line-height:1;display:flex}.upcoming-item .day-badge small{opacity:.8;font-size:.5rem;font-weight:500}.upcoming-item .info{flex:1}.upcoming-item .info .name{font-size:.82rem;font-weight:500}.upcoming-item .info .cat{color:var(--text-tertiary);margin-top:1px;font-size:.68rem}.upcoming-item .amount{color:var(--expense);font-family:JetBrains Mono,monospace;font-size:.82rem;font-weight:600}.filter-bar{scrollbar-width:none;gap:6px;margin:12px 0 16px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{border:1px solid var(--border-strong);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;padding:7px 14px;font-family:inherit;font-size:.75rem;font-weight:500;transition:all .2s}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.search-box{margin-bottom:16px;position:relative}.search-box input{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-card);width:100%;color:var(--text-primary);outline:none;padding:11px 16px 11px 40px;font-family:inherit;font-size:.85rem;transition:border-color .2s}.search-box input::placeholder{color:var(--text-tertiary)}.search-box input:focus{border-color:var(--accent)}.search-box .search-icon{color:var(--text-tertiary);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.date-group{margin-bottom:20px}.date-header{color:var(--text-tertiary);border-bottom:1px solid var(--border);justify-content:space-between;margin-bottom:4px;padding-bottom:8px;font-size:.72rem;font-weight:600;display:flex}.recurring-summary{gap:10px;margin:12px 0 20px;display:flex}.recurring-stat{text-align:center;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);flex:1;padding:14px 8px}.recurring-stat .val{color:var(--expense);font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:600}.recurring-stat .lbl{color:var(--text-tertiary);margin-top:4px;font-size:.65rem}.recurring-item{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);align-items:center;gap:12px;margin-bottom:8px;padding:14px;display:flex}.recurring-badge{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.3rem;display:flex}.recurring-detail{cursor:pointer;flex:1}.recurring-detail .name{font-size:.85rem;font-weight:600}.recurring-detail .sub{color:var(--text-tertiary);align-items:center;gap:8px;margin-top:2px;font-size:.7rem;display:flex}.recurring-detail .sub .tag{background:var(--bg-secondary);border-radius:4px;padding:1px 6px;font-size:.6rem;font-weight:500}.recurring-right{text-align:right}.recurring-right .amount{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600}.toggle{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle .slider{background:var(--bg-secondary);cursor:pointer;border-radius:11px;transition:all .3s;position:absolute;inset:0}.toggle .slider:before{content:"";width:16px;height:16px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:all .3s;position:absolute;top:3px;left:3px}.toggle input:checked+.slider{background:var(--accent)}.toggle input:checked+.slider:before{transform:translate(18px)}.savings-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;margin-bottom:12px;padding:20px}.savings-header{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.savings-header .type{color:var(--savings);background:var(--savings-bg);border-radius:4px;margin-bottom:4px;padding:2px 8px;font-size:.62rem;font-weight:600;display:inline-block}.savings-header .name{font-size:.95rem;font-weight:600}.savings-header .rate{color:var(--savings);font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700}.savings-amounts{color:var(--text-secondary);justify-content:space-between;margin-bottom:6px;font-size:.72rem;display:flex}.savings-amounts .current{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-weight:600}.savings-track{background:var(--bg-secondary);border-radius:3px;height:6px;overflow:hidden}.savings-fill{background:linear-gradient(90deg, var(--savings), #7db8e0);border-radius:3px;height:100%;transition:width .6s}.savings-footer{color:var(--text-tertiary);justify-content:space-between;margin-top:12px;font-size:.68rem;display:flex}.stat-tabs{background:var(--bg-secondary);border-radius:var(--radius-sm);margin:12px 0 20px;padding:3px;display:flex}.stat-tab{text-align:center;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .2s}.stat-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.category-list{margin-top:16px}.category-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.category-item:last-child{border-bottom:none}.category-color{border-radius:3px;flex-shrink:0;width:10px;height:10px}.category-name{flex:1;font-size:.82rem;font-weight:500}.category-bar-wrap{background:var(--bg-secondary);border-radius:2px;width:80px;height:4px;overflow:hidden}.category-bar-fill{border-radius:2px;height:100%;transition:width .6s}.category-amount{text-align:right;min-width:70px;font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:500}.category-pct{color:var(--text-tertiary);text-align:right;min-width:32px;font-size:.68rem}.modal-overlay{background:var(--bg-modal-overlay);z-index:2000;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:85dvh;padding:24px 20px 36px;animation:.35s cubic-bezier(.22,1,.36,1) slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{background:var(--border-strong);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.modal-title{text-align:center;margin-bottom:20px;font-size:1.05rem;font-weight:700}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.72rem;font-weight:600;display:block}.form-input{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-input);width:100%;color:var(--text-primary);outline:none;padding:11px 14px;font-family:inherit;font-size:.88rem;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-tertiary)}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.type-selector{gap:8px;margin-bottom:16px;display:flex}.type-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border-strong);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;flex:1;padding:10px;font-family:inherit;font-size:.82rem;font-weight:600;transition:all .2s}.type-btn.active.expense{border-color:var(--expense);color:var(--expense);background:var(--expense-bg)}.type-btn.active.income{border-color:var(--income);color:var(--income);background:var(--income-bg)}.type-btn.active.savings{border-color:var(--savings);color:var(--savings);background:var(--savings-bg)}.category-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px;display:grid}.cat-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;font-family:inherit;transition:all .2s;display:flex}.cat-btn:hover{border-color:var(--accent)}.cat-btn.active{border-color:var(--accent);background:var(--accent-light)}.cat-btn .emoji{font-size:1.2rem}.cat-btn .text{color:var(--text-secondary);font-size:.62rem;font-weight:500}.btn-primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;border:none;width:100%;margin-top:8px;padding:14px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-danger{border-radius:var(--radius-md);border:1px solid var(--expense);width:100%;color:var(--expense);cursor:pointer;background:0 0;margin-top:8px;padding:12px;font-family:inherit;font-size:.82rem;font-weight:500}.fab{bottom:calc(var(--nav-height) + 16px);background:var(--accent);color:#fff;cursor:pointer;z-index:500;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.5rem;transition:all .2s;display:flex;position:fixed;right:calc(50% - 220px);box-shadow:0 4px 16px #3d6b5059}.fab:hover{transform:scale(1.05)}@media (width<=480px){.fab{right:20px}}.nl-input-wrap{margin:12px 0 16px;position:relative}.nl-input{border:2px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-card);width:100%;color:var(--text-primary);outline:none;padding:14px 50px 14px 16px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.nl-input:focus{border-color:var(--accent)}.nl-input::placeholder{color:var(--text-tertiary)}.nl-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.nl-preview{background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);flex-wrap:wrap;gap:12px;margin-top:8px;padding:12px;font-size:.75rem;display:flex}.nl-preview .tag{background:var(--bg-card);border-radius:6px;padding:3px 8px;font-weight:500}.empty-state{text-align:center;color:var(--text-tertiary);padding:48px 20px}.empty-state .icon{margin-bottom:12px;font-size:2.5rem}.empty-state .msg{font-size:.85rem}.month-nav{justify-content:center;align-items:center;gap:16px;padding:8px 0;display:flex}.month-nav .month-label{text-align:center;min-width:120px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:600}.month-nav button{border:1px solid var(--border-strong);background:var(--bg-card);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex}.month-nav button:hover{border-color:var(--accent);color:var(--accent)}.chart-container{height:200px;margin:8px 0;position:relative}.cal-toggle{border:1px solid var(--border);background:var(--bg-card);color:var(--text-tertiary);cursor:pointer;border-radius:16px;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-family:inherit;font-size:.68rem;font-weight:500;transition:all .2s;display:inline-flex}.cal-toggle:hover{border-color:var(--accent);color:var(--accent)}.selected-day-header{justify-content:space-between;align-items:center;margin-bottom:12px;font-size:.9rem;font-weight:600;display:flex}.clear-day{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.7rem}.clear-day:hover{color:var(--text-primary)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.cal-dow{text-align:center;color:var(--text-tertiary);padding:4px 0 8px;font-size:.62rem;font-weight:600}.cal-cell{cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;min-height:52px;padding:6px 2px;transition:background .15s;display:flex}.cal-cell:hover{background:var(--bg-card-hover)}.cal-cell.empty{cursor:default}.cal-cell.empty:hover{background:0 0}.cal-cell.today .cal-day{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.cal-cell.selected{background:var(--accent-light)}.cal-day{margin-bottom:2px;font-size:.72rem;font-weight:500;line-height:22px}.cal-amount{white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:.52rem;font-weight:500;line-height:1.3}.cal-amount.expense{color:var(--expense)}.cal-amount.income{color:var(--income)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}
