*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font:"Inter", system-ui, sans-serif;--bg-base:#080811;--bg-surface:#0f0f1a;--bg-card:#13131f;--bg-card-hover:#171726;--bg-input:#0c0c18;--bg-sidebar:#0a0a16;--border:#ffffff0f;--border-active:#8b5cf666;--text-primary:#e2e8f0;--text-secondary:#8892a4;--text-muted:#4a5568;--text-heading:#f1f5f9;--accent:#8b5cf6;--accent-hover:#7c3aed;--accent-light:#8b5cf626;--accent-glow:#8b5cf64d;--income:#10b981;--income-bg:#10b9811f;--expense:#f43f5e;--expense-bg:#f43f5e1f;--expense-muted:#f43f5eb8;--income-muted:#10b981b8;--warning:#f59e0b;--warning-bg:#f59e0b1f;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 20px #8b5cf633;--sidebar-w:240px;--header-h:64px;--radius:12px;--radius-sm:8px;--radius-lg:16px}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}h1,h2,h3,h4{color:var(--text-heading);font-weight:600;line-height:1.2}h1{font-size:24px}h2{font-size:20px}h3{font-size:16px}h4{font-size:13px;font-weight:500}p{color:var(--text-secondary)}.btn{border-radius:var(--radius-sm);font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--accent-light);color:var(--text-primary);border-color:var(--border-active)}.btn-danger{color:var(--expense);background:0 0;border:1px solid #f43f5e33}.btn-danger:hover{background:var(--expense-bg)}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:8px;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--accent-light);color:var(--accent)}.input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}select.input{cursor:pointer}.icon-select{width:100%;position:relative}.icon-select-trigger{text-align:left;cursor:pointer;justify-content:space-between;align-items:center;gap:8px;display:flex}.icon-select-trigger-content{align-items:center;gap:8px;min-height:20px;display:inline-flex}.icon-select-trigger-icon{color:var(--text-muted);align-items:center;display:inline-flex}.icon-select-placeholder{color:var(--text-muted)}.icon-select-chevron{color:var(--text-muted);flex-shrink:0}.icon-select-trigger-open{border-color:var(--accent)}.icon-select-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-height:220px;box-shadow:var(--shadow-lg);z-index:100;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.icon-select-option{width:100%;color:var(--text);font-size:inherit;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;transition:background .1s;display:flex}.icon-select-option:hover{background:var(--bg-card-hover)}.icon-select-option-selected{background:var(--accent-subtle)}.icon-select-option-icon{color:var(--text-muted);flex-shrink:0;align-items:center;display:inline-flex}.icon-select-add-new{border-top:1px solid var(--border);color:var(--accent);margin-top:2px;padding-top:12px;font-weight:500}.icon-select-add-new:hover{background:var(--accent-light)}.icon-select-add-new .icon-select-option-icon{color:var(--accent)}.category-quick-add-backdrop{z-index:60}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.badge{border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-income{background:var(--income-bg);color:var(--income)}.badge-expense{background:var(--expense-bg);color:var(--expense)}.login-page{background:var(--bg-base);background-image:radial-gradient(80% 60% at 50% -10%,#8b5cf61f,#0000),radial-gradient(60% 40% at 80% 80%,#3b82f60f,#0000);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:400px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);padding:48px 40px}.login-logo{align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-logo-icon{background:var(--accent-light);border:1px solid var(--border-active);width:44px;height:44px;color:var(--accent);border-radius:10px;justify-content:center;align-items:center;display:flex}.login-logo h1{color:var(--text-heading);font-size:22px;font-weight:700}.login-logo span{color:var(--text-secondary);font-size:13px;font-weight:400}.login-form{flex-direction:column;gap:16px;display:flex}.login-form label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.login-error{color:var(--expense);background:var(--expense-bg);border-radius:var(--radius-sm);border:1px solid #f43f5e33;padding:10px 14px;font-size:13px}.auth-page{background:var(--bg-base);background-image:radial-gradient(80% 60% at 50% -10%,#8b5cf61f,#0000),radial-gradient(60% 40% at 80% 80%,#3b82f60f,#0000);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:420px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);padding:40px 40px 36px}.auth-logo{align-items:center;gap:12px;margin-bottom:28px;display:flex}.auth-logo-icon{background:var(--accent-light);border:1px solid var(--border-active);width:44px;height:44px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.auth-logo h1{color:var(--text-heading);font-size:20px;font-weight:700;line-height:1.2}.auth-logo span{color:var(--text-secondary);font-size:13px;font-weight:400}.auth-tabs{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);gap:4px;margin-bottom:24px;padding:4px;display:flex}.auth-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 12px;font-size:13px;font-weight:500;transition:all .15s}.auth-tab:hover{color:var(--text-primary)}.auth-tab--active{background:var(--accent);color:#fff}.auth-tab--active:hover{color:#fff}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.auth-password-wrap{position:relative}.auth-password-wrap .input{width:100%;padding-right:40px}.auth-eye{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.auth-eye:hover{color:var(--text-secondary)}.auth-error{color:var(--expense);background:var(--expense-bg);border-radius:var(--radius-sm);border:1px solid #f43f5e33;padding:10px 14px;font-size:13px}.auth-submit{justify-content:center;width:100%;margin-top:4px;padding:10px 16px;font-size:14px;font-weight:600}.auth-footer{color:var(--text-muted);text-align:center;margin-top:20px;font-size:13px}.auth-link{color:var(--accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.auth-link:hover{color:var(--accent-hover)}.app-layout{height:100vh;display:flex;overflow:hidden}.main-header-left{align-items:center;gap:12px;min-width:0;display:flex}.main-header-titles{min-width:0}.mobile-menu-toggle{border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:none}.mobile-menu-toggle:hover{background:var(--accent-light);color:var(--accent);border-color:var(--border-active)}.mobile-menu-backdrop{z-index:55;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000a6;transition:opacity .2s;position:fixed;inset:0}.mobile-menu-backdrop.open{opacity:1;pointer-events:auto}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;padding:0 0 16px;display:flex}.sidebar-brand{height:var(--header-h);border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:0;padding:0 20px;display:flex}.sidebar-brand-icon{background:var(--accent-light);border:1px solid var(--border-active);width:36px;height:36px;color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-text strong{color:var(--text-heading);font-size:15px;font-weight:700;display:block}.sidebar-brand-text span{color:var(--text-muted);font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px 0;display:flex}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;font-size:14px;font-weight:500;font-family:var(--font);box-sizing:border-box;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;transition:all .15s;display:flex}.sidebar-nav-item:hover{background:var(--accent-light);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-light)}.sidebar-nav-item.active svg{color:var(--accent)}.sidebar-nav-item svg{flex-shrink:0}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:2px;margin:0 12px;padding:16px 12px 0;display:flex}.sidebar-user{align-items:center;gap:10px;padding:8px 0 12px;display:flex}.sidebar-avatar{background:var(--accent-light);border:1px solid var(--border-active);width:32px;height:32px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.sidebar-username{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:500;overflow:hidden}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.main-header{height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:0 28px;display:flex}.main-header-left h2{font-size:18px;font-weight:600}.main-header-left p{color:var(--text-muted);margin-top:1px;font-size:13px}.main-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.month-nav{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:4px;padding:4px;display:flex;overflow:hidden}.month-nav-btn{width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.month-nav-btn:hover{background:var(--accent-light);color:var(--accent)}.month-nav-label{color:var(--text-primary);text-align:center;min-width:100px;padding:0 8px;font-size:13px;font-weight:600}.month-nav-select{background:var(--bg-input);border:1px solid var(--border);height:30px;color:var(--text-primary);font-size:13px;font-family:var(--font);border-radius:6px;outline:none;padding:0 8px}.month-nav-select:focus{border-color:var(--accent)}.month-nav-select-month{min-width:130px}.month-nav-select-year{min-width:82px}.month-nav-select-monthyear{min-width:150px;display:none}.main-body{flex:1;padding:20px;overflow-y:auto}.dashboard-grid{grid-template-columns:2fr 1fr 1fr;align-items:start;gap:20px;display:grid;container:dashboard-grid/inline-size}.dashboard-left-col,.dashboard-right-col,.dashboard-hero-left{display:contents!important}.dashboard-grid .dashboard-pie-card{aspect-ratio:auto;grid-area:1/1;justify-self:stretch;width:100%;height:calc(25cqw - 10px);min-height:calc(25cqw - 10px)}.dashboard-balance-value-card{grid-area:1/2}.dashboard-balance-card-right{grid-area:1/3}.dashboard-two-col-left{grid-area:2/1}.dashboard-two-col-right{grid-area:2/2/auto/4}.dashboard-grid.safari-stable{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:20px;display:grid;container-type:normal}.dashboard-grid.safari-stable .dashboard-left-col,.dashboard-grid.safari-stable .dashboard-right-col{width:auto;min-width:0}.dashboard-grid.safari-stable .dashboard-hero-left{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;display:grid}.dashboard-grid.safari-stable .dashboard-square-card,.dashboard-grid.safari-stable .dashboard-balance-card-right{aspect-ratio:auto;height:auto;min-height:260px}.dashboard-grid.safari-stable .dashboard-balance-fill{min-height:180px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:20px;transition:border-color .15s;display:flex}.stat-card:hover{border-color:#ffffff1a}.stat-header{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon-balance{background:var(--accent-light);color:var(--accent)}.stat-icon-income{background:var(--income-bg);color:var(--income)}.stat-icon-expense{background:var(--expense-bg);color:var(--expense)}.stat-icon-budget{background:var(--warning-bg);color:var(--warning)}.stat-value{color:var(--text-heading);font-size:26px;font-weight:700;line-height:1}.stat-value.positive{color:var(--income)}.stat-value.negative{color:var(--expense)}.dashboard-left-col{flex-direction:column;align-items:flex-start;gap:20px;min-width:0;display:flex}.dashboard-right-col{flex-direction:column;gap:20px;min-width:0;display:flex}.dashboard-hero-left{grid-template-columns:1fr 1fr;gap:20px;width:100%;display:grid}.dashboard-square-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);aspect-ratio:1;flex-direction:column;min-height:0;padding:20px;display:flex}@supports (-webkit-touch-callout:none){.dashboard-grid{container-type:normal}.dashboard-hero-left{flex-direction:column;gap:20px;display:flex}.dashboard-square-card{aspect-ratio:auto;backface-visibility:visible;contain:paint;min-height:320px;transform:none}.dashboard-pie-fill,.dashboard-balance-fill,.budget-vs-actual-section,.recent-section{backface-visibility:visible;contain:paint;transform:none}.dashboard-left-col .dashboard-square-card svg,.dashboard-left-col .dashboard-square-card .recharts-wrapper,.dashboard-left-col .dashboard-square-card .recharts-surface,.dashboard-left-col .dashboard-square-card .recharts-layer,.dashboard-left-col .dashboard-square-card .recharts-sector,.dashboard-left-col .dashboard-square-card .recharts-curve{backface-visibility:visible!important;transition:none!important;animation:none!important;transform:none!important}.dashboard-left-col,.dashboard-left-col *{transform:none;transform-style:flat!important;perspective:none!important}.dashboard-left-col *{animation:none!important}}.dashboard-pie-card .chart-card-header{flex-shrink:0}.dashboard-pie-card .chart-legend{flex:0 auto;justify-content:flex-start;min-height:0;max-height:150px;padding-right:4px;overflow:hidden auto}.dashboard-pie-2col{flex:1;align-items:stretch;gap:16px;min-height:0;display:flex}.dashboard-pie-2col .dashboard-pie-fill{flex:0 0 44%;width:auto;height:100%;min-height:0}.dashboard-pie-2col .chart-legend{flex:1;justify-content:safe center;height:100%;max-height:none}.dashboard-pie-2col .dashboard-pie-donut-wrap{height:100%;min-height:0}.dashboard-pie-card .dashboard-pie-fill{flex:1;width:100%;min-height:140px}.dashboard-pie-donut-wrap{justify-content:center;align-items:center;width:100%;height:100%;min-height:140px;display:flex}.dashboard-pie-donut{aspect-ratio:1;border-radius:50%;width:min(100%,220px);position:relative}.dashboard-pie-donut-hole{background:var(--bg-card);border-radius:50%;position:absolute;inset:30%}.dashboard-balance-card .chart-card-header{flex-shrink:0}.dashboard-balance-fill{flex:1;width:100%;min-height:0}.dashboard-pie-empty{padding:60px 40px}.dashboard-balance-value-card{flex-direction:column;gap:0;padding:0;display:flex}.dashboard-balance-rect{border-bottom:1px solid var(--border);flex-direction:column;flex:1;min-height:0;padding:12px 20px;display:flex}.dashboard-balance-rect:last-child{border-bottom:none}.dashboard-balance-rect-title{color:var(--text-primary);flex-shrink:0;margin:0 0 8px;font-size:15px;font-weight:600}.dashboard-balance-list{flex-direction:column;flex:1;justify-content:center;gap:6px;min-height:0;display:flex}.dashboard-balance-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.dashboard-balance-label{color:var(--text-muted);flex-shrink:0;font-size:12px}.dashboard-balance-num{color:var(--text-primary);text-align:right;font-size:14px;font-weight:600}.dashboard-balance-num.positive{color:var(--income)}.dashboard-balance-num.negative{color:var(--expense-muted)}.dashboard-balance-transfer-wrap{border-top:1px solid var(--border);flex-direction:column;align-items:stretch;gap:6px;margin-top:10px;padding-top:10px;display:flex}.dashboard-balance-transfer-btn{justify-content:center;align-items:center;gap:8px;width:100%;font-size:12px;font-weight:600;display:inline-flex}.dashboard-balance-transfer-hint{color:var(--text-muted);text-align:center;font-size:11px}.dashboard-balance-transfer-hint .dashboard-balance-num{font-size:11px;font-weight:700}.dashboard-balance-transfer-error{color:var(--expense-muted);text-align:center;font-size:11px}.dashboard-balance-transfer-btn-remove:not(:disabled){color:var(--text-muted)}.dashboard-balance-transfer-btn-remove:not(:disabled):hover{color:var(--expense-muted)}.carry-over-transfer-section{border:1px solid var(--border);background:#ffffff05;border-radius:12px;margin:0 0 20px;padding:14px 16px}.carry-over-transfer-header{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.carry-over-transfer-title{color:var(--text-primary);font-size:13px;font-weight:700}.carry-over-transfer-note{color:var(--text-muted);font-size:11px;line-height:1.35}.carry-over-transfer-rows{flex-direction:column;gap:8px;display:flex}.dashboard-placeholder-card .chart-card-header{flex-shrink:0}.dashboard-placeholder-content{min-height:0;color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.dashboard-placeholder-content p{margin:0}.dashboard-stats-blocks{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.dashboard-stats-blocks .stat-card{padding:14px 16px}.dashboard-stats-blocks .stat-value{font-size:20px}.charts-row{grid-template-columns:1fr 380px;gap:20px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-pie-card .chart-card-header{border-bottom:1px solid var(--border);margin-bottom:0;padding-bottom:20px}.chart-card-header h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.chart-legend{flex-direction:column;gap:12px;display:flex}.chart-legend-item{justify-content:space-between;align-items:center;gap:8px;display:flex}.chart-legend-left{align-items:center;gap:8px;min-width:0;display:flex}.chart-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chart-legend-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.chart-legend-amount{color:var(--text-primary);flex-shrink:0;font-size:13px;font-weight:600}.chart-legend-right{flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;display:inline-flex}.chart-legend-percent{text-align:right;min-width:40px;color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:12px}.dashboard-two-col{grid-template-columns:1fr 1fr;align-items:stretch;gap:20px;display:grid}.dashboard-two-col-left{flex-direction:column;gap:20px;display:flex}.budget-expense-card{order:1}.budget-income-card{order:2}.budget-recent-card{order:3}.dashboard-two-col-right{flex-direction:column;align-self:start;width:100%;min-width:0;display:flex}.dashboard-placeholder-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);justify-content:center;align-items:center;min-height:200px;padding:24px 20px;font-size:14px;display:flex}.dashboard-placeholder-block p{margin:0}.budget-vs-actual-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.budget-vs-actual-table-wrap{overflow-x:auto}.budget-vs-actual-table{border-collapse:collapse;width:100%;font-size:14px}.budget-vs-actual-table th,.budget-vs-actual-table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 20px}.budget-vs-actual-table th{color:var(--text-secondary);background:var(--bg-surface);font-weight:600}.budget-vs-actual-table th.num,.budget-vs-actual-table td.num{text-align:right}.budget-vs-actual-table tbody tr:last-child td{border-bottom:none}.budget-table-category-row{cursor:pointer;transition:background .1s,opacity .15s}.budget-table-category-row:hover{background:var(--bg-card-hover)}.budget-table-category-row-expanded{opacity:.6;background:var(--bg-surface)}.budget-table-category-row-expanded .num,.budget-table-category-row-expanded .num.positive,.budget-table-category-row-expanded .num.negative{color:var(--text-muted)}.budget-table-category-row-expanded:hover{opacity:.85;background:var(--bg-card-hover)}.budget-table-subcategory-row{background:#8b5cf614}.budget-table-subcategory-row:hover{background:#8b5cf624}.budget-table-subcategory-row-last td{border-bottom:2px solid #ffffffbf!important}.budget-table-subcategory-cell{color:var(--text-secondary);padding-left:28px;font-size:13px}.budget-table-budgeted-cell{position:relative}.budget-table-budgeted-editable{cursor:pointer;border-radius:4px;margin:-2px -6px;padding:2px 6px;display:inline-block}.budget-table-budgeted-editable:hover{background:var(--bg-card-hover)}.budget-table-edit-wrap{align-items:center;gap:6px;display:inline-flex}.budget-table-budgeted-input{width:72px;font-size:14px;font-family:var(--font);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);text-align:right;border-radius:4px;padding:4px 8px}.budget-table-budgeted-input:focus{border-color:var(--accent);outline:none}.budget-table-budgeted-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.budget-table-budgeted-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.budget-table-budgeted-input[type=number]{appearance:textfield}.budget-table-save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;padding:0;transition:background .15s,transform .1s;display:inline-flex}.budget-table-save-btn:hover{background:var(--accent-hover,color-mix(in srgb, var(--accent) 85%, white))}.budget-table-save-btn:active{transform:scale(.96)}.budget-vs-actual-table td.num.positive{color:var(--income)}.budget-vs-actual-table td.num.negative{color:var(--expense-muted)}.budget-vs-actual-table .budget-table-category-row-expanded td.num,.budget-vs-actual-table .budget-table-category-row-expanded td.num.positive,.budget-vs-actual-table .budget-table-category-row-expanded td.num.negative{color:var(--text-muted)}.budget-header-income{color:var(--income)}.budget-header-expense{color:var(--expense)}.budget-table-total-row{background:var(--bg-surface);border-top:2px solid var(--border);font-weight:600}.budget-table-total-row td{padding-top:14px;padding-bottom:14px}.recent-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-top:0;overflow:hidden}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.section-header h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.filter-bar{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-tab{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);background:0 0;border-radius:99px;padding:6px 16px;transition:all .15s}.filter-tab:hover{border-color:var(--border-active);color:var(--text-primary)}.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.sort-mode-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.sort-mode-label{color:var(--text-muted);font-size:13px;font-weight:500}.sort-mode-switch{gap:6px;display:flex}.sort-mode-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);background:0 0;border-radius:99px;padding:6px 14px;transition:all .15s}.sort-mode-btn:hover{border-color:var(--border-active);color:var(--text-primary)}.sort-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.tx-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow:hidden}.tx-group{border-bottom:1px solid var(--border)}.tx-group:last-child{border-bottom:none}.tx-group-header,.tx-subgroup-header{background:var(--bg-card);cursor:pointer;width:100%;font-family:var(--font);color:var(--text-primary);text-align:left;border:none;align-items:center;gap:10px;padding:12px 20px;font-size:14px;font-weight:500;transition:background .1s;display:flex}.tx-group-header:hover,.tx-subgroup-header:hover{background:var(--bg-card-hover)}.tx-group-chevron{color:var(--text-muted);flex-shrink:0;align-items:center;display:flex}.tx-group-title{flex:1;min-width:0}.tx-subgroup-header{background:var(--bg-surface);padding:10px 20px 10px 36px;font-size:13px;font-weight:500}.tx-subgroup-header:hover{background:var(--bg-card-hover)}.tx-subgroup-sum{flex-shrink:0;font-size:12px;font-weight:600}.tx-subgroup-header-expense .tx-subgroup-sum{color:var(--expense-muted)}.tx-subgroup-header-income .tx-subgroup-sum{color:var(--income-muted)}.tx-subgroup-title{min-width:0;color:var(--text-secondary);flex:1}.tx-group-count{color:var(--text-muted);flex-shrink:0;font-size:12px}.tx-group-body{border-top:1px solid var(--border)}.tx-subgroup{border-bottom:1px solid var(--border)}.tx-subgroup:last-child{border-bottom:none}.tx-subgroup .tx-group-body{border-top:none;padding-left:62px}.tx-type-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;margin-bottom:20px;display:flex;overflow:hidden}.tx-type-section:last-child{margin-bottom:0}.tx-type-section-header{background:var(--bg-surface);color:var(--text-primary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 20px;font-size:14px;font-weight:600;display:flex}.tx-type-section-title{flex:1}.tx-type-section-sum{flex-shrink:0;font-weight:700}.tx-type-section-sum.income{color:var(--income)}.tx-type-section-sum.expense{color:var(--expense)}.tx-type-section-body{flex:1}.tx-type-section-total{border-top:1px solid var(--border);text-align:center;color:var(--text-primary);flex-shrink:0;margin-top:auto;padding:14px 20px;font-size:14px;font-weight:700}.tx-type-section-total.expense{color:var(--expense)}.tx-type-section-total.income{color:var(--income)}.recurring-page,.recurring-layout{flex-direction:column;gap:20px;display:flex}.recurring-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;padding:18px 18px 16px;display:flex}.recurring-section-right{display:flex}.recurring-schedule{flex-direction:column;flex:1;gap:12px;padding-right:4px;display:flex}.recurring-list{flex-direction:column;gap:12px;display:flex}.recurring-list-heading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:600}.recurring-row{border:1px solid var(--border-subtle);background:linear-gradient(135deg,#94a3b812,#0000);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.recurring-row-main{align-items:flex-start;gap:10px;display:flex}.recurring-dot{border-radius:999px;width:9px;height:9px;margin-top:6px}.recurring-dot.income{background:var(--income)}.recurring-dot.expense{background:var(--expense)}.recurring-row-title{align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.recurring-row-interval{color:var(--text-muted);background:#94a3b82e;border-radius:999px;padding:2px 8px;font-size:11px}.recurring-row-interval-meta{display:none}.recurring-row-meta-income-pct{color:var(--text-muted);text-overflow:ellipsis;max-width:100%;font-size:11px;line-height:1.3;display:block;overflow:hidden}.recurring-row-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:8px;min-width:0;margin-top:2px;font-size:12px;display:flex}.recurring-row-meta-category,.recurring-row-meta-date{white-space:nowrap;text-overflow:ellipsis;display:inline-block;overflow:hidden}.recurring-row-meta-category{max-width:220px}.recurring-row-right{align-items:center;gap:10px;display:flex}.recurring-row-top-actions,.recurring-row-bottom-actions{align-items:center;gap:6px;display:inline-flex}.recurring-row-amount{font-size:14px;font-weight:600}.recurring-row-amount.income{color:var(--income)}.recurring-row-amount.expense{color:var(--expense)}.recurring-month-block{border:1px solid var(--border);background:var(--bg-card);border-radius:12px;padding:10px 12px}.recurring-month-header{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.recurring-month-label{font-size:13px;font-weight:600}.recurring-month-count{color:var(--text-muted);font-size:12px}.recurring-month-body{flex-direction:column;gap:6px;display:flex}.recurring-occ-row{justify-content:space-between;align-items:center;gap:10px;padding:7px 0;display:flex}.recurring-occ-main{align-items:center;gap:10px;display:flex}.recurring-occ-status{justify-content:center;align-items:center;width:20px;display:flex}.recurring-occ-status-btn{cursor:pointer;color:inherit;background:0 0;border:none;justify-content:center;align-items:center;margin:0;padding:0;display:inline-flex}.recurring-occ-status-btn:hover{opacity:.85}.recurring-paid-icon{color:var(--income)}.recurring-unpaid-icon{color:var(--text-muted)}.recurring-occ-info{flex-direction:column;gap:2px;display:flex}.recurring-occ-title{align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.recurring-occ-type{color:var(--text-muted);border:1px solid #94a3b866;border-radius:999px;padding:1px 6px;font-size:10px}.recurring-occ-type.income{border-color:#16a34a99}.recurring-occ-type.expense{border-color:#ef444499}.recurring-occ-meta{color:var(--text-muted);flex-wrap:wrap;gap:4px;font-size:11px;display:flex}.recurring-occ-right{align-items:center;gap:8px;display:flex}.recurring-occ-amount{font-size:13px;font-weight:600}.recurring-occ-amount.income{color:var(--income)}.recurring-occ-amount.expense{color:var(--expense)}.dashboard-recurring-list{padding:0 20px 16px}.dashboard-recurring-list .recurring-occ-row{border-bottom:1px solid var(--border);padding:12px 0}.dashboard-recurring-list .recurring-occ-row.moving-to-paid{animation:.22s recurringMoveToPaid}@keyframes recurringMoveToPaid{0%{opacity:1;transform:translateY(0)}to{opacity:.35;transform:translateY(14px)}}.dashboard-recurring-list .recurring-occ-row:last-child{border-bottom:none}.btn-ghost-small{padding:4px 8px;font-size:11px}.recurring-amount-input{text-align:right;width:110px;padding-inline:8px;font-size:13px}.recurring-amount-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.recurring-amount-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.recurring-amount-input[type=number]{appearance:textfield}.recurring-amount-display{cursor:pointer;background:0 0;border:none;padding:0}.recurring-amount-display:hover{text-decoration:underline}.btn-pay-active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-pay-active:hover{background:var(--accent-hover)}.tx-group-sum{flex-shrink:0;margin-right:8px;font-size:13px;font-weight:600}.tx-group-sum.income{color:var(--income)}.tx-group-sum.expense{color:var(--expense)}.tx-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 16px;transition:background .1s;display:flex}.tx-item:last-child{border-bottom:none}.tx-item:hover{background:var(--bg-card-hover)}.tx-item-compact{gap:8px;padding:6px 16px}.tx-item-compact-amount{flex-shrink:0;font-size:12px;font-weight:600}.tx-item-compact-expense .tx-item-compact-amount{color:var(--expense-muted)}.tx-item-compact-income .tx-item-compact-amount{color:var(--income-muted)}.tx-item-compact-desc{min-width:0;color:var(--text-primary);flex:1;font-size:13px}.tx-item-compact .tx-date{font-size:12px}.tx-item-compact .btn-icon{padding:4px}.tx-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.tx-icon-income{background:var(--income-bg);color:var(--income)}.tx-icon-expense{background:var(--expense-bg);color:var(--expense)}.tx-info{flex:1;min-width:0}.tx-name{color:var(--text-primary);font-size:13px;font-weight:500}.tx-meta{color:var(--text-muted);gap:6px;margin-top:1px;font-size:11px;display:flex}.tx-amount{text-align:right;flex-shrink:0;min-width:85px;font-size:14px;font-weight:600}.tx-amount.income{color:var(--income)}.tx-amount.expense{color:var(--expense)}.tx-date{color:var(--text-muted);text-align:right;flex-shrink:0;width:72px;min-width:72px;font-size:11px}.empty-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state svg{opacity:.3}.empty-state p{font-size:14px}.budget-page{flex-direction:column;gap:24px;display:flex}.budget-top-charts{grid-template-columns:1fr 1fr;gap:20px;display:grid}.budget-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;min-height:380px;padding:20px;display:flex}.budget-chart-card .chart-card-header{border-bottom:1px solid var(--border);margin-bottom:0;padding-bottom:16px}.budget-chart-2col{flex:1;align-items:stretch;gap:16px;min-height:0;padding-top:16px;display:flex}.budget-chart-fill{flex:0 0 44%;min-height:0}.budget-chart-card .chart-legend{flex:1;justify-content:center;height:100%;min-height:0;max-height:none;padding-right:4px;overflow:hidden auto}.budget-chart-empty{flex:1}.budget-chart-total{border-top:1px solid var(--border);text-align:center;color:var(--text-primary);flex-shrink:0;margin-top:auto;padding-top:14px;font-size:14px;font-weight:700}.budget-chart-total-inline{justify-content:center;align-items:center;gap:8px;display:flex}.budget-chart-total.expense{color:var(--expense)}.budget-chart-total.income{color:var(--income)}.budget-chart-total-row{border-top:1px solid var(--border);color:var(--text-primary);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;margin-top:auto;padding:14px 20px 0;font-size:14px;font-weight:700;display:flex}.budget-chart-total-left,.budget-chart-total-right{align-items:center;gap:8px;min-width:0;display:flex}.budget-chart-total-label{color:var(--text-primary);font-weight:700}.budget-chart-total-value{color:var(--text-primary);font-weight:800}.budget-chart-total-value.expense{color:var(--expense)}.budget-chart-total-value.income{color:var(--income)}.budget-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.budget-sync-message{color:var(--text-muted);font-size:13px}.budget-two-col{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.budget-block-empty{text-align:center;color:var(--text-muted);padding:24px 20px;font-size:14px}.budget-block-empty p{margin:0 0 12px}.budget-block-empty .btn{margin-top:4px}.tx-group-body.budget-category-body{padding-left:62px}.budget-category-body .tx-item-compact-income .tx-item-compact-amount{color:var(--income)}.budget-category-body .tx-item-compact-expense .tx-item-compact-amount{color:var(--expense)}.budget-subcategory-row{cursor:pointer}.budget-subcategory-row:hover{background:var(--bg-card-hover)}.budget-grid{gap:12px;display:grid}.budget-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.budget-item-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.budget-item-names{min-width:0}.budget-item-name{color:var(--text-primary);font-size:14px;font-weight:500}.budget-item-cat{color:var(--text-muted);margin-top:2px;font-size:12px}.budget-amounts{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.budget-spent{color:var(--text-primary);font-size:15px;font-weight:600}.budget-planned{color:var(--text-muted);font-size:12px}.budget-progress{background:#ffffff0f;border-radius:99px;height:6px;margin-top:4px;overflow:hidden}.budget-progress-bar{border-radius:99px;height:100%;transition:width .4s}.budget-remaining{justify-content:flex-end;margin-top:6px;font-size:12px;display:flex}.budget-remaining.ok{color:var(--income)}.budget-remaining.warn{color:var(--warning)}.budget-remaining.over{color:var(--expense)}.cat-sections{flex-direction:column;gap:24px;display:flex}.cat-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.cat-section-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.cat-section-header h4{margin:0;font-size:16px;font-weight:600}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.cat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;min-height:0;display:flex;overflow:hidden}.cat-card-header{border-bottom:1px solid var(--border);background:#ffffff05;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.cat-card-title-row{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.cat-card-title-row h4{flex:1;min-width:0;margin:0;font-size:14px;font-weight:600}.cat-card-title-input{flex:1;min-width:0;padding:4px 8px;font-size:14px}.cat-card-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.btn-icon-danger{color:var(--text-muted)}.btn-icon-danger:hover{color:var(--expense)}.btn-icon-save{color:var(--text-muted);flex-shrink:0}.btn-icon-save:hover{color:var(--income)}.subcat-list{flex:1;min-height:0;padding:8px 0}.cat-card-footer{border-top:1px solid var(--border);flex-shrink:0;padding:8px 16px 12px}.cat-card-add-sub{justify-content:center;width:100%;font-size:12px}.subcat-item{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;font-size:13px;transition:background .1s;display:flex}.subcat-item:hover{background:var(--bg-card-hover)}.subcat-item-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.subcat-edit-input{flex:1;min-width:0;padding:2px 6px;font-size:13px}.subcat-item .btn-icon{padding:4px}.subcat-item .btn-icon-danger:hover{color:var(--expense)}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:max(24px, env(safe-area-inset-top,0px) + 12px) 20px max(96px, env(safe-area-inset-bottom,0px) + 48px);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:#000000b3;justify-content:center;align-items:flex-start;display:flex;position:fixed;inset:0;overflow:hidden auto}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-lg);flex-shrink:0;padding:28px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h3{font-size:17px;font-weight:600}.modal-form{flex-direction:column;gap:14px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.form-readonly-value{color:var(--text-primary);margin:0;font-size:14px;font-weight:500}.modal-footer{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.type-selector{gap:8px;display:flex}.type-btn{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);color:var(--text-secondary);background:0 0;flex:1;padding:10px;transition:all .15s}.type-btn.income-active{background:var(--income-bg);color:var(--income);border-color:#10b9814d}.type-btn.expense-active{background:var(--expense-bg);color:var(--expense);border-color:#f43f5e4d}.recurring-switch-label{cursor:pointer;color:var(--text-primary);justify-content:space-between;align-items:center;gap:12px;width:100%;margin:0;font-size:13px;font-weight:500;display:flex}.recurring-switch-text{-webkit-user-select:none;user-select:none}.recurring-switch{flex-shrink:0;width:46px;height:28px;display:inline-block;position:relative}.recurring-switch input{opacity:0;cursor:pointer;z-index:1;width:100%;height:100%;margin:0;position:absolute}.recurring-switch-track{cursor:pointer;background:var(--border);border-radius:999px;transition:background .2s;position:absolute;inset:0}.recurring-switch input:checked+.recurring-switch-track{background:var(--income)}.recurring-switch input:focus-visible+.recurring-switch-track{outline:2px solid var(--income);outline-offset:2px}.recurring-switch-track:after{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000002e}.recurring-switch input:checked+.recurring-switch-track:after{transform:translate(18px)}.loading{color:var(--text-muted);justify-content:center;align-items:center;gap:10px;padding:60px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.recharts-tooltip-wrapper .custom-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:10px 14px;font-size:13px}.dashboard-pie-card .recharts-wrapper :focus,.dashboard-pie-card .recharts-wrapper :focus-visible,.budget-chart-card .recharts-wrapper :focus,.budget-chart-card .recharts-wrapper :focus-visible,.dashboard-pie-card .recharts-sector,.dashboard-pie-card .recharts-surface,.budget-chart-card .recharts-sector,.budget-chart-card .recharts-surface{outline:none!important}@media (width<=1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-row,.dashboard-grid{grid-template-columns:1fr}.dashboard-stats-blocks{grid-template-columns:repeat(2,1fr)}.dashboard-left-col,.dashboard-right-col{flex-direction:column;gap:20px;min-width:0;display:flex}.dashboard-hero-left{grid-template-columns:1fr 1fr;gap:20px;width:100%;display:grid}.dashboard-grid .dashboard-pie-card,.dashboard-balance-value-card,.dashboard-balance-card-right,.dashboard-two-col-left,.dashboard-two-col-right{grid-area:auto}.dashboard-grid .dashboard-pie-card{aspect-ratio:1;height:auto;min-height:0}}@media (width<=768px){.mobile-menu-toggle{display:inline-flex}.sidebar{z-index:60;height:100vh;transition:transform .2s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar.mobile-menu-open{transform:translate(0)}.sidebar-brand{justify-content:flex-start;padding:16px 20px}.sidebar-nav-item{padding:12px}.stats-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.main-body{padding:20px}.budget-income-card,.budget-expense-card{display:none}.dashboard-grid,.dashboard-grid.safari-stable,.dashboard-grid.safari-stable .dashboard-hero-left{grid-template-columns:1fr}.dashboard-grid .dashboard-pie-card,.dashboard-balance-value-card,.dashboard-balance-card-right,.dashboard-two-col-left,.dashboard-two-col-right{grid-area:auto!important}.dashboard-left-col,.dashboard-right-col{flex-direction:column;gap:12px;width:100%;min-width:0;display:flex!important}.dashboard-hero-left{flex-direction:column;grid-template-columns:1fr;gap:12px;width:100%;display:flex!important}.dashboard-balance-card-right{height:auto;min-height:200px}.dashboard-stats-blocks{grid-template-columns:1fr}.main-header-left h2{font-size:16px}.main-header-left p{font-size:12px}.month-nav{flex-wrap:wrap;gap:4px}.main-header-left p,.month-nav-select-month,.month-nav-select-year{display:none}.month-nav-select-monthyear{text-align:center;appearance:none;pointer-events:none;background:0 0;border:none;border-radius:0;outline:none;min-width:90px;height:28px;padding:0 2px;font-size:13px;line-height:28px;display:inline-block}.dashboard-grid{gap:12px}.dashboard-square-card{aspect-ratio:auto;min-height:260px;padding:16px}.dashboard-grid .dashboard-pie-card{margin-top:0}.dashboard-grid .btn-icon>span{display:none}.dashboard-pie-2col{flex-direction:column;gap:50px}.dashboard-pie-2col .dashboard-pie-fill{flex:none;width:100%;height:240px}.dashboard-pie-donut{width:min(100%,272px)}.dashboard-grid .dashboard-pie-card .chart-legend{max-height:208px}.dashboard-grid .dashboard-pie-card .dashboard-pie-2col{padding-top:18px}.dashboard-grid .dashboard-pie-card .dashboard-pie-fill,.dashboard-grid .dashboard-pie-card .dashboard-pie-donut-wrap{padding-top:10px}.dashboard-balance-card-right,.dashboard-recurring-list .btn-ghost-small{display:none}.tx-date{width:58px;min-width:58px}.tx-amount{min-width:72px}.page-header{flex-direction:column;align-items:flex-start;gap:14px}.page-header>.btn-primary{justify-content:center;align-self:stretch}.page-header>div:first-child{justify-content:center;width:100%;gap:28px!important}.tx-list .tx-item{grid-template-rows:auto auto;grid-template-columns:32px 1fr auto auto;align-items:start;gap:2px 10px;width:100%;min-width:0;max-width:100%;display:grid;overflow:hidden}.tx-list .tx-item .tx-icon{grid-area:1/1/span 2}.tx-list .tx-item .tx-info{grid-area:1/2/span 2;min-width:0}.tx-list .tx-item .tx-name{white-space:nowrap;text-overflow:ellipsis;width:100%;display:block;overflow:hidden}.tx-list .tx-item .tx-amount{text-align:right;grid-area:1/3;min-width:0}.tx-list .tx-item .tx-date{text-align:right;grid-area:2/3;width:auto;min-width:0}.tx-list .tx-item button:first-of-type{grid-area:1/4}.tx-list .tx-item button:nth-of-type(2){grid-area:2/4}.tx-list .tx-item .btn-icon{padding:4px}.tx-list .tx-item-compact{grid-template-rows:auto auto;grid-template-columns:auto 1fr auto;align-items:start;gap:2px 8px;width:100%;min-width:0;max-width:100%;padding:8px 16px;display:grid;overflow:hidden}.tx-list .tx-item-compact .tx-item-compact-amount{grid-area:1/1;font-size:13px}.tx-list .tx-item-compact .tx-item-compact-desc{white-space:nowrap;text-overflow:ellipsis;grid-area:1/2;min-width:0;font-size:13px;overflow:hidden}.tx-list .tx-item-compact .tx-date{text-align:right;grid-area:2/2;justify-self:end;width:auto;min-width:0;font-size:11px}.tx-list .tx-item-compact button:first-of-type{grid-area:1/3}.tx-list .tx-item-compact button:nth-of-type(2){grid-area:2/3}.recent-section .tx-item{grid-template-rows:auto auto;grid-template-columns:32px 1fr auto auto;align-items:start;gap:2px 10px;width:100%;min-width:0;max-width:100%;display:grid;overflow:hidden}.recent-section .tx-item .tx-icon{grid-area:1/1/span 2}.recent-section .tx-item .tx-info{grid-area:1/2/span 2;min-width:0}.recent-section .tx-item .tx-amount{text-align:right;grid-area:1/3;min-width:0}.recent-section .tx-item .tx-date{text-align:right;grid-area:2/3;width:auto;min-width:0}.recent-section .tx-item button:first-of-type{grid-area:1/4}.recent-section .tx-item button:nth-of-type(2){grid-area:2/4}.recent-section .tx-item .btn-icon{padding:4px}.recent-section .tx-name{white-space:nowrap;text-overflow:ellipsis;width:100%;display:block;overflow:hidden}.dashboard-recurring-list .recurring-occ-row{grid-template-rows:auto auto;grid-template-columns:32px 1fr auto;align-items:start;gap:2px 10px;width:100%;min-width:0;max-width:100%;padding:12px 0;display:grid;overflow:hidden}.dashboard-recurring-list .recurring-occ-main{grid-area:1/1/span 2/span 2;grid-template-rows:auto auto;grid-template-columns:20px 1fr;align-items:start;gap:2px 10px;min-width:0;display:grid}.dashboard-recurring-list .recurring-occ-status{grid-area:1/1/span 2;width:20px;margin-top:1px}.dashboard-recurring-list .recurring-occ-info{grid-area:1/2/span 2;grid-template-rows:auto auto;row-gap:2px;min-width:0;display:grid}.dashboard-recurring-list .recurring-occ-title{grid-row:1;align-items:center;gap:6px;width:100%;min-width:0;display:flex}.dashboard-recurring-list .recurring-occ-title>span:nth-child(2){white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.dashboard-recurring-list .recurring-occ-meta{grid-row:2;margin-top:0;font-size:11px}.dashboard-recurring-list .recurring-occ-right{flex-direction:row;grid-area:1/3/span 2;justify-content:flex-end;align-items:flex-start;gap:8px;min-width:0;display:flex}.dashboard-recurring-list .recurring-occ-type{display:none}.dashboard-recurring-list .recurring-occ-amount{font-size:14px}.dashboard-recurring-list .btn-icon{padding:4px}.recurring-month-body .recurring-occ-row{grid-template-rows:auto auto;grid-template-columns:20px 1fr auto;align-items:start;gap:2px 10px;width:100%;min-width:0;max-width:100%;padding:10px 0;display:grid;overflow:hidden}.recurring-month-body .recurring-occ-main{grid-area:1/1/span 2/span 2;grid-template-rows:auto auto;grid-template-columns:20px 1fr;gap:2px 10px;min-width:0;display:grid}.recurring-month-body .recurring-occ-status{grid-area:1/1/span 2;width:20px;margin-top:1px}.recurring-month-body .recurring-occ-info{grid-area:1/2/span 2;grid-template-rows:auto auto;row-gap:2px;min-width:0;display:grid}.recurring-month-body .recurring-occ-title{width:100%;min-width:0}.recurring-month-body .recurring-occ-title>span:nth-child(2){white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.recurring-month-body .recurring-occ-meta{flex-direction:column;gap:1px;margin-top:0;font-size:11px;display:flex}.recurring-month-body .recurring-occ-meta-category,.recurring-month-body .recurring-occ-meta-date{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.recurring-month-body .recurring-occ-right{grid-area:1/3/span 2;grid-template-rows:auto auto;grid-template-columns:auto auto;place-items:start end;gap:4px 8px;min-width:0;display:grid}.recurring-month-body .recurring-occ-right>:first-child{grid-area:1/1;justify-self:end}.recurring-month-body .recurring-occ-right>:nth-child(2){grid-area:1/2;justify-self:end}.recurring-month-body .recurring-occ-right>:nth-child(3){grid-area:2/1/auto/span 2;justify-self:end}.recurring-month-body .recurring-occ-amount{font-size:14px}.recurring-month-body .btn-icon{padding:4px}.recurring-row{grid-template-rows:minmax(0,1fr) minmax(0,1fr);grid-template-columns:9px 1fr auto auto;align-items:start;gap:2px 8px;min-height:70px;display:grid}.recurring-row-main{grid-area:1/1/span 2/span 2;grid-template-rows:minmax(0,1fr) minmax(0,1fr);grid-template-columns:9px 1fr;gap:2px 10px;min-width:0;display:grid}.recurring-dot{grid-area:1/1/span 2;margin-top:6px}.recurring-row-main>div:last-child{grid-area:1/2/span 2;min-width:0}.recurring-row-title{width:100%;min-width:0}.recurring-row-title>span:nth-child(2){white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.recurring-row-title .recurring-row-interval{display:inline-flex}.recurring-row-meta .recurring-row-interval-meta{display:none}.recurring-row-meta{grid-template-columns:1fr;grid-auto-rows:auto;align-items:start;row-gap:2px;margin-top:0;display:grid}.recurring-row-meta-category,.recurring-row-meta-date{display:block}.recurring-row-right{grid-area:1/3/span 2/span 2;grid-template-rows:minmax(0,1fr) minmax(0,1fr);grid-template-columns:auto;place-items:stretch end;row-gap:0;height:100%;display:grid}.recurring-row-right>.recurring-row-top-actions{white-space:nowrap;grid-area:1/1;place-self:start end;align-items:center;gap:8px;display:inline-flex}.recurring-row-right>.recurring-row-bottom-actions{grid-area:1/1/span 2;grid-template-columns:auto auto;align-self:end;justify-items:end;column-gap:6px;display:inline-grid}.recurring-row-right>.recurring-row-bottom-actions>button:first-child{grid-area:1/1}.recurring-row-right>.recurring-row-bottom-actions>button:nth-child(2){grid-area:1/2}}.goals-page-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,380px),1fr));gap:20px;display:grid}.goal-card-wrap{min-height:0}.goals-page-grid .goal-card-wrap.dashboard-square-card{aspect-ratio:auto;height:auto;min-height:0}.goal-donut-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex}.goal-donut-pct{color:var(--text-primary);font-size:13.6px;font-weight:700;line-height:1.15}.goal-donut-sub{color:var(--text-muted);font-size:10.2px;font-weight:500}.goal-meta{color:var(--text-primary);flex-direction:column;gap:4px;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.goal-meta-sub{color:var(--text-muted);font-size:12px;font-weight:500}.goal-card-header{flex-wrap:wrap;gap:8px 12px}.goal-card-header-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.goal-tx-list{flex-direction:column;gap:6px;max-height:180px;padding-right:4px;display:flex;overflow-y:auto}.goal-tx-empty{color:var(--text-muted);margin:0;font-size:13px}.goal-tx-row{grid-template-columns:auto auto 1fr;align-items:baseline;gap:8px;font-size:12px;display:grid}.goal-tx-date{color:var(--text-muted);flex-shrink:0}.goal-tx-amt{color:var(--expense-muted);font-weight:600}.goal-tx-desc{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-secondary);overflow:hidden}.goal-legend{min-width:0}.quick-card{flex-direction:column;gap:14px;padding:24px;display:flex}.quick-head{align-items:center;gap:12px;display:flex}.quick-head-icon{color:#a78bfa;background:#8b5cf62e;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.quick-status{color:var(--income);background:var(--income-bg);border:1px solid #10b98133;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;display:inline-flex}.quick-guide{border:1px solid var(--border);background:var(--bg-input);border-radius:12px;flex-direction:column;gap:8px;padding:12px;display:flex}.quick-guide-title{color:var(--text-primary);font-size:13px;font-weight:600}.quick-guide-steps{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:12px;display:flex}.quick-command{color:#d8b4fe;background:#8b5cf61f;border:1px solid #8b5cf642;border-radius:8px;padding:8px 10px;font-size:12px}.quick-mappings-card,.quick-unmatched-card{border:1px solid var(--border);background:#ffffff03;border-radius:12px;padding:14px}.quick-row-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.quick-row-head h4{color:var(--text-primary);font-size:14px;font-weight:600}.quick-form{grid-template-columns:1.1fr .9fr .9fr auto;gap:10px;margin-bottom:10px;display:grid}.quick-form-actions{gap:8px;display:inline-flex}.quick-mapping-row,.quick-unmatched-row{border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;margin-top:8px;padding:10px 12px;display:flex}.quick-mapping-title{color:var(--text-primary);font-size:14px;font-weight:600}.quick-mapping-sub{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.quick-mapping-right{align-items:center;gap:6px;display:inline-flex}.quick-chip{border-radius:999px;align-items:center;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.quick-chip-category{color:#34d399;background:#10b98124}.quick-chip-subcategory{color:#a5b4fc;background:#6366f129}.quick-chip-count{color:var(--text-secondary);background:#ffffff0f}@media (width<=980px){.quick-form{grid-template-columns:1fr}}
