*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:DM Sans,sans-serif;font-size:inherit}:root{--green: #1A9E75;--green-light: #E1F5EE;--green-dark: #0F6E56;--green-btn: #0d6b4f;--red: #E24B4A;--red-light: #FCEBEB;--amber: #BA7517;--amber-light: #FAEEDA;--blue-light: #E6F1FB;--blue: #378ADD;--income: #2a9d8f;--expense: #e76f51;--text: #1a1a1a;--text-muted: #6b7280;--text-hint: #9ca3af;--border: #e5e7eb;--border-light: #f3f4f6;--bg: #f8f9f8;--surface: #ffffff;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--sidebar-w: 220px}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.navbar{background:var(--surface);border-bottom:1px solid var(--border);height:60px;display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:100}.brand{font-family:Pacifico,cursive;font-style:italic;font-size:18px;color:#1b7a6e;white-space:nowrap}.btn-add{display:flex;align-items:center;gap:8px;background:var(--green-btn);color:#fff;border:none;border-radius:var(--radius-md);padding:8px 18px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-add:hover{background:var(--green-dark)}.btn-add .plus{width:22px;height:22px;background:#fff3;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:300}.fab-add{display:none}.txn-header-spacer{flex:1}.user-pill{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;border:1.5px solid var(--border);border-radius:24px;cursor:pointer;background:var(--surface);white-space:nowrap}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--green-light);color:var(--green-dark);font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-name{font-size:13px;font-weight:500}.user-pill-wrap{position:relative}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 16px #0000001a;z-index:200;overflow:hidden}.user-dropdown-info{padding:14px 16px 12px}.user-dropdown-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.user-dropdown-email{font-size:12px;color:var(--text-muted)}.user-dropdown-divider{height:1px;background:var(--border);margin:0}.user-dropdown-item{display:block;width:100%;padding:11px 16px;text-align:left;background:none;border:none;font-size:13px;color:var(--red, #e53e3e);cursor:pointer}.user-dropdown-item:hover{background:var(--border-light)}.layout{display:flex;flex:1}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:4px;flex-shrink:0}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-hint);padding:12px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-md);font-size:13.5px;font-weight:400;color:var(--text-muted);cursor:pointer;transition:all .15s;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--border-light);color:var(--text)}.nav-item.active{background:var(--green-light);color:var(--green-dark);font-weight:500}.nav-icon{width:18px;text-align:center;font-size:16px}.nav-icon-img{width:18px;height:18px;object-fit:contain;opacity:.5;flex-shrink:0}.nav-item.active .nav-icon-img{opacity:1}.nav-icon-char{width:18px;text-align:center;font-size:14px;flex-shrink:0;filter:grayscale(1) opacity(.5)}.nav-item.active .nav-icon-char{filter:none}.sidebar-divider{height:1px;background:var(--border);margin:8px 0}.nav-sub-item{display:flex;align-items:center;width:100%;padding:5px 14px 5px 34px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:13px;color:var(--text-muted);text-align:left;border-radius:var(--radius-md);transition:color .15s,background .15s}.nav-sub-item:hover{color:var(--text);background:var(--border-light)}.nav-sub-item.active{color:var(--green-dark);font-weight:500}.main{flex:1;padding:24px;overflow-y:auto;min-width:0}.month-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.month-nav-left{display:flex;align-items:center;gap:6px}.month-nav button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}.month-nav button:hover{background:var(--border-light)}.month-pill{padding:5px 14px;border-radius:20px;border:1.5px solid var(--border);font-size:13px;font-weight:500;cursor:pointer;background:var(--surface);color:var(--text-muted);transition:all .15s}.month-pill.active{background:var(--green);color:#fff;border-color:var(--green)}.summary-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-bottom:24px}.summary-card{display:flex;align-items:center;gap:16px;padding:4px 24px}.summary-card:not(:last-child){border-right:1px solid var(--border)}.summary-card:first-child{padding-left:0}.summary-card:last-child{padding-right:0}.summary-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.summary-icon.income{background:var(--green-light)}.summary-icon.expense{background:var(--red-light)}.summary-icon.balance{background:var(--blue-light)}.summary-label{font-size:12px;color:var(--text-muted);margin-bottom:3px}.summary-amount{font-size:22px;font-weight:600;line-height:1.1;letter-spacing:-.5px}.summary-amount.income{color:var(--income)}.summary-amount.expense{color:var(--expense)}.summary-amount.balance{color:var(--text)}.summary-sub{font-size:11.5px;color:var(--text-hint);margin-top:2px}.content-grid{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}.stats-page-grid{display:grid;grid-template-columns:360px 1fr;gap:20px;align-items:start}.section-title{font-size:15px;font-weight:600;color:var(--green-dark);margin-bottom:12px}.txn-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.txn-panel-header{padding:12px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:8px}.txn-tabs{display:flex;gap:2px;background:var(--border-light);border-radius:var(--radius-sm);padding:3px}.txn-tab{padding:4px 12px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text-muted);transition:all .15s;border:none;background:none}.txn-tab.active{background:var(--surface);color:var(--green-dark);box-shadow:0 1px 3px #00000014}.day-group{border-bottom:1px solid var(--border-light);scroll-margin-top:76px}.day-group:last-child{border-bottom:none}.day-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg)}.day-header-left{display:flex;align-items:center;gap:8px}.day-num{font-size:18px;font-weight:600;color:var(--text)}.day-num.weekday{color:var(--income)}.day-num.weekend{color:var(--expense)}.day-label{font-size:11px;font-weight:600;background:var(--text);color:var(--surface);padding:2px 6px;border-radius:4px}.day-label.weekday{background:var(--income)}.day-label.weekend{background:var(--expense)}.day-totals{display:flex;gap:16px;font-size:13px}.day-income{color:var(--income);font-weight:500}.day-expense{color:var(--expense);font-weight:500}.txn-row{display:grid;grid-template-columns:90px 1fr 110px;align-items:center;padding:10px 20px;border-bottom:1px solid var(--border-light);transition:background .1s;cursor:pointer}.txn-row:last-child{border-bottom:none}.txn-row:hover{background:var(--bg)}.txn-cat{font-size:11px;color:var(--text-muted);line-height:1.4}.txn-cat-main{font-weight:500;color:var(--text);font-size:12px}.txn-cat-sub{font-size:10.5px;color:var(--text-hint)}.txn-info{min-width:0}.txn-name{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-name span{font-weight:400;color:var(--text-muted);font-size:12px}.txn-meta{font-size:11.5px;color:var(--text-hint);margin-top:2px;display:flex;align-items:center;gap:6px}.txn-amount{font-size:13.5px;font-weight:500;text-align:right;white-space:nowrap}.txn-amount.expense{color:var(--expense)}.txn-amount.income{color:var(--income)}.txn-amount.transfer{color:var(--blue)}.txn-empty{padding:40px 20px;text-align:center;color:var(--text-hint);font-size:13px}.right-panel{display:flex;flex-direction:column;gap:16px}.panel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.panel-card-header{padding:14px 16px 10px;border-bottom:1px solid var(--border-light)}.budget-list{padding:8px 0}.budget-item{padding:10px 16px;border-bottom:1px solid var(--border-light)}.budget-item:last-child{border-bottom:none}.budget-item-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.budget-item-name{font-size:12.5px;font-weight:500;color:var(--text)}.budget-item-pct{font-size:11.5px;font-weight:600}.pct-over{color:var(--red)}.pct-ok{color:var(--green)}.budget-amounts{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-bottom:6px}.budget-spent{color:var(--red);font-weight:500}.budget-spent.ok{color:var(--green-dark)}.budget-bar-track{height:6px;background:var(--border-light);border-radius:99px;overflow:hidden}.budget-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.bar-over{background:var(--red)}.bar-ok{background:var(--green)}.bar-blue{background:var(--blue)}.stats-tabs{display:flex;gap:6px;padding:12px 16px 0}.stats-tab{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);transition:all .15s}.stats-tab.active{background:var(--text);color:#fff;border-color:var(--text)}.chart-area{padding:12px 16px 16px;display:flex;gap:16px;align-items:center}.chart-wrap{width:140px;height:140px;flex-shrink:0}.chart-legend{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.legend-item{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;gap:6px;border-radius:5px;padding:2px 4px;margin:0 -4px}.legend-item-clickable{cursor:pointer;transition:background .12s}.legend-item-clickable:hover{background:var(--border-light)}.legend-left{display:flex;align-items:center;gap:6px;min-width:0}.legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.legend-name{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-pct{font-size:11px;color:var(--text-hint)}.legend-amt{font-weight:500;color:var(--text);white-space:nowrap}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal-v2{background:var(--bg);border-radius:var(--radius-lg);width:400px;max-width:95vw;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px #00000038}.modal-v2-header{background:var(--green);padding:13px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-v2-back{color:#ffffffe6;background:none;border:none;cursor:pointer;font-size:13px;font-family:DM Sans,sans-serif;padding:0;width:80px}.modal-v2-title{color:#fff;font-size:16px;font-weight:600}.modal-v2-actions{width:80px;display:flex;justify-content:flex-end}.type-tabs-v2{display:flex;gap:6px;padding:8px 10px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0}.type-tab-v2{flex:1;padding:7px 4px;text-align:center;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);background:none;font-family:DM Sans,sans-serif;transition:all .15s}.type-tab-v2.active-income{color:var(--income);border-color:var(--income)}.type-tab-v2.active-expense{color:var(--expense);border-color:var(--expense)}.type-tab-v2.active-transfer{color:var(--blue);border-color:var(--blue)}.modal-v2-body{flex:1;overflow-y:auto;padding:14px 14px 20px;display:flex;flex-direction:column;gap:10px}.form-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden}.form-field-row{display:flex;align-items:center;padding:0 14px;min-height:50px;gap:8px}.field-label{font-size:13px;color:var(--text-muted);width:76px;flex-shrink:0}.field-value{flex:1;font-size:13.5px;font-weight:500;color:var(--text);padding:2px 0 3px;border-bottom:1.5px solid var(--border-light)}.field-value.required-empty{border-bottom-color:var(--red)}.field-value-input{flex:1;border:none;outline:none;font-size:13.5px;font-family:DM Sans,sans-serif;color:var(--text);background:transparent;padding:0;min-width:0}.field-value-input::placeholder{color:var(--text-hint);font-style:italic;font-size:12.5px}.field-divider{height:1px;background:var(--border-light);margin:0 14px}.currency-select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 6px;font-size:12px;font-family:DM Sans,sans-serif;color:var(--text-muted);background:var(--bg);cursor:pointer;flex-shrink:0;outline:none}.currency-select:focus{border-color:var(--green)}.rate-row{padding:8px 14px 10px;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--border-light)}.rate-checkbox-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.rate-checkbox-label input[type=checkbox]{accent-color:var(--green);width:14px;height:14px;flex-shrink:0}.rate-input-row{display:flex;align-items:center;gap:6px;padding-left:20px}.rate-unit{font-size:11px;color:var(--text-hint);white-space:nowrap}.rate-input{flex:1;border:none;border-bottom:1.5px solid var(--border);outline:none;font-size:13px;font-family:DM Sans,sans-serif;color:var(--text);background:transparent;padding:2px 0;min-width:0;text-align:right}.rate-input:focus{border-bottom-color:var(--green)}.rate-input.is-default{color:var(--green-dark)}.field-ph{font-style:italic;color:var(--text-hint);font-size:12.5px;font-weight:300}.field-note-input{border-bottom:1.5px solid var(--border)!important;padding-bottom:3px}.field-note-input:focus{border-bottom-color:var(--income)!important}.field-note-input::placeholder{color:var(--text-hint)!important;font-style:italic}.note-sugg-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 12px #00000014}.note-sugg-item{display:flex;align-items:center;width:100%;padding:10px 14px;text-align:left;border:none;border-bottom:1px solid var(--border-light);background:none;cursor:pointer;font-size:13px;color:var(--text);font-family:inherit;transition:background .1s}.note-sugg-item:last-child{border-bottom:none}.note-sugg-item:hover{background:var(--green-light);color:var(--green-dark)}.note-sugg-icon{font-size:11px;color:var(--text-hint);margin-right:6px}.btn-save{padding:11px 20px;border:none;border-radius:var(--radius-md);background:var(--green-btn);color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;transition:background .15s;width:100%}.btn-save:hover{background:var(--green-dark)}.btn-save:disabled{background:var(--text-hint);cursor:not-allowed}.btn-delete{padding:11px 20px;border:1.5px solid var(--red);border-radius:var(--radius-md);background:none;color:var(--red);cursor:pointer;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;transition:all .15s;flex:1}.btn-delete:hover{background:var(--red-light)}.btn-delete.confirming{background:var(--red);color:#fff;border-color:var(--red)}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.edit-actions{display:flex;gap:8px}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;display:flex;align-items:flex-end}.bottom-sheet{background:var(--surface);width:100%;max-height:72vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-header{background:#1a1a1a;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.bottom-sheet-title{color:#fff;font-size:15px;font-weight:600}.bottom-sheet-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:2px 6px;line-height:1}.bottom-sheet-body{flex:1;overflow-y:auto}.picker-grid-row{display:grid;grid-template-columns:repeat(3,1fr)}.picker-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;gap:3px;min-height:50px;border:none;background:none;cursor:pointer;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);transition:background .12s;font-family:DM Sans,sans-serif}.picker-cell:nth-child(3n){border-right:none}.picker-cell:hover{background:var(--border-light)}.picker-cell.selected{background:var(--green-light)}.picker-cell.selected .picker-cell-name{color:var(--green-dark);font-weight:600}.picker-cell.child{background:var(--bg);min-height:42px;padding:8px}.picker-cell.child:hover,.picker-cell.child.selected{background:var(--green-light)}.picker-cell-empty{border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light)}.picker-cell-empty:nth-child(3n){border-right:none}.picker-cell-icon{font-size:22px;line-height:1}.picker-cell-name{font-size:11px;color:var(--text);text-align:center;line-height:1.3;word-break:break-word}.picker-cell-arrow{font-size:10px;color:var(--text-hint);margin-top:1px}.picker-children{background:var(--bg);border-bottom:2px solid var(--border)}.inline-picker{background:var(--bg);border-top:1px solid var(--border-light);overflow-y:auto;max-height:216px}.inline-picker .picker-cell{min-height:46px;padding:8px 6px}.inline-picker .picker-cell.child{min-height:38px;padding:7px 6px}.field-chevron{font-size:10px;color:var(--text-hint);margin-left:4px;flex-shrink:0;transition:transform .15s}.field-chevron.open{transform:rotate(180deg)}.cal-month-summary{display:grid;grid-template-columns:repeat(3,1fr);padding:10px 16px;text-align:center;border-bottom:1px solid var(--border-light);gap:0}.cal-sum-label{font-size:11px;color:var(--text-muted);margin-bottom:2px}.cal-sum-value{font-size:14px;font-weight:600;color:var(--text)}.cal-sum-value.income{color:var(--income)}.cal-sum-value.expense{color:var(--expense)}.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg);border-bottom:1px solid var(--border-light)}.cal-head-cell{text-align:center;padding:6px 2px;font-size:11px;font-weight:600;color:var(--text-muted)}.cal-head-cell.is-sat,.cal-head-cell.is-sun{color:var(--expense)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border-left:1px solid var(--border-light)}.cal-cell{border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);padding:4px 4px 5px;min-height:68px;cursor:pointer;transition:background .1s;overflow:hidden}.cal-cell:hover:not(.cal-other){background:var(--border-light)}.cal-other{opacity:.35;pointer-events:none}.cal-selected{background:var(--green-light)!important}.cal-sat .cal-day-num,.cal-sun .cal-day-num{color:var(--expense)}.cal-today .cal-day-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#1a1a1a;color:#fff;border-radius:50%;font-size:10px}.cal-day-num{display:block;font-size:12px;font-weight:600;color:var(--text);line-height:1;margin-bottom:3px}.cal-amounts{display:flex;flex-direction:column;gap:1px;align-items:flex-end}.cal-in{font-size:9.5px;color:var(--income);font-weight:500}.cal-ex{font-size:9.5px;color:var(--expense);font-weight:500}.cal-net{font-size:9.5px;color:var(--text);font-weight:500}.cal-net.neg{color:var(--red)}.cal-txns-section{border-top:2px solid var(--income)}.cal-txns-header{padding:8px 16px;font-size:12px;font-weight:600;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.btn-cal-add{padding:3px 10px;border-radius:var(--radius-sm);border:1.5px solid var(--income);background:none;cursor:pointer;font-size:11px;font-weight:600;color:var(--income);font-family:inherit;transition:all .12s}.btn-cal-add:hover{background:var(--green-light)}.monthly-year-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border-light);background:var(--bg)}.monthly-nav-btn{background:none;border:none;cursor:pointer;font-size:20px;color:var(--text-muted);padding:0 8px;line-height:1;font-family:inherit}.monthly-nav-btn:hover{color:var(--text)}.monthly-nav-year{font-size:16px;font-weight:600;color:var(--text)}.monthly-year-totals{display:grid;grid-template-columns:repeat(3,1fr);padding:12px 20px;border-bottom:1px solid var(--border-light);text-align:center}.myt-item{display:flex;flex-direction:column;gap:2px}.myt-label{font-size:11px;color:var(--text-muted)}.myt-value{font-size:15px;font-weight:600;color:var(--text)}.myt-value.income{color:var(--income)}.myt-value.expense{color:var(--expense)}.month-block{border-bottom:1px solid var(--border-light)}.month-block:last-child{border-bottom:none}.month-block-header{display:grid;grid-template-columns:1fr 110px 120px 20px;align-items:start;padding:12px 16px;cursor:pointer;transition:background .1s}.month-block-header:hover{background:var(--border-light)}.month-name{font-size:15px;font-weight:600;color:var(--text)}.month-range{font-size:11px;color:var(--text-hint);margin-top:2px}.month-income{font-size:13px;font-weight:500;color:var(--income);text-align:right;padding-top:1px}.month-expense-col{text-align:right}.month-expense{font-size:13px;font-weight:500;color:var(--expense)}.month-total{font-size:11.5px;color:var(--text-muted);margin-top:2px}.month-expand-icon{font-size:11px;color:var(--text-hint);text-align:right;padding-top:4px}.month-weeks{background:var(--bg)}.week-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.btn-back{display:flex;align-items:center;gap:6px;background:none;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:7px 16px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-muted);font-family:inherit;transition:all .15s}.btn-back:hover{background:var(--border-light);color:var(--text)}.month-week-row{display:grid;grid-template-columns:1fr 110px 120px;align-items:start;padding:8px 16px 8px 32px;border-top:1px solid var(--border-light);transition:background .1s;cursor:pointer}.month-week-row:hover:not(.this-week){background:var(--border-light)}.month-week-row.this-week{background:var(--green-light)}.month-week-row.this-week:hover{background:var(--green-light);filter:brightness(.97)}.week-range-label{font-size:12px;color:var(--text-muted);padding-top:2px}.week-income{font-size:12px;font-weight:500;color:var(--income);text-align:right;padding-top:1px}.week-expense-col{text-align:right}.week-expense{font-size:12px;font-weight:500;color:var(--expense)}.week-net{font-size:11.5px;color:var(--text-muted);margin-top:2px}.filter-bar{display:flex;align-items:center;flex-wrap:wrap;gap:5px;min-width:0;position:relative}.filter-chip{display:inline-flex;align-items:center;gap:4px;background:var(--income);color:#fff;padding:3px 8px 3px 10px;border-radius:99px;font-size:10.5px;font-weight:500;white-space:nowrap}.filter-chip-type{opacity:.7;font-size:9px;text-transform:uppercase;letter-spacing:.3px}.filter-chip .filter-chip-x{width:14px;height:14px;border-radius:50%;border:none;background:#ffffff40;color:#fff;cursor:pointer;font-size:11px;padding:0;line-height:1;display:flex;align-items:center;justify-content:center}.filter-chip .filter-chip-x:hover{background:#ffffff73}.filter-btn-icon{width:13px;height:13px;object-fit:contain;opacity:.6;flex-shrink:0}.filter-bar .filter-add-btn.active .filter-btn-icon{opacity:1;filter:brightness(10)}.filter-bar .filter-add-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .15s}.filter-bar .filter-add-btn:hover{background:var(--border-light);color:var(--text)}.filter-bar .filter-add-btn.active{background:var(--green);color:#fff;border-color:var(--green)}.filter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:149}.stats-mobile-tabs{display:none}.filter-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:150;width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000024;overflow:hidden}.filter-dd-title{padding:8px 14px 6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-hint);border-bottom:1px solid var(--border-light);background:var(--bg)}.filter-dropdown .filter-dd-opt{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 14px;text-align:left;border:none;border-bottom:1px solid var(--border-light);background:none;cursor:pointer;font-size:10px;color:var(--text);transition:background .1s}.filter-dropdown .filter-dd-opt:last-child{border-bottom:none}.filter-dropdown .filter-dd-opt:hover{background:var(--border-light)}.filter-dd-count{background:var(--border-light);color:var(--text-hint);font-size:10px;padding:1px 7px;border-radius:99px;flex-shrink:0}.filter-dropdown .filter-dd-back{display:block;width:100%;padding:7px 14px;border:none;border-bottom:1px solid var(--border-light);background:var(--bg);cursor:pointer;font-size:10px;color:var(--text-muted);text-align:left;transition:background .1s}.filter-dropdown .filter-dd-back:hover{background:var(--border-light)}.filter-dd-list{max-height:200px;overflow-y:auto}.filter-dd-empty{padding:10px 14px;font-size:11px;color:var(--text-hint);text-align:center}.filter-note-row{display:flex;gap:8px;align-items:center;padding:8px 12px}.filter-note-input{flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;font-size:12px;font-family:inherit;outline:none;color:var(--text)}.filter-note-input:focus{border-color:var(--income)}.filter-note-apply{padding:5px 10px;border-radius:var(--radius-sm);background:var(--income);color:#fff;border:none;cursor:pointer;font-size:11px;font-weight:600;font-family:inherit;transition:opacity .15s}.filter-note-apply:disabled{opacity:.35;cursor:not-allowed}.skeleton{background:var(--border-light);border-radius:4px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-msg{color:var(--red);font-size:12px;padding:8px 0}.settings-page{max-width:760px}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px}.settings-title{font-size:18px;font-weight:600;color:var(--text);flex-shrink:0}.settings-tabs{display:flex;gap:3px;background:var(--border-light);border-radius:var(--radius-md);padding:4px}.settings-tab{padding:6px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:none;background:none;color:var(--text-muted);font-family:DM Sans,sans-serif;transition:all .15s}.settings-tab.active{background:var(--surface);color:var(--green-dark);box-shadow:0 1px 3px #00000014}.settings-body{display:flex;flex-direction:column;gap:16px}.settings-back-btn{font-size:26px;line-height:1;padding:0 10px 0 0;border:none;background:none;cursor:pointer;color:var(--green-dark);font-family:DM Sans,sans-serif;display:flex;align-items:center}.settings-menu-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.settings-menu-item{position:relative;width:100%;display:flex;align-items:center;gap:14px;padding:14px 16px;border:none;background:none;cursor:pointer;text-align:left;font-family:DM Sans,sans-serif;transition:background .12s}.settings-menu-item:hover{background:var(--border-light)}.settings-menu-item:active{background:var(--border)}.settings-menu-icon{width:36px;height:36px;border-radius:9px;background:var(--green-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-menu-icon img{width:18px;height:18px;object-fit:contain}.settings-menu-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.settings-menu-label{font-size:14px;font-weight:500;color:var(--text)}.settings-menu-sub{font-size:12px;color:var(--text-muted)}.settings-menu-chevron{font-size:20px;color:var(--text-hint);line-height:1}.settings-menu-divider{position:absolute;bottom:0;left:64px;right:0;height:1px;background:var(--border-light)}.settings-loading{height:160px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);animation:pulse 1.5s ease-in-out infinite}.settings-empty{padding:20px 16px;text-align:center;font-size:13px;color:var(--text-hint)}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.settings-group-label{padding:7px 16px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-hint);background:var(--bg);border-bottom:1px solid var(--border-light);border-top:1px solid var(--border-light)}.settings-section>div:first-child .settings-group-label{border-top:none}.settings-item-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border-light);transition:background .1s}.settings-item-row:last-child{border-bottom:none}.settings-item-row:hover{background:var(--border-light)}.settings-item-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0;line-height:1}.settings-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.settings-item-name{font-size:13.5px;font-weight:500;color:var(--text)}.settings-item-sub{font-size:11.5px;color:var(--text-hint)}.settings-item-badge{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--border-light);padding:3px 10px;border-radius:99px;white-space:nowrap;flex-shrink:0}.settings-item-actions{display:flex;gap:1px;flex-shrink:0}.settings-btn-icon{width:28px;height:28px;border-radius:var(--radius-sm);border:none;background:none;cursor:pointer;font-size:13px;color:var(--text-hint);display:flex;align-items:center;justify-content:center;transition:all .12s;font-family:inherit;flex-shrink:0}.settings-btn-icon:hover{background:var(--border);color:var(--text)}.settings-btn-icon:disabled{opacity:.25;cursor:default;pointer-events:none}.settings-btn-icon.edit:hover{background:var(--green-light);color:var(--green-dark)}.settings-btn-icon.del:hover{background:var(--red-light);color:var(--red)}.settings-btn-sm{padding:3px 9px;border-radius:var(--radius-sm);font-size:11px;border:1.5px solid var(--border);background:none;cursor:pointer;color:var(--text-muted);font-family:inherit;transition:all .12s;flex-shrink:0;white-space:nowrap}.settings-btn-sm:hover{background:var(--green-light);border-color:var(--green);color:var(--green-dark)}.settings-expand-btn{width:20px;height:20px;flex-shrink:0;border:none;background:none;cursor:pointer;font-size:11px;color:var(--text-hint);padding:0;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .12s}.settings-expand-btn:hover{background:var(--border)}.settings-add-btn{padding:11px 20px;border:1.5px dashed var(--border);border-radius:var(--radius-lg);background:none;cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text-muted);font-family:inherit;transition:all .15s;width:100%}.settings-add-btn:hover{background:var(--green-light);border-color:var(--green);color:var(--green-dark)}.settings-type-toggle{display:flex;gap:6px;margin-bottom:12px}.settings-type-btn{padding:6px 22px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-family:inherit;transition:all .15s}.settings-type-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.settings-cat-block{border-bottom:1px solid var(--border-light)}.settings-cat-block:last-child{border-bottom:none}.settings-cat-block>.settings-item-row{border-bottom:none}.settings-children{background:var(--bg)}.settings-child-row{padding-left:24px;background:var(--bg)}.settings-child-row:last-child{border-bottom:none}.settings-currency-table{overflow:hidden}.settings-currency-row{display:grid;grid-template-columns:1fr 80px 44px 40px 36px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border-light);gap:8px}.settings-currency-row:last-child{border-bottom:none}.settings-currency-head{background:var(--bg);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-hint)}.cur-code{display:flex;flex-direction:column;gap:2px}.cur-code-label{font-size:14px;font-weight:600;color:var(--text)}.cur-symbol-inline{font-size:13px;font-weight:400;color:var(--text-muted)}.cur-name{font-size:11px;color:var(--text-hint)}.cur-rate{font-size:12px;color:var(--text-muted);white-space:nowrap;text-align:right}.cur-flag-cell{display:flex;justify-content:center;align-items:center}.currency-flag-on{font-size:13px;font-weight:600;color:var(--green)}.currency-flag-off{font-size:13px;color:var(--border)}.field-select{flex:1;border:none;outline:none;background:transparent;font-size:13.5px;font-family:DM Sans,sans-serif;color:var(--text);cursor:pointer;min-width:0;padding:2px 0}.field-checkbox-label{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:13px;color:var(--text);-webkit-user-select:none;user-select:none}.field-checkbox-label input[type=checkbox]{accent-color:var(--green);width:15px;height:15px;flex-shrink:0}.account-summary-strip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 24px;display:flex;align-items:center;gap:0}.account-summary-item{flex:1;display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center}.account-summary-label{font-size:11px;color:var(--text-hint);text-transform:uppercase;letter-spacing:.5px}.account-summary-value{font-size:17px;font-weight:600;color:var(--text)}.account-summary-value.income{color:var(--income)}.account-summary-value.expense{color:var(--expense)}.account-summary-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}.settings-month-label{font-size:13px;font-weight:500;color:var(--text-muted);background:var(--border-light);padding:5px 14px;border-radius:20px}.budget-page-row{padding:12px 16px;border-bottom:1px solid var(--border-light);transition:background .1s}.budget-page-row:last-child{border-bottom:none}.budget-page-row:hover{background:var(--border-light)}.budget-page-row-top{display:flex;align-items:center;justify-content:space-between}.budget-page-row-name{font-size:14px;font-weight:500;color:var(--text)}.budget-page-row-detail{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-top:4px}.settings-modal{background:var(--surface);border-radius:var(--radius-lg);width:380px;max-width:95vw;box-shadow:0 20px 56px #00000038;overflow:hidden}.settings-modal-header{background:#1a1a1a;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}.settings-modal-title{color:#fff;font-size:15px;font-weight:600}.settings-modal-body{padding:16px;display:flex;flex-direction:column;gap:10px}.settings-modal-footer{padding:0 16px 16px;display:flex;flex-direction:column;gap:6px}.bottom-nav{display:none}@media (max-width: 1023px){.content-grid,.stats-page-grid{grid-template-columns:1fr}.main{padding:18px}}@media (max-width: 639px){.sidebar{display:none}.layout{flex-direction:column}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(54px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface);border-top:1px solid var(--border);z-index:100;align-items:stretch}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 1px 4px;border:none;background:none;cursor:pointer;color:var(--text-hint);font-size:8.5px;font-weight:500;font-family:DM Sans,sans-serif;overflow:hidden;transition:color .15s}.bottom-nav-item img{width:19px;height:19px;object-fit:contain;opacity:.35;flex-shrink:0;transition:opacity .15s}.bottom-nav-item.active{color:var(--green-dark)}.bottom-nav-item.active img{opacity:1}.main{padding:14px;padding-bottom:calc(68px + env(safe-area-inset-bottom,0px))}.navbar{padding:0 14px;height:52px}.user-pill{padding:3px;border-radius:50%;border:1.5px solid var(--border)}.user-name,.btn-add{display:none}.fab-add{display:flex;align-items:center;justify-content:center;position:fixed;bottom:calc(66px + env(safe-area-inset-bottom,0px));right:16px;width:46px;height:46px;border-radius:14px;background:var(--green-btn);color:#fff;border:none;font-size:26px;font-weight:300;cursor:pointer;z-index:90;box-shadow:0 4px 14px #0000002e}.month-pill:not(.active){display:none}.month-nav{gap:8px;margin-bottom:12px;align-items:flex-start}.filter-bar{flex-direction:column;align-items:flex-end;gap:5px}.filter-bar .filter-add-btn{order:-1}.filter-chip{white-space:normal;text-align:left}.summary-bar{padding:10px 4px;margin-bottom:14px}.summary-card{display:grid;grid-template-columns:max-content max-content;justify-content:center;gap:1px 5px;padding:6px 4px;align-items:center}.summary-card:first-child{padding-left:2px}.summary-card:last-child{padding-right:2px}.summary-body{display:contents}.summary-icon{grid-column:1;grid-row:1;width:16px;height:16px;background:none;border-radius:0}.summary-icon svg{width:14px;height:14px}.summary-label{grid-column:2;grid-row:1;font-size:10px;margin-bottom:0}.summary-amount{grid-column:1 / 3;grid-row:2;font-size:14px;text-align:center;padding-top:3px}.summary-sub{display:none}.chart-area{flex-direction:column;align-items:center}.chart-legend{width:100%}.stats-mobile-tabs{display:flex;gap:2px;background:var(--border-light);border-radius:var(--radius-sm);padding:3px;margin-bottom:12px}.stats-mobile-hidden{display:none}.content-grid{gap:14px}.txn-panel-header{flex-direction:column;align-items:flex-start;gap:6px;padding:10px 14px}.txn-header-spacer{display:none}.txn-row{grid-template-columns:80px 1fr 82px;padding:8px 14px}.txn-amount,.txn-name{font-size:12.5px}.day-header{padding:8px 14px}.day-num{font-size:16px}.day-totals{gap:10px;font-size:12px}.settings-page{max-width:100%}.settings-header{margin-bottom:12px}.budget-page-row{padding:10px 12px}.month-block-header{grid-template-columns:1fr 76px 84px 18px;padding:10px 12px}.month-week-row{grid-template-columns:1fr 76px 84px;padding:8px 12px 8px 22px}.monthly-year-nav{padding:8px 14px}.monthly-year-totals{padding:10px 14px}.month-name{font-size:13px}.month-income,.month-expense{font-size:12px}.week-income,.week-expense{font-size:11.5px}.week-net{font-size:11px}.account-summary-strip{padding:12px 14px}.account-summary-value{font-size:15px}.account-summary-label{font-size:10px}.cal-cell{min-height:52px;padding:3px}.cal-day-num{font-size:10.5px}.cal-in,.cal-ex,.cal-net{font-size:8.5px}}
