*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,:root[data-theme=dark]{--bg-body:#0e1726;--bg-secondary:#131f37;--bg-card:#18243f;--bg-card-hover:#1e2c49;--bg-input:#1a2740;--border:#2a3d5c;--border-subtle:#1e2e49;--text-primary:#f2f5f9;--text-secondary:#9fb3cc;--text-muted:#647e9f;--navy:#10243e;--accent:#2bd9a3;--accent-hover:#3ee7b0;--accent-text:#08291e;--accent-soft:#2bd9a326;--accent-shadow:#2bd9a34d;--green:#2bd9a3;--green-soft:#2bd9a326;--red:#ff7c70;--red-soft:#ff7c7026;--yellow:#ffcf5c;--yellow-soft:#ffcf5c29;--sidebar-width:240px;--radius:16px;--radius-sm:10px;--shadow:0 40px 90px -28px #000000b3;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme=light]{--bg-body:#f6f7f9;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#fbfcfe;--bg-input:#eef1f6;--border:#dce2ea;--border-subtle:#e8ecf1;--text-primary:#10243e;--text-secondary:#51698a;--text-muted:#8597ae;--navy:#10243e;--accent:#159c73;--accent-hover:#2bd9a3;--accent-text:#fff;--accent-soft:#159c731f;--accent-shadow:#159c7333;--green:#159c73;--green-soft:#159c731f;--red:#e8503f;--red-soft:#e8503f1a;--yellow:#e0a019;--yellow-soft:#e0a01921;--sidebar-width:240px;--radius:16px;--radius-sm:10px;--shadow:0 40px 80px -30px #10243e4d;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root{--space-xxs:4px;--space-xs:6px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-xxl:24px;--space-3xl:28px;--space-4xl:32px;--fs-xxs:11px;--fs-xs:12px;--fs-sm:13px;--fs-md:14px;--fs-lg:15px;--fs-xl:17px;--fs-xxl:18px;--fs-3xl:22px;--fs-4xl:28px;--z-base:1;--z-above:2;--z-sticky:50;--z-modal-overlay:100;--z-dropdown:200;--z-overlay:999;--z-toast:1000;font-family:Inter,system-ui,sans-serif;font-size:var(--fs-md);color:var(--text-primary);line-height:1.5}*,:before,:after{transition:background-color .3s cubic-bezier(.4,0,.2,1),border-color .3s cubic-bezier(.4,0,.2,1),color .3s cubic-bezier(.4,0,.2,1)}a,button,input,select,textarea,.nav-link,.btn,.btn-icon,.btn-logout,.btn-sidebar-action,.month-btn,.toggle-switch .slider,.toggle-switch .slider:before,.bar-rect,.cat-picker-trigger,.cat-picker-row,.cat-picker-subrow,.source-item-btn{transition:background-color .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}body{background:var(--bg-body);min-height:100vh}#root{min-height:100vh;display:flex}.layout{width:100%;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);height:100vh;padding:var(--space-xxl) 0;flex-direction:column;flex-shrink:0;display:flex;position:sticky;top:0}.sidebar-logo{padding:0 var(--space-xl) var(--space-3xl);font-size:var(--fs-xxl);color:var(--text-primary);letter-spacing:-.5px;align-items:center;gap:var(--space-sm);font-weight:700;display:flex}.sidebar-logo-text{display:inline}.sidebar-logo-text span{color:var(--green)}.sidebar-logo-img{width:var(--space-3xl);height:var(--space-3xl);flex-shrink:0}.sidebar-nav{padding:0 var(--space-sm);scrollbar-width:thin;flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}.nav-link{align-items:center;gap:var(--radius-sm);padding:var(--radius-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--bg-card);color:var(--text-primary)}.nav-link.active{background:var(--accent-soft);color:var(--accent)}.nav-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-bottom{padding:var(--space-sm) var(--space-sm) 0;border-top:1px solid var(--border-subtle);padding-top:var(--space-lg);margin-top:auto}.sidebar-user{align-items:center;gap:var(--radius-sm);padding:var(--radius-sm) var(--space-md);margin-bottom:var(--space-xxs);display:flex}.sidebar-user-avatar{width:var(--space-4xl);height:var(--space-4xl);background:var(--accent);font-size:var(--fs-sm);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex;overflow:hidden}.sidebar-user-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:var(--fs-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-email{font-size:var(--fs-xxs);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.btn-logout,.btn-sidebar-action{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--fs-md);cursor:pointer;background:0 0;border:none;font-weight:500;transition:background .15s,color .15s;display:flex}.btn-logout:hover{background:var(--red-soft);color:var(--red)}.btn-sidebar-action:hover{background:var(--bg-card);color:var(--text-primary)}.main-content{min-height:100vh;padding:var(--space-3xl) var(--space-4xl);flex:1;overflow-y:auto}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:500}.form-control{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-md);padding:var(--space-xs) var(--space-md);width:100%;font-family:inherit;transition:border-color .15s}.form-control:focus{border-color:var(--accent);outline:none}.form-control::placeholder{color:var(--text-muted)}select.form-control{appearance:none;cursor:pointer}.accounting-method-toggle{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:3px;display:inline-flex;box-shadow:inset 0 1px 2px #0003}.method-btn{border-radius:calc(var(--radius-sm) - 3px);cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border:none;justify-content:center;align-items:center;padding:6px 14px;font-size:.78rem;font-weight:600;transition:background-color .15s,color .15s,box-shadow .15s;display:inline-flex}.method-btn:hover:not(.active){color:var(--text-primary);background:#ffffff0d}.method-btn.active{background:var(--accent);color:var(--accent-text);box-shadow:0 2px 6px var(--accent-shadow)}.method-info-btn{border:1px solid var(--border);width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:2px;font-size:.7rem;transition:background-color .15s,color .15s;display:flex}.method-info-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;padding:var(--radius-sm) var(--space-md);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);font-weight:600}tbody td{padding:var(--space-md) var(--space-md);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);font-size:var(--fs-md)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-card-hover)}tbody tr.transaction-ignored td{opacity:.55}@media (width<=768px){.hide-short{display:none!important}}.modal-overlay{z-index:var(--z-modal-overlay);padding:var(--space-lg);background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3xl);width:100%;max-width:480px;max-height:calc(100vh - var(--space-4xl));box-shadow:var(--shadow);overflow-y:auto}.modal-header{margin-bottom:var(--space-xxl);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--fs-xl);font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;font-size:var(--space-xl);padding:2px var(--space-xs);background:0 0;border:none;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-footer{gap:var(--space-sm);margin-top:var(--space-xxl);justify-content:flex-end;display:flex}.form-grid{gap:var(--space-lg);display:grid}.form-grid-2{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.month-selector{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);display:flex}.month-selector-label{font-size:var(--fs-lg);text-align:center;text-transform:capitalize;min-width:160px;font-weight:600}.month-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);width:var(--space-4xl);height:var(--space-4xl);cursor:pointer;justify-content:center;align-items:center;transition:background .15s;display:flex}.month-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.cat-picker{width:100%;position:relative}.cat-picker-trigger{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-md);cursor:pointer;text-align:left;width:100%;font-family:inherit;transition:border-color .15s,box-shadow .15s;display:flex}.cat-picker-trigger:hover{border-color:var(--text-muted)}.cat-picker-trigger:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.cat-picker-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.cat-picker-chevron{color:var(--text-muted);font-size:var(--fs-sm);flex-shrink:0;justify-content:center;align-items:center;line-height:1;transition:transform .2s,color .15s;display:inline-flex}.cat-picker-chevron.open{color:var(--accent);transform:rotate(180deg)}.cat-picker-panel{top:calc(100% + var(--space-xxs));background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:var(--z-dropdown);animation:.12s cat-picker-open;position:absolute;left:0;right:0;overflow:hidden}@keyframes cat-picker-open{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cat-picker-search-wrap{padding:var(--radius-sm) var(--radius-sm) var(--space-xs);border-bottom:1px solid var(--border-subtle)}.cat-picker-search{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:var(--fs-sm);padding:var(--space-xs) var(--radius-sm);font-family:inherit;transition:border-color .15s}.cat-picker-search:focus{border-color:var(--accent);outline:none}.cat-picker-search::placeholder{color:var(--text-muted)}.cat-picker-list{max-height:260px;padding:var(--space-xxs) 0;scrollbar-width:thin;scrollbar-color:var(--border) transparent;overflow-y:auto}.cat-picker-list::-webkit-scrollbar{width:4px}.cat-picker-list::-webkit-scrollbar-track{background:0 0}.cat-picker-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.cat-picker-empty{padding:var(--space-xl) var(--space-md);font-size:var(--fs-sm);color:var(--text-muted);text-align:center}.cat-picker-row{width:100%;padding:var(--space-xs) var(--space-md);cursor:pointer;text-align:left;color:var(--text-primary);font-size:var(--fs-sm);justify-content:space-between;align-items:center;gap:var(--space-sm);background:0 0;border:none;font-family:inherit;font-weight:500;transition:background .1s;display:flex}.cat-picker-row:hover{background:var(--bg-card-hover)}.cat-picker-row.selected{background:var(--accent-soft);color:var(--accent)}.cat-picker-row-title{align-items:center;gap:var(--space-xs);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;display:flex;overflow:hidden}.cat-picker-chevron-sm{color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;font-size:10px;line-height:1;transition:transform .2s,color .15s;display:inline-flex}.cat-picker-chevron-sm.open{color:var(--accent);transform:rotate(90deg)}.cat-picker-subrow{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md) var(--space-sm) var(--space-4xl);background:var(--bg-body);cursor:pointer;text-align:left;color:var(--text-secondary);font-size:var(--fs-sm);border:none;border-top:1px solid var(--border-subtle);font-family:inherit;font-weight:400;transition:background .1s,color .1s;display:flex}.cat-picker-subrow:hover{background:var(--bg-card-hover);color:var(--text-primary)}.cat-picker-subrow.selected{background:var(--accent-soft);color:var(--accent);font-weight:500}.cat-picker-check{color:var(--accent);flex-shrink:0;font-size:12px;font-weight:700;line-height:1}.source-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:var(--radius-sm) var(--space-md);font-size:var(--fs-md);width:100%;height:auto;transition:border-color .15s}.source-btn:hover{border-color:var(--accent)}.source-item-btn{align-items:center;gap:var(--space-md);width:100%;padding:var(--radius-sm) var(--space-xxs);cursor:pointer;text-align:left;border-radius:var(--radius-sm);color:var(--text-primary);background:0 0;border:none;transition:background .12s;display:flex}.source-item-btn:hover{background:var(--bg-card-hover)}.source-item-addition{padding-left:var(--space-xl)}.source-item-icon{font-size:var(--space-xl);flex-shrink:0}.source-item-btn>span:last-child{flex-direction:column;gap:2px;display:flex}.source-item-title{font-size:var(--fs-md);font-weight:500}.source-item-sub{font-size:var(--fs-xs);color:var(--text-secondary)}.cat-filter-overlay{z-index:calc(var(--z-sticky) - 1);position:fixed;inset:0}.cat-filter-dropdown{top:calc(100% + var(--space-xs));z-index:var(--z-sticky);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);min-width:220px;max-width:280px;position:absolute;right:0;overflow:hidden}.cat-filter-header{padding:var(--radius-sm) var(--space-md);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.cat-filter-title{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.cat-filter-clear{font-size:var(--fs-xs);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-weight:500}.cat-filter-clear:hover{text-decoration:underline}.cat-filter-list{padding:var(--space-xs) 0;max-height:280px;overflow-y:auto}.cat-filter-item{padding:var(--space-sm) var(--space-md);cursor:pointer;font-size:var(--fs-sm);color:var(--text-primary);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;transition:background .12s;display:flex}.cat-filter-item:hover{background:var(--bg-card-hover)}.cat-filter-item input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px}.cat-filter-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.cat-filter-label{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.cat-filter-label--muted{color:var(--text-muted)}.cat-filter-divider{background:var(--border);height:1px;margin:var(--space-xxs) 0}.cat-filter-group-label{padding:var(--space-sm) var(--space-md) var(--space-xxs);font-size:var(--fs-xxs);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);font-weight:600;display:block}.cat-filter-empty{padding:var(--space-md) var(--space-md);font-size:var(--fs-sm);color:var(--text-muted);display:block}.cat-filter-badge{background:var(--accent);color:#fff;font-size:var(--fs-xxs);border-radius:20px;margin-left:2px;padding:1px 7px;font-weight:600}.tx-filters-row .month-selector{margin-bottom:0}@media (width<=576px){.cat-filter-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-overlay);background:#0006;transition:opacity .2s}.cat-filter-dropdown{position:fixed;border:1px solid var(--border)!important;width:100%!important;min-width:100%!important;max-width:100%!important;z-index:var(--z-toast)!important;border-bottom:none!important;border-radius:20px 20px 0 0!important;animation:.25s cubic-bezier(.16,1,.3,1) slide-up!important;inset:auto 0 0!important;box-shadow:0 -10px 30px #0000004d!important}.cat-filter-list{max-height:50vh!important}}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.page-title{font-size:var(--fs-3xl);margin-bottom:var(--space-xxl);color:var(--text-primary);font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--space-xxl);box-shadow:var(--shadow)}.btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);font-size:var(--fs-md);cursor:pointer;border:none;font-weight:500;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px var(--accent-shadow);transform:scale(1.02)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);transform:scale(1.02)}.btn-danger{background:var(--red-soft);color:var(--red)}.btn-danger:hover:not(:disabled){background:var(--red-soft);filter:brightness(1.2)}.btn-icon{padding:var(--space-xs) var(--space-sm);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;transition:background .15s,color .15s;display:inline-flex}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary)}.badge{padding:var(--space-xxs) var(--space-sm);font-size:var(--fs-xs);border-radius:20px;align-items:center;font-weight:600;display:inline-flex}.badge-green{background:var(--green-soft);color:var(--green)}.badge-red{background:var(--red-soft);color:var(--red)}.badge-blue{background:var(--accent-soft);color:var(--accent)}.badge-yellow{background:var(--yellow-soft);color:var(--yellow)}.stats-row{gap:var(--space-lg);margin-bottom:var(--space-xxl);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--space-lg) var(--space-xl)}.stat-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-xs);font-weight:500}.stat-value{font-size:var(--fs-3xl);font-weight:700}.stat-value.green{color:var(--green)}.stat-value.red{color:var(--red)}.error-msg{color:var(--red);font-size:var(--fs-sm);padding:var(--space-sm) var(--space-md);background:var(--red-soft);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.loading{text-align:center;color:var(--text-secondary);padding:var(--space-4xl)}.empty-state{text-align:center;color:var(--text-secondary);padding:var(--space-4xl) var(--space-xl)}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-switch .slider{cursor:pointer;background:#6b829f;border-radius:999px;transition:background .2s,box-shadow .2s;position:absolute;inset:0}.toggle-switch .slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 2px #0003}.toggle-switch input:checked+.slider{background:var(--green)}.toggle-switch input:checked+.slider:before{transform:translate(20px)}.toggle-switch.small{width:34px;height:18px}.toggle-switch.small .slider:before{width:12px;height:12px;top:3px;left:3px}.toggle-switch.small input:checked+.slider:before{transform:translate(14px)}.toggle-switch input:disabled+.slider{opacity:.6;filter:grayscale(.15);cursor:default}.theme-toggle-btn{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.theme-toggle-btn:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border)}.theme-toggle-btn svg{flex-shrink:0;width:16px;height:16px}.premium-gate{align-items:center;gap:var(--space-lg);border-radius:var(--radius);padding:var(--space-md) var(--space-lg);background:#f59e0b14;border:1px solid #f59e0b4d;display:flex}.premium-gate-icon{width:36px;height:36px;color:var(--yellow);flex-shrink:0;justify-content:center;align-items:center;display:flex}.premium-gate-icon svg{width:24px;height:24px}.premium-gate-content{flex:1;min-width:0}.premium-gate-title{font-size:var(--fs-md);color:var(--yellow);margin-bottom:var(--space-xxs);font-weight:700}.premium-gate-desc{font-size:var(--fs-sm);color:var(--text-secondary)}.card-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-head h2{font-size:15px;font-weight:700}.card-head a{color:var(--accent);font-size:13px;font-weight:500;text-decoration:none}.card-head a:hover{text-decoration:underline}.home-topbar{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.home-greet{color:var(--text-secondary);text-transform:capitalize;margin-bottom:4px;font-size:13px}.home-grid{grid-template-columns:2fr 1fr;align-items:start;gap:18px;display:grid}.home-col{flex-direction:column;gap:18px;min-width:0;display:flex}.home-bento{grid-template-columns:repeat(12,1fr);align-items:start;gap:20px;display:grid}.home-bento>*{min-width:0}.bento-hero,.bento-quick-actions{grid-column:span 12}.bento-flow{grid-column:span 8;align-self:stretch}.bento-flow-wide{grid-column:span 12;align-self:stretch}.bento-action-center{grid-column:span 4;align-self:stretch}.bento-recent,.bento-accounts{grid-column:span 6;align-self:stretch}.bento-health{grid-column:span 8;align-self:stretch}.bento-health-wide{grid-column:span 12;align-self:stretch}.bento-donut,.bento-installments{grid-column:span 4;align-self:stretch}@media (width<=1080px){.bento-flow,.bento-flow-wide,.bento-action-center,.bento-health,.bento-health-wide,.bento-donut,.bento-installments,.bento-recent,.bento-accounts{grid-column:span 12}}@media (width<=768px){.home-bento{flex-direction:column;display:flex}}.glass-panel{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius);background:#ffffff0a;border:1px solid #ffffff14;padding:24px;box-shadow:0 4px 30px #0000001a}:root[data-theme=light] .glass-panel{background:#fff9;border:1px solid #fff6;box-shadow:0 8px 32px #10243e0d}.home-qa-row{gap:12px;margin-bottom:24px;padding-bottom:4px;display:flex;overflow-x:auto}.home-qa-btn{background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-primary);white-space:nowrap;border-radius:12px;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.home-qa-btn:hover{background:var(--bg-card-hover);border-color:var(--accent);color:var(--accent);box-shadow:0 4px 12px var(--accent-soft);transform:translateY(-2px)}.home-qa-btn svg{width:18px;height:18px}.action-center-item{border-bottom:1px solid var(--border-subtle);color:inherit;background:0 0;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;transition:background .2s;display:flex}.action-center-item:hover{background:var(--bg-input)}.action-center-item:last-child{border-bottom:none}.ac-icon{border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.ac-icon.urgent{background:var(--red-soft);color:var(--red)}.ac-icon.warning{background:var(--yellow-soft);color:var(--yellow)}.ac-icon.info{color:#3b82f6;background:#3b82f626}.ac-main{flex:1;min-width:0}.ac-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.ac-subtitle{color:var(--text-secondary);margin-top:2px;font-size:12px}.ac-amount{font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.home-balance-card{background:linear-gradient(135deg, var(--navy) 0%, #1c3a5e 100%);border-radius:var(--radius);color:#fff;z-index:1;padding:24px;position:relative;overflow:hidden}.hbc-inner{z-index:2;pointer-events:none;position:relative}.hbc-spark-bg{height:55%;position:absolute;bottom:0;left:0;right:0}.hbc-spark-bg .sparkline-wrap{width:100%;height:100%;display:block}.sparkline-wrap{display:inline-block;position:relative}.sparkline-tooltip{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;white-space:nowrap;z-index:10;background:#0f172ae0;border:1px solid #ffffff1f;border-radius:8px;padding:6px 10px;position:absolute;transform:translate(-50%,calc(-100% - 10px))}.sparkline-tooltip-label{opacity:.65;text-transform:capitalize;color:#fff;margin-bottom:2px;font-size:11px}.sparkline-tooltip-value{font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.sparkline-tooltip-value.pos{color:#34d399}.sparkline-tooltip-value.neg{color:#f87171}.home-balance-card:after{content:"";background:var(--accent-soft);pointer-events:none;border-radius:50%;width:200px;height:200px;position:absolute;top:-60px;right:-40px}.hbc-label{text-transform:uppercase;letter-spacing:.06em;opacity:.85;z-index:1;margin-bottom:8px;font-size:12px;position:relative}.hbc-value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;z-index:1;margin-bottom:16px;font-size:36px;font-weight:700;position:relative}.hbc-meta{z-index:1;position:relative}.hbc-pill{box-shadow:var(--shadow-sm);border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex}.hbc-pill.green{background:var(--green-soft);color:var(--green)}.hbc-pill.red{background:var(--red-soft);color:var(--red)}.sparkline-dot{pointer-events:none;z-index:1;background:#fff;border-radius:50%;transition:width .1s,height .1s;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #fff3}.home-flow-row{grid-template-columns:1fr 1fr 1fr;gap:18px;display:grid}.home-flow{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:18px 20px}.home-flow-top{align-items:center;gap:10px;margin-bottom:12px;display:flex}.home-flow-ic{border-radius:9px;flex-shrink:0;place-items:center;width:34px;height:34px;display:grid}.home-flow-ic svg{width:16px;height:16px}.home-flow-ic.inc{background:var(--green-soft);color:var(--green)}.home-flow-ic.exp{background:var(--red-soft);color:var(--red)}.home-flow-label{color:var(--text-secondary);font-size:13px;font-weight:500}.home-flow-val{letter-spacing:-.01em;font-variant-numeric:tabular-nums;font-size:22px;font-weight:700}.home-flow-val.inc{color:var(--green)}.home-flow-val.exp{color:var(--red)}.home-flow-ic.txs{background:var(--blue-soft);color:var(--blue)}.home-flow-val.txs{color:var(--text-primary)}.home-flow-bar{background:var(--bg-input);border-radius:4px;height:5px;margin-top:12px;overflow:hidden}.home-flow-bar i{border-radius:4px;height:100%;display:block}.home-tx{border-top:1px solid var(--border-subtle);align-items:center;gap:12px;padding:11px 0;display:flex}.home-tx:first-of-type{border-top:none}.home-tx-ic{border-radius:10px;flex-shrink:0;place-items:center;width:38px;height:38px;display:grid}.home-tx-ic svg{width:16px;height:16px}.home-tx-ic.inc{background:var(--green-soft);color:var(--green)}.home-tx-ic.exp{background:var(--red-soft);color:var(--red)}.home-tx-main{flex:1;min-width:0}.home-tx-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.home-tx-date{color:var(--text-secondary);margin-top:2px;font-size:12px}.home-tx-amt{white-space:nowrap;font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.home-tx-amt.inc{color:var(--green)}.home-tx-amt.exp{color:var(--text-primary)}.home-donut-wrap{align-items:center;gap:20px;display:flex}.home-donut{border-radius:50%;flex-shrink:0;width:110px;height:110px;position:relative}.home-donut:after{content:"";background:var(--bg-card);border-radius:50%;position:absolute;inset:16px}.home-donut-center{z-index:1;text-align:center;place-items:center;display:grid;position:absolute;inset:0}.home-donut-val{font-variant-numeric:tabular-nums;font-size:13px;font-weight:700;line-height:1.2}.home-donut-lbl{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.home-cat-legend{flex-direction:column;flex:1;gap:10px;min-width:0;display:flex}.home-cat-item{align-items:center;gap:8px;font-size:13px;display:flex}.home-cat-dot{border-radius:3px;flex-shrink:0;width:9px;height:9px}.home-cat-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.home-cat-pct{font-variant-numeric:tabular-nums;font-weight:700}.home-acct{border-top:1px solid var(--border-subtle);align-items:center;gap:12px;padding:11px 0;display:flex}.home-acct:first-of-type{border-top:none}.home-acct-bar{border-radius:4px;flex-shrink:0;width:4px;height:32px}.home-acct-main{flex:1;min-width:0}.home-acct-name{font-size:13.5px;font-weight:600}.home-acct-type{color:var(--text-secondary);margin-top:1px;font-size:11.5px}.home-acct-bal{font-variant-numeric:tabular-nums;white-space:nowrap;font-size:14px;font-weight:700}.home-acct-bal.green{color:var(--green)}.home-acct-bal.red{color:var(--red)}.home-bill{border-top:1px solid var(--border-subtle);align-items:center;gap:12px;padding:10px 0;display:flex}.home-bill:first-of-type{border-top:none}.home-bill-date{text-align:center;flex-shrink:0;width:40px}.home-bill-day{font-variant-numeric:tabular-nums;font-size:17px;font-weight:700;line-height:1}.home-bill-mon{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.home-bill-sep{background:var(--border-subtle);flex-shrink:0;width:1px;height:28px}.home-bill-main{flex:1;min-width:0}.home-bill-name{font-size:13.5px;font-weight:600}.home-bill-cycle{color:var(--text-secondary);text-transform:capitalize;margin-top:1px;font-size:11.5px}.accounts-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:28px;display:grid}.account-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);flex-direction:column;gap:8px;padding:16px;display:flex}.account-color-bar{border-radius:2px;width:32px;height:4px;margin-bottom:4px}.account-name{color:var(--text-secondary);font-size:13px;font-weight:500}.account-balance{font-size:18px;font-weight:700}.login-page{background:radial-gradient(ellipse at 50% 0%, var(--accent-soft) 0%, var(--bg-body) 65%);flex:1;justify-content:center;align-items:center;display:flex}.login-box{text-align:center;width:100%;max-width:380px}.login-logo{color:var(--text-primary);letter-spacing:-1px;justify-content:center;align-items:center;gap:10px;margin-bottom:8px;font-size:32px;font-weight:800;display:flex}.login-logo-text{display:inline}.login-logo-text span{color:var(--green)}.login-logo-img{flex-shrink:0;width:44px;height:44px}.login-subtitle{color:var(--text-secondary);margin-bottom:36px;font-size:15px}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:32px}.login-card-title{margin-bottom:6px;font-size:18px;font-weight:700}.login-card-desc{color:var(--text-secondary);margin-bottom:28px;font-size:13px}.google-btn-wrap{justify-content:center;display:flex}.tx-type-tabs{gap:4px;margin-bottom:16px;display:flex}.tx-type-tab{cursor:pointer;background:var(--bg-input);color:var(--text-secondary);border:none;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.tx-type-tab.active{background:var(--accent);color:#fff}.top-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));align-items:start;gap:24px;display:grid}.credit-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:18px;min-height:220px;padding:28px;display:flex}.credit-card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.credit-card-name{letter-spacing:-.2px;font-size:18px;font-weight:800}.credit-card-digits{color:var(--text-muted);letter-spacing:1px;font-family:monospace;font-size:13px}.credit-card-info{grid-template-columns:1fr 1fr;gap:16px;display:grid}.credit-card-field{flex-direction:column;gap:2px;display:flex}.field-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px;font-weight:600}.field-value{color:var(--text-primary);font-size:16px;font-weight:700}.badge-muted{color:var(--text-muted);background:#4e6a8a33}.cc-bills-chart-wrap{-webkit-overflow-scrolling:touch;position:relative;overflow:auto visible}.cc-chart-legend{border-top:1px solid var(--border-subtle);flex-wrap:wrap;gap:14px;margin-top:14px;padding-top:10px;display:flex}.cc-chart-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.cc-chart-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cc-chart-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);z-index:20;pointer-events:none;white-space:nowrap;min-width:160px;padding:10px 14px}.cc-chart-tooltip-month{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.cc-chart-tooltip-row{align-items:center;gap:8px;padding:2px 0;font-size:13px;display:flex}.cc-chart-tooltip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cc-chart-tooltip-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;max-width:120px;overflow:hidden}.cc-chart-tooltip-val{font-variant-numeric:tabular-nums;color:var(--text-primary);white-space:nowrap;margin-left:8px;font-weight:700}.page{padding:24px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:13px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-error{color:var(--red);font-size:13px}.error-msg{color:var(--red);padding:12px;font-size:14px}.card-link{color:var(--accent);font-size:13px;font-weight:600;text-decoration:none}.card-link:hover{text-decoration:underline}.budget-month-nav{align-items:center;gap:12px;margin-bottom:20px;display:flex}.budget-month-label{text-align:center;min-width:100px;font-size:15px;font-weight:700}.budget-summary-bar{flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:24px;padding:18px 24px;display:flex}.budget-summary-item{flex-direction:column;gap:2px;display:flex}.budget-summary-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.budget-summary-val{font-size:20px;font-weight:700}.budget-summary-val.inc{color:var(--green)}.budget-summary-val.exp{color:var(--red)}.budget-summary-sep{background:var(--border);width:1px;height:40px}.budget-summary-progress-wrap{flex:1;min-width:160px}.budget-summary-progress-track{background:var(--border);border-radius:4px;height:8px;margin-bottom:4px;overflow:hidden}.budget-summary-progress-fill{border-radius:4px;height:100%;transition:width .6s}.budget-summary-pct{color:var(--text-secondary);font-size:11px}.budget-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.budget-card-wrap{position:relative}.budget-delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;line-height:1;transition:color .15s,background .15s;position:absolute;top:8px;right:8px}.budget-delete-btn:hover{color:var(--red);background:var(--red-soft)}.budget-ring-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);cursor:pointer;padding:18px;transition:border-color .2s,transform .15s,box-shadow .15s}.budget-ring-card:hover{border-color:var(--budget-color,var(--accent));transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.budget-ring-card.budget-status-over{border-color:var(--red)}.budget-ring-card.budget-status-warning{border-color:var(--yellow)}.budget-ring-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.budget-ring-icon{font-size:18px}.budget-ring-name{flex:1;font-size:13px;font-weight:700}.budget-status-badge{text-transform:uppercase;border-radius:20px;padding:2px 7px;font-size:10px;font-weight:700}.budget-status-badge.warning{background:var(--yellow-soft);color:var(--yellow)}.budget-status-badge.over{background:var(--red-soft);color:var(--red)}.budget-ring-body{justify-content:center;margin-bottom:12px;display:flex;position:relative}.budget-svg{display:block}.budget-ring-progress{transition:stroke-dasharray .6s}.budget-ring-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.budget-ring-pct{font-size:16px;font-weight:800}.budget-ring-remaining{font-size:12px;font-weight:700}.budget-ring-lbl{color:var(--text-muted);font-size:10px}.budget-bar-track{background:var(--border);border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden}.budget-bar-fill{border-radius:3px;height:100%;transition:width .6s}.budget-ring-amounts{justify-content:space-between;font-size:11px;display:flex}.budget-spent{font-weight:700}.budget-total{color:var(--text-secondary)}.budget-empty{text-align:center;flex-direction:column;gap:12px;padding:48px}.budget-empty-icon{font-size:48px}.budget-empty-title{margin:0;font-size:16px;font-weight:700}.budget-empty-desc{color:var(--text-secondary);max-width:320px;margin:0;font-size:13px}.budget-group-picker{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.budget-group-btn{border:2px solid var(--border);cursor:pointer;color:var(--text-primary);background:0 0;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;transition:border-color .15s,background .15s;display:flex}.budget-group-btn:hover{border-color:var(--group-color,var(--accent))}.budget-group-btn.active{border-color:var(--group-color,var(--accent));background:color-mix(in srgb, var(--group-color,var(--accent)) 12%, transparent)}.budget-group-btn-icon{font-size:20px}.budget-group-btn-label{text-align:center;font-size:10px;font-weight:600;line-height:1.2}.budget-cat-list{border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:10px;display:flex;overflow-y:auto}.budget-cat-item{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:13px;transition:background .12s;display:flex}.budget-cat-item:hover{background:var(--bg-secondary)}.budget-cat-item.selected{background:color-mix(in srgb, var(--accent) 10%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent)}.budget-cat-item input[type=checkbox]{accent-color:var(--accent)}.budget-group-legend{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.budget-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.budget-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.budget-home-widget{margin-bottom:16px}.budget-home-scroll{scrollbar-width:none;gap:12px;padding-top:4px;padding-bottom:4px;display:flex;overflow-x:auto}.budget-home-scroll::-webkit-scrollbar{display:none}.budget-home-card{border:1px solid var(--border-subtle);background:var(--bg-secondary);min-width:100px;color:var(--text-primary);border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;padding:12px 8px;text-decoration:none;transition:border-color .15s,transform .12s;display:flex}.budget-home-card:hover{border-color:var(--accent);transform:translateY(-2px)}.budget-home-top{position:relative}.budget-home-center{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.budget-home-icon{font-size:18px}.budget-home-name{text-align:center;margin-top:6px;font-size:10px;font-weight:700;line-height:1.2}.budget-home-remaining{margin-top:4px;font-size:12px;font-weight:800}.budget-home-remaining.ok{color:var(--green)}.budget-home-remaining.warning{color:var(--yellow,#f59e0b)}.budget-home-remaining.over{color:var(--red)}.budget-home-lbl{color:var(--text-muted);font-size:10px}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;margin-bottom:8px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.ai-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 24px;display:flex}.ai-empty-icon{background:var(--accent-soft);width:80px;height:80px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;display:flex}.ai-empty-icon svg{width:42px;height:42px}.ai-empty h2{color:var(--text-primary);font-size:22px;font-weight:700}.ai-empty p{color:var(--text-secondary);max-width:420px;line-height:1.6}.ai-empty-btn{margin-top:8px;padding:12px 32px;font-size:15px}.ai-loading{color:var(--text-secondary);flex-direction:column;align-items:center;gap:16px;padding:80px 24px;display:flex}.ai-loading p{color:var(--text-primary);font-size:15px}.ai-loading span{color:var(--text-muted);font-size:12px}.ai-loading-ring{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.9s linear infinite ai-spin}@keyframes ai-spin{to{transform:rotate(360deg)}}.ai-report{flex-direction:column;gap:16px;display:flex}.ai-summary-card{padding:20px 24px}.ai-summary-text{color:var(--text-primary);margin-bottom:12px;font-size:14px;line-height:1.7}.ai-summary-meta{color:var(--text-muted);align-items:center;gap:16px;font-size:12px;display:flex}.ai-refresh-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:4px 12px;font-size:12px}.ai-refresh-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.ai-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.ai-next-available{color:var(--text-secondary,#888);text-align:right;font-size:11px;line-height:1.3}.ai-kpi-row{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.ai-kpi-card{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:20px 16px;display:flex}.ai-kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:12px;font-weight:600}.health-gauge{flex-direction:column;align-items:center;gap:4px;display:flex}.health-gauge-label{letter-spacing:.01em;font-size:16px;font-weight:700}.ai-savings-val{margin:8px 0 2px;font-size:36px;font-weight:800;line-height:1}.ai-savings-label{margin-bottom:10px;font-size:13px;font-weight:600}.ai-savings-bar{background:var(--bg-input);border-radius:3px;width:100%;height:6px;overflow:hidden}.ai-savings-bar div{border-radius:3px;height:100%;transition:width .8s}.ai-net-val{margin:12px 0 4px;font-size:26px;font-weight:800}.ai-net-val.positive{color:var(--green)}.ai-net-val.negative{color:var(--red)}.ai-kpi-sub{color:var(--text-muted);font-size:12px}.ai-kpi-sub .inc{color:var(--green)}.ai-kpi-sub .exp{color:var(--red)}.ai-kpi-sub .sep{color:var(--text-muted)}.monthly-chart-wrap{max-width:600px;margin:0 auto;padding:8px 0 4px}.chart-legend{color:var(--text-secondary);justify-content:center;gap:20px;margin-top:8px;font-size:12px;display:flex}.chart-legend span{align-items:center;gap:6px;display:flex}.chart-legend i{border-radius:2px;width:10px;height:10px;display:inline-block}.ai-insights-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.ai-insights-col{padding-bottom:8px}.ai-insight{border-radius:var(--radius-sm);align-items:flex-start;gap:12px;margin-bottom:8px;padding:12px 16px;display:flex}.ai-insight.positive{background:var(--green-soft);border-left:3px solid var(--green)}.ai-insight.warning{background:var(--yellow-soft);border-left:3px solid var(--yellow)}.ai-insight-icon{flex-shrink:0;margin-top:1px;font-size:14px}.ai-insight.positive .ai-insight-icon{color:var(--green)}.ai-insight.warning .ai-insight-icon{color:var(--yellow)}.ai-insight-title{color:var(--text-primary);margin-bottom:2px;font-size:13px;font-weight:600}.ai-insight-desc{color:var(--text-secondary);font-size:12px;line-height:1.5}.ai-cat-table{border-collapse:collapse;width:100%;font-size:13px}.ai-cat-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);padding:8px 12px;font-size:11px;font-weight:600}.ai-cat-table td{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:10px 12px}.ai-cat-table tr:last-child td{border-bottom:none}.ai-cat-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:8px;display:inline-block}.ai-cat-amt{color:var(--red);white-space:nowrap;font-weight:600}.ai-cat-bar-wrap{align-items:center;gap:8px;display:flex}.ai-cat-bar-wrap>div{border-radius:3px;flex-shrink:0;height:6px}.ai-cat-bar-fill{border-radius:3px;min-width:2px;height:6px}.ai-trend{border-radius:10px;align-items:center;gap:3px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.ai-trend.up{background:var(--red-soft);color:var(--red)}.ai-trend.down{background:var(--green-soft);color:var(--green)}.ai-trend.stable{background:var(--bg-input);color:var(--text-muted)}.ai-recommendations{flex-direction:column;gap:10px;padding:4px 0 4px 20px;display:flex}.ai-recommendations li{color:var(--text-primary);padding-left:4px;font-size:14px;line-height:1.6}.ai-recommendations li::marker{color:var(--accent);font-weight:700}@media (width<=1080px){.home-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{display:none}.main-content{margin:0;padding:0}.stats-row,.form-grid-2,.cards-grid,.home-flow-row,.ai-kpi-row,.ai-insights-row{grid-template-columns:1fr}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.import-btn--has-result{position:relative}.import-ready-dot{width:var(--space-sm);height:var(--space-sm);background:var(--accent);margin-right:var(--space-xs);vertical-align:middle;border-radius:50%;flex-shrink:0;animation:2s ease-in-out infinite import-dot-pulse;display:inline-block}@keyframes import-dot-pulse{0%,to{opacity:1}50%{opacity:.4}}.rate-badge{font-variant-numeric:tabular-nums;letter-spacing:.01em;border-radius:6px;align-items:center;padding:3px 8px;font-size:11.5px;font-weight:700;display:inline-flex}.rate-badge-low{background:var(--green-soft);color:var(--green)}.rate-badge-mid{background:var(--yellow-soft);color:var(--yellow)}.rate-badge-high{background:var(--red-soft);color:var(--red)}.estimate-chip{background:var(--yellow-soft);color:var(--yellow);text-transform:uppercase;letter-spacing:.06em;vertical-align:middle;border-radius:5px;align-items:center;padding:2px 6px;font-size:10px;font-weight:700;display:inline-flex}.variable-badge{background:var(--yellow-soft);color:var(--yellow);border-radius:6px;align-items:center;gap:3px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.dti-status-chip{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.meta-chip{background:var(--bg-input);color:var(--text-secondary);border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:500;display:inline-flex}.stats-row-4{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;display:grid}.debts-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px;display:grid}.debt-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s,transform .15s;overflow:hidden}.debt-card:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.debt-card-accent{width:100%;height:3px}.debt-card-body{padding:20px}.debt-card-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:16px;display:flex}.debt-card-id{align-items:center;gap:10px;min-width:0;display:flex}.debt-card-icon{border-radius:9px;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.debt-card-icon svg{width:17px;height:17px}.debt-card-name{font-size:15px;font-weight:700;line-height:1.2}.debt-card-creditor{color:var(--text-secondary);margin-top:2px;font-size:12px}.debt-card-badges{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:5px;display:flex}.debt-card-balance{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:12px;font-size:28px;font-weight:800}.debt-progress-track{background:var(--bg-input);border-radius:4px;height:5px;margin-bottom:6px;overflow:hidden}.debt-progress-fill{border-radius:4px;height:100%;transition:width .4s}.debt-progress-label{color:var(--text-secondary);justify-content:space-between;margin-bottom:16px;font-size:11.5px;display:flex}.debt-card-footer{border-top:1px solid var(--border-subtle);align-items:center;gap:0;padding-top:14px;display:flex}.debt-footer-item{flex-direction:column;flex:1;gap:2px;display:flex}.debt-footer-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:10px;font-weight:700}.debt-footer-value{font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:700}.debt-footer-sep{background:var(--border-subtle);flex-shrink:0;width:1px;height:28px;margin:0 12px}.section-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.debt-tabs{background:var(--bg-secondary);border-radius:var(--radius-sm);gap:3px;width:fit-content;padding:3px;display:flex}.debt-tab{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:500}.debt-tab.active{background:var(--bg-card);color:var(--text-primary);font-weight:600;box-shadow:0 1px 4px #0003}.sort-controls{align-items:center;gap:6px;display:flex}.sort-label{color:var(--text-muted);font-size:12px}.sort-btn{border:1px solid var(--border-subtle);cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500}.sort-btn:hover{border-color:var(--border);color:var(--text-primary)}.sort-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.detail-header-card{margin-bottom:20px}.detail-header-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.detail-header-left{flex:1;min-width:0}.detail-header-identity{align-items:center;gap:12px;margin-bottom:12px;display:flex}.detail-meta-chips{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.detail-header-balance{text-align:right;flex-shrink:0}.detail-balance-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.detail-balance-value{letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:36px;font-weight:800}.detail-progress-section{margin-top:20px}.detail-progress-labels{color:var(--text-secondary);justify-content:space-between;margin-top:8px;font-size:12px;display:flex}.detail-actions{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.overview-top-grid{grid-template-columns:1fr auto;align-items:start;gap:16px;margin-bottom:16px;display:grid}.next-pmt-card{min-width:200px}.history-table-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.projection-card{flex:1}.projection-top-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.projection-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:13px;font-weight:700}.projection-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.projection-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.projection-value{font-variant-numeric:tabular-nums;font-size:18px;font-weight:700}.projection-sub{color:var(--text-muted);margin-top:3px;font-size:11.5px}.variable-warning{background:var(--yellow-soft);color:var(--yellow);border-radius:var(--radius-sm);align-items:center;gap:7px;margin-top:14px;padding:10px 14px;font-size:12px;font-weight:500;display:flex}.sim-slider-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.sim-slider{appearance:none;background:var(--bg-input);cursor:pointer;border-radius:4px;outline:none;width:100%;height:6px;display:block}.sim-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);width:20px;height:20px;box-shadow:0 2px 8px var(--accent-shadow);cursor:pointer;border-radius:50%}.sim-slider::-moz-range-thumb{background:var(--accent);width:20px;height:20px;box-shadow:0 2px 8px var(--accent-shadow);cursor:pointer;border:none;border-radius:50%}.sim-slider-labels{color:var(--text-muted);justify-content:space-between;margin-top:5px;font-size:10px;display:flex}.sim-savings-row{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.sim-savings-card{background:var(--bg-input);text-align:center;border-radius:12px;padding:18px}.sim-savings-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;font-size:10.5px;font-weight:700}.sim-savings-value{font-variant-numeric:tabular-nums;font-size:30px;font-weight:800}.sim-savings-sub{color:var(--text-secondary);margin-top:4px;font-size:11px}.sim-comparison{grid-template-columns:1fr 1fr;gap:12px;display:grid}.sim-scenario{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:18px}.sim-scenario-highlight{border-color:var(--accent);background:var(--accent-soft)}.sim-scenario-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;font-size:10.5px;font-weight:700}.sim-scenario-pmt{font-variant-numeric:tabular-nums;margin-bottom:14px;font-size:22px;font-weight:800}.sim-pmt-unit{color:var(--text-muted);font-size:13px;font-weight:500}.sim-scenario-row{border-top:1px solid var(--border-subtle);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:5px 0;font-size:12.5px;display:flex}.sim-scenario-row:first-of-type{border-top:none}.sim-scenario-row span:last-child{color:var(--text-primary);font-weight:600}.amort-controls{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.amort-btn{border:1px solid var(--border);cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12.5px;font-weight:500}.amort-btn:hover{border-color:var(--border);color:var(--text-primary)}.amort-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.chart-legend{gap:14px;margin-bottom:14px;display:flex}.chart-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.chart-legend-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.strategy-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.strategy-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.strategy-best{border-color:var(--accent)}.strategy-header{margin-bottom:16px}.strategy-best-badge{text-transform:uppercase;letter-spacing:.07em;color:var(--accent);background:var(--accent-soft);border-radius:20px;margin-bottom:6px;padding:2px 8px;font-size:9.5px;font-weight:700;display:inline-block}.strategy-name{letter-spacing:-.01em;margin-bottom:4px;font-size:16px;font-weight:700}.strategy-desc{color:var(--text-secondary);font-size:12px}.strategy-order-list{flex-direction:column;gap:5px;margin-bottom:16px;display:flex}.strategy-order-item{background:var(--bg-secondary);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.strategy-num{background:var(--bg-input);width:19px;height:19px;color:var(--text-muted);border-radius:50%;flex-shrink:0;place-items:center;font-size:10px;font-weight:700;display:grid}.strategy-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.strategy-debt-name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12.5px;font-weight:500;overflow:hidden}.strategy-debt-meta{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.strategy-totals{border-top:1px solid var(--border-subtle);padding-top:12px}.strategy-total-row{color:var(--text-secondary);justify-content:space-between;padding:4px 0;font-size:12.5px;display:flex}.strategy-total-row span:last-child{color:var(--text-primary);font-weight:700}.strategy-savings{border-top:1px solid var(--border-subtle);margin-top:8px;padding-top:8px;font-size:11.5px;font-weight:600}.debt-type-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.debt-type-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;text-align:center;padding:9px 10px;font-family:inherit;font-size:12.5px;font-weight:500;line-height:1.3}.debt-type-btn:hover{border-color:var(--border);color:var(--text-primary)}.debt-type-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.payment-debt-chip{background:var(--bg-input);border-radius:var(--radius-sm);align-items:center;gap:12px;margin-bottom:20px;padding:12px 14px;display:flex}.extra-payment-row{justify-content:space-between;align-items:center;padding:10px 0;display:flex}.payment-split{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);gap:0;display:flex;overflow:hidden}.payment-split-item{text-align:center;flex:1;padding:14px 16px}.payment-split-divider{background:var(--border-subtle);flex-shrink:0;width:1px}.payment-split-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:700}.payment-split-val{font-variant-numeric:tabular-nums;font-size:20px;font-weight:800}.payment-split-sub{color:var(--text-muted);margin-top:4px;font-size:11px}@media (width<=900px){.stats-row-4{grid-template-columns:1fr 1fr}.debts-grid,.strategy-grid,.overview-top-grid{grid-template-columns:1fr}.projection-grid{grid-template-columns:1fr 1fr}.sim-comparison{grid-template-columns:1fr}}@media (width<=640px){.stats-row-4{grid-template-columns:1fr}.detail-header-top{flex-direction:column}.detail-header-balance{text-align:left}}
