*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1773cf;--primary-light:#e8f1fb;--success:#27ae60;--danger:#e74c3c;--warning:#f1c40f;--bg:#f1f5f9;--surface:#fff;--surface2:#f8fafc;--border:#e2e8f0;--text:#1c1c1e;--text-sub:#64748b;--sidebar-bg:#fff;--input-bg:#f8fafc}[data-theme=dark]{--bg:#0f172a;--surface:#1e293b;--surface2:#0f172a;--border:#334155;--text:#f8fafc;--text-sub:#94a3b8;--sidebar-bg:#1e293b;--input-bg:#0f172a;--primary-light:#1773cf1f}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;overscroll-behavior:none;-webkit-overflow-scrolling:touch;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}input,textarea,select{-webkit-user-select:text!important;user-select:text!important}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;overflow-y:auto}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:230px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);padding:20px 20px 16px}.logo-text{color:var(--primary);font-size:20px;font-weight:800}.sidebar-nav{flex-direction:column;gap:2px;padding:12px 10px;display:flex}.nav-item{color:var(--text-sub);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--primary-light);color:var(--primary)}.nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:700}.screen{max-width:900px;margin:0 auto;padding:24px 20px 80px}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header h2,.screen>h2{color:var(--text);margin-bottom:20px;font-size:22px;font-weight:800}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin-bottom:16px;padding:20px}.card-title{color:var(--text);margin-bottom:14px;font-size:15px;font-weight:700}.card-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.summary-card{justify-content:space-between;align-items:center;display:flex}.summary-small{padding:16px 20px}.grid-2{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.balance-card{background:var(--primary);color:#fff;border-radius:20px;margin-bottom:20px;padding:28px 24px;transition:background .3s}.balance-card.balance-negative{background:#c0392b}.balance-label{opacity:.85;margin-bottom:6px;font-size:13px}.balance-value{margin-bottom:16px;font-size:36px;font-weight:900}.balance-row{gap:20px;display:flex}.balance-stat{opacity:.9;align-items:center;gap:6px;font-size:13px;display:flex}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px}.stat-card.inc{border-left:3px solid var(--success)}.stat-card.exp{border-left:3px solid var(--danger)}.stat-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600}.stat-value{color:var(--text);font-size:18px;font-weight:800}.stat-sub{color:var(--text-sub);margin-top:4px;font-size:11px}.health-score{align-items:center;gap:16px;display:flex}.score-circle{border:5px solid var(--color,var(--primary));background:color-mix(in srgb,var(--color,var(--primary)) 10%,transparent);border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.score-num{color:var(--color,var(--primary));font-size:22px;font-weight:900;line-height:1}.score-max{color:var(--text-sub);font-size:10px}.score-bars{flex-direction:column;flex:1;gap:10px;display:flex}.score-bar-row{flex-direction:column;gap:4px;display:flex}.score-bar-row span{color:var(--text-sub);font-size:11px;font-weight:600}.bar-bg{background:var(--border);border-radius:3px;height:5px}.bar-fill{border-radius:3px;height:5px;transition:width .5s}.tx-list{flex-direction:column;gap:2px;display:flex}.tx-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.tx-item:last-child{border-bottom:none}.tx-icon{background:var(--primary-light);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.tx-info{flex:1;min-width:0}.tx-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.tx-meta{color:var(--text-sub);margin-top:2px;font-size:12px}.tx-note{color:var(--text-sub);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:12px;font-style:italic;overflow:hidden}.tx-amount{white-space:nowrap;font-size:14px;font-weight:700}.tx-amount.inc{color:var(--success)}.tx-amount.exp{color:var(--danger)}.tx-actions{gap:4px;display:flex}.amount-green{color:var(--success);font-weight:700}.amount-red{color:var(--danger);font-weight:700}.sub-label{color:var(--text-sub);font-size:12px}.field{margin-bottom:14px}.field label{color:var(--text-sub);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.field-optional{font-size:12px;font-weight:400}.note-textarea{border:1.5px solid var(--border);background:var(--input-bg);width:100%;color:var(--text);resize:none;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s}.note-textarea:focus{border-color:var(--primary);outline:none}.custom-emoji-row{align-items:center;gap:8px;margin-top:10px;display:flex}.custom-emoji-label{color:var(--text-sub);white-space:nowrap;font-size:12px}.custom-emoji-input{border:1.5px solid var(--border);background:var(--input-bg);width:52px;color:var(--text);text-align:center;border-radius:8px;padding:6px 8px;font-size:20px}.custom-emoji-input:focus{border-color:var(--primary);outline:none}.custom-emoji-preview{font-size:26px;line-height:1}input,select,textarea{border:1.5px solid var(--border);background:var(--input-bg);width:100%;color:var(--text);border-radius:10px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s}input:focus,select:focus{border-color:var(--primary)}input.error,select.error{border-color:var(--danger)}.err-msg{color:var(--danger);margin-top:4px;font-size:12px;display:block}.amount-row{gap:8px;display:flex}.amount-row input{flex:1}.amount-row select{flex-shrink:0;width:90px}.password-field{display:flex;position:relative}.password-field input{flex:1;padding-right:40px}.password-field .icon-btn{position:absolute;top:50%;right:8px;transform:translateY(-50%)}button{cursor:pointer;border:none;font-family:inherit}.btn-primary{background:var(--primary);color:#fff;border-radius:10px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{border:1.5px solid var(--primary);color:var(--primary);background:0 0;border-radius:10px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:600;display:flex}.btn-danger{background:var(--danger);color:#fff;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:15px;font-weight:700;display:flex}.btn-sm{background:var(--primary-light);color:var(--primary);border:none;border-radius:8px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:600;display:flex}.btn-sm.success{color:var(--success);background:#27ae601f}.btn-sm:disabled{opacity:.4;cursor:not-allowed}.icon-btn{color:var(--text-sub);background:0 0;border-radius:8px;align-items:center;padding:6px;display:flex}.icon-btn:hover{background:var(--border)}.save-btn{color:#fff;border-radius:12px;width:100%;margin-top:8px;padding:13px;font-size:15px;font-weight:700;transition:opacity .15s}.save-btn.inc{background:var(--success)}.save-btn.exp{background:var(--primary)}.save-btn:disabled{opacity:.5}.full-width{justify-content:center;width:100%;margin-top:8px}.type-toggle{background:var(--border);border-radius:10px;margin-bottom:16px;padding:3px;display:flex}.type-toggle button{color:var(--text-sub);background:0 0;border-radius:8px;flex:1;padding:8px;font-size:14px;font-weight:600}.type-toggle button.active.exp{background:var(--danger);color:#fff}.type-toggle button.active.inc{background:var(--success);color:#fff}.tab-row{gap:8px;margin-bottom:16px;display:flex}.tab-row button,.filter-btns button{background:var(--surface);border:1.5px solid var(--border);color:var(--text-sub);border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .15s}.tab-row button.active,.filter-btns button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filters-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-box{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:200px;padding:8px 12px;display:flex}.search-box input{color:var(--text);background:0 0;border:none;padding:0;font-size:14px}.search-box input:focus{border:none}.filter-btns{flex-wrap:wrap;gap:6px;display:flex}.cat-chips{flex-wrap:wrap;gap:6px;margin-bottom:4px;display:flex}.cat-chip{background:var(--surface2);border:1.5px solid var(--border);color:var(--text-sub);cursor:pointer;border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .15s}.cat-chip.active{background:color-mix(in srgb,var(--cat-color,var(--primary)) 15%,transparent);border-color:var(--cat-color,var(--primary));color:var(--cat-color,var(--primary))}.color-row{flex-wrap:wrap;gap:8px;display:flex}.color-circle{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform .15s}.color-circle.active{border-color:var(--text);transform:scale(1.2)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border-radius:20px;width:100%;max-width:480px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h3{color:var(--text);font-size:18px;font-weight:800}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-box{background:var(--surface);border-radius:24px;width:100%;max-width:420px;padding:36px 32px;box-shadow:0 4px 30px #0000001a}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo span{font-size:48px}.auth-logo h1{color:var(--primary);margin:8px 0 4px;font-size:28px;font-weight:900}.auth-logo p{color:var(--text-sub);font-size:14px}.auth-box h2{color:var(--text);margin-bottom:20px;font-size:20px;font-weight:800}.auth-switch{text-align:center;color:var(--text-sub);margin-top:16px;font-size:14px}.auth-switch button{color:var(--primary);background:0 0;font-size:14px;font-weight:700;text-decoration:underline}.remembered-card{background:var(--primary-light);border:1.5px solid var(--primary);border-radius:14px;align-items:center;gap:12px;margin-bottom:4px;padding:14px 16px;display:flex}.remembered-avatar{background:var(--surface);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 2px 8px #1773cf26}.remembered-name{color:var(--primary);margin-bottom:2px;font-size:13px;font-weight:600}.remembered-phone{color:var(--text);font-size:15px;font-weight:800}.profile-header{text-align:center;margin-bottom:24px}.avatar-lg{background:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin:0 auto 12px;display:flex}.profile-name{color:var(--text);font-size:20px;font-weight:800}.settings-row{justify-content:space-between;align-items:center;display:flex}.theme-toggle{background:var(--primary-light);width:40px;height:40px;color:var(--primary);border-radius:12px;justify-content:center;align-items:center;display:flex}.wallet-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.wallet-item:last-child{border-bottom:none}.wallet-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.wallet-name{color:var(--text);font-size:15px;font-weight:700}.saving-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.saving-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.saving-goal{color:var(--text);font-size:17px;font-weight:700}.saving-actions{align-items:center;gap:8px;margin-top:10px;display:flex}.progress-bg{background:var(--border);border-radius:4px;height:8px}.progress-fill{border-radius:4px;height:8px;transition:width .5s}.plan-result{background:var(--primary-light);text-align:center;border-radius:14px;margin-top:12px;padding:16px}.plan-result p{color:var(--text-sub);font-size:13px}.plan-amount{color:var(--primary);margin:6px 0;font-size:28px;font-weight:900}.sub-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.sub-item:last-child{border-bottom:none}.sub-item.due{background:#e74c3c0a;border-radius:10px;margin:-4px;padding:12px}.sub-icon{font-size:24px}.sub-name{color:var(--text);font-size:15px;font-weight:700}.sub-meta{color:var(--text-sub);margin-top:2px;font-size:12px}.format-list{flex-direction:column;gap:8px;display:flex}.format-item{border:1.5px solid var(--border);cursor:pointer;color:var(--text);border-radius:12px;align-items:center;gap:12px;padding:14px;font-size:14px;font-weight:600;display:flex}.format-item.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.format-item input[type=radio]{width:auto;margin:0}.badge-green{color:var(--success);background:#27ae601f;border-radius:20px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.debt-summary{justify-content:space-between;display:flex}.debt-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.debt-item:last-child{border-bottom:none}.debt-item.paid{opacity:.5}.debt-icon{font-size:24px}.debt-info{flex:1}.debt-name{color:var(--text);font-size:15px;font-weight:700}.debt-meta{color:var(--text-sub);margin-top:2px;font-size:12px}.debt-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.cat-legend{flex-direction:column;gap:6px;margin-top:12px;display:flex}.legend-item{align-items:center;gap:8px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-name{color:var(--text);flex:1;font-size:13px}.legend-pct{color:var(--text-sub);font-size:13px;font-weight:700}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;min-width:280px;max-width:360px;padding:12px 16px;animation:.2s slideIn;display:flex;box-shadow:0 8px 24px #00000026}.toast span{color:var(--text);flex:1;font-size:14px;font-weight:500}.toast button{color:var(--text-sub);background:0 0;padding:2px}.toast-success{border-left:3px solid var(--success)}.toast-warning{border-left:3px solid var(--warning)}.toast-error{border-left:3px solid var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.install-banner{background:var(--surface);border:1.5px solid var(--primary);z-index:500;border-radius:16px;align-items:center;gap:10px;padding:12px 14px;animation:.3s slideUp;display:flex;position:fixed;bottom:80px;left:12px;right:12px;box-shadow:0 8px 32px #1773cf33}.install-banner-icon{flex-shrink:0;font-size:28px}.install-banner-text{flex:1;min-width:0}.install-title{color:var(--text);font-size:13px;font-weight:700}.install-sub{color:var(--text-sub);margin-top:2px;font-size:11px}.install-btn{background:var(--primary);color:#fff;white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;gap:4px;padding:7px 12px;font-size:12px;font-weight:700;display:flex}.install-close{color:var(--text-sub);background:0 0;flex-shrink:0;padding:4px}@media (width>=769px){.install-banner{max-width:420px;bottom:24px;left:50%;right:auto;transform:translate(-50%)}}.cat-manage-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.cat-manage-item:last-child{border-bottom:none}.cat-manage-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.cat-manage-name{color:var(--text);flex:1;font-size:14px;font-weight:600}.cat-manage-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.new-cat-chip{border-style:dashed!important}.new-cat-form{background:var(--surface2);border:1.5px solid var(--border);border-radius:12px;margin-top:8px;padding:12px}.new-cat-icons{flex-wrap:wrap;gap:6px;display:flex}.icon-pick{background:var(--surface);border:1.5px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:all .15s;display:flex}.icon-pick.active{border-color:var(--primary);background:var(--primary-light);transform:scale(1.15)}.confirm-box{text-align:center;max-width:320px}.confirm-icon{justify-content:center;margin-bottom:12px;display:flex}.confirm-msg{color:var(--text);margin-bottom:20px;font-size:15px;line-height:1.5}.confirm-actions{gap:10px;display:flex}.confirm-actions button{flex:1;justify-content:center}.loader-page{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loader-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-text{text-align:center;color:var(--text-sub);padding:32px 0;font-size:14px}.fab{background:var(--primary);color:#fff;z-index:100;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .15s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #1773cf66}.fab:hover{transform:scale(1.05)}.bottom-nav{display:none}@media (width<=768px){.sidebar{display:none}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:100;height:62px;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px);-webkit-backdrop-filter:blur(12px);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tab{color:var(--text-sub);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-width:0;padding:6px 4px;font-size:10px;font-weight:500;transition:color .15s;display:flex}.bottom-tab span{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.bottom-tab.active{color:var(--primary)}.bottom-tab-add{background:var(--primary);color:#fff;border-radius:50%;flex:none;width:50px;height:50px;margin:-12px 6px auto;padding:0;font-size:0;box-shadow:0 4px 16px #1773cf73}.bottom-sheet-overlay{z-index:300;background:#00000073;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.bottom-sheet{background:var(--surface);padding:12px 16px calc(16px + env(safe-area-inset-bottom,0px));border-radius:24px 24px 0 0;animation:.25s cubic-bezier(.32,.72,0,1) slideUp}.bottom-sheet-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.bottom-sheet-header{color:var(--text);justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.more-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.more-item{background:var(--surface2);border:1.5px solid var(--border);color:var(--text-sub);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;font-size:11px;font-weight:600;transition:all .15s;display:flex}.more-item.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.main-content{padding-bottom:70px}.fab{display:none;bottom:78px;right:16px}.grid-2,.grid-3{grid-template-columns:1fr}.screen{padding:16px 12px 24px}.modal-box{border-radius:16px;padding:20px}.balance-value{font-size:28px}.toast-container{bottom:80px;left:12px;right:12px}.toast{min-width:unset;max-width:unset}}@keyframes slideUp{0%{opacity:.6;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@supports (padding-bottom:env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(62px + env(safe-area-inset-bottom))}.main-content{padding-bottom:calc(70px + env(safe-area-inset-bottom));padding-top:env(safe-area-inset-top,0px)}}.install-card-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.install-card-header .card-title{margin-bottom:0}.install-done{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px 0;display:flex}.install-done p{color:var(--success);font-weight:600}.install-ios-title{color:var(--text);margin-bottom:12px;font-size:13px;font-weight:700}.install-android{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.install-info{margin-bottom:16px}.install-steps{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.install-step{color:var(--text);align-items:flex-start;gap:12px;font-size:14px;line-height:1.5;display:flex}.install-step-num{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:26px;height:26px;margin-top:1px;font-size:12px;font-weight:800;display:flex}.app-install-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 20px;font-size:15px;font-weight:700;transition:opacity .15s;display:flex}.app-install-btn:disabled{opacity:.6}.app-install-btn:hover:not(:disabled){opacity:.9}.install-features{border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:8px;margin-top:16px;padding-top:16px;display:grid}.install-feature{color:var(--text-sub);background:var(--surface2);border-radius:8px;padding:8px 10px;font-size:12px}.budget-item{border-bottom:1px solid var(--border);padding:14px 0}.budget-item:last-child{border-bottom:none}.budget-header{align-items:center;gap:10px;margin-bottom:4px;display:flex}.budget-cat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.budget-cat-name{color:var(--text);font-size:15px;font-weight:700}.recurring-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.recurring-item:last-child{border-bottom:none}.recurring-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.heatmap-weekdays{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px;display:grid}.heatmap-wd{color:var(--text-sub);text-align:center;font-size:10px;font-weight:600}.heatmap-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.heatmap-cell{aspect-ratio:1;cursor:default;border:2px solid #0000;border-radius:5px;justify-content:center;align-items:center;transition:transform .1s;display:flex}.heatmap-cell:hover{transform:scale(1.15)}.heatmap-cell.empty{background:0 0!important}.heatmap-cell.today{border-color:var(--primary)!important}.heatmap-day{color:var(--text);opacity:.7;font-size:9px;font-weight:700;line-height:1}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:8px;display:flex}.heatmap-legend-cell{border-radius:3px;width:14px;height:14px}.insight-item{border-left:3px solid;border-radius:10px;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.insight-good{border-color:var(--success);background:#27ae600f}.insight-warn{border-color:var(--warning);background:#f1c40f14}.insight-bad{border-color:var(--danger);background:#e74c3c0f}.insight-info{background:var(--surface2);border-color:var(--border)}.insight-icon{flex-shrink:0;margin-top:1px;font-size:16px}.insight-text{color:var(--text);font-size:13px;line-height:1.5}.tx-date-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:4px;padding-bottom:8px;display:flex}.tx-date-label{color:var(--text-sub);font-size:13px;font-weight:700}.tx-date-totals{gap:8px;display:flex}.import-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:14px;padding:40px 20px;transition:border-color .15s}.import-dropzone:hover{border-color:var(--primary)}.onboarding-steps{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px;display:grid}.onboarding-step{background:var(--surface2);border:1.5px solid var(--border);text-align:center;border-radius:14px;padding:14px 12px}.onboarding-icon{margin-bottom:8px;font-size:28px;display:block}.onboarding-title{color:var(--text);margin-bottom:4px;font-size:13px;font-weight:700}.onboarding-desc{color:var(--text-sub);font-size:11px;line-height:1.4}.widget-panel{margin-bottom:12px;padding:16px}.widget-toggles{flex-wrap:wrap;gap:8px;display:flex}.widget-toggle-btn{background:var(--surface2);border:1.5px solid var(--border);color:var(--text-sub);cursor:pointer;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.widget-toggle-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
