:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--text-primary: rgba(255, 255, 255, .95);--text-secondary: rgba(255, 255, 255, .6);--card-bg: #1a1a1a;--card-shadow: 0 1px 3px rgba(0, 0, 0, .3);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .4);--border-color: rgba(255, 255, 255, .1);--input-bg: #252525;--item-bg: #252525;--item-bg-hover: #2a2a2a;--navbar-bg: rgba(15, 15, 15, .9);--table-header-bg: #1f1f1f;--primary-color: #6366f1;--primary-color-dark: #4f46e5;--primary-color-alpha: rgba(99, 102, 241, .15);--chart-grid: rgba(255, 255, 255, .1);--progress-track: rgba(255, 255, 255, .1);--badge-bg: rgba(99, 102, 241, .15);--secondary-btn-bg: transparent;--secondary-btn-bg-hover: rgba(255, 255, 255, .1);--edit-btn-bg: rgba(99, 102, 241, .15);--edit-btn-color: #6366f1;--edit-btn-bg-hover: rgba(99, 102, 241, .25);--delete-btn-bg: rgba(239, 68, 68, .15);--delete-btn-color: #ef4444;--delete-btn-bg-hover: rgba(239, 68, 68, .25);--error-color: #ef4444;--error-color-alpha: rgba(239, 68, 68, .2)}@media(prefers-color-scheme:light){:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--text-primary: #1a1a1a;--text-secondary: rgba(0, 0, 0, .6);--card-bg: #ffffff;--card-shadow: 0 1px 3px rgba(0, 0, 0, .1);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .15);--border-color: rgba(0, 0, 0, .1);--input-bg: #fafafa;--item-bg: #f8f8f8;--item-bg-hover: #f0f0f0;--navbar-bg: rgba(255, 255, 255, .9);--table-header-bg: #fafafa;--chart-grid: rgba(0, 0, 0, .1);--progress-track: rgba(0, 0, 0, .1);--secondary-btn-bg-hover: rgba(0, 0, 0, .05)}}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);-webkit-tap-highlight-color:transparent}#root{width:100%;min-height:100vh}a{font-weight:500;color:var(--primary-color);text-decoration:none}a:hover{color:var(--primary-color-dark)}h1,h2,h3,h4,h5,h6{margin:0}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.navbar{display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:60px;background:var(--navbar-bg);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.navbar-brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.brand-icon{font-size:1.4rem}.brand-text{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.navbar-links{display:flex;gap:.25rem;align-items:center}.nav-link{padding:.4rem .75rem;color:var(--text-secondary);text-decoration:none;border-radius:7px;font-weight:500;font-size:.875rem;transition:all .15s;white-space:nowrap}.nav-link:hover{color:var(--text-primary);background:var(--item-bg-hover)}.nav-link.active{color:var(--primary-color);background:var(--primary-color-alpha)}.navbar-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-export{padding:.4rem .875rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:7px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-export:hover{background:var(--item-bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.export-dropdown{position:relative}.export-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #0003;min-width:160px;z-index:200;overflow:hidden}.export-menu button{display:block;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:background .15s}.export-menu button:hover{background:var(--item-bg-hover)}.export-menu button:not(:last-child){border-bottom:1px solid var(--border-color)}.btn-logout{padding:.4rem .875rem;background:var(--delete-btn-bg);color:var(--delete-btn-color);border:1px solid rgba(239,68,68,.3);border-radius:7px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-logout:hover{background:var(--delete-btn-bg-hover)}.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;transition:background .15s;flex-shrink:0}.hamburger:hover{background:var(--item-bg-hover)}.hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .25s ease,opacity .25s ease}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:900px){.navbar{flex-wrap:wrap;height:auto;padding:.875rem 1.25rem;gap:0}.navbar-brand{flex:1}.navbar-actions{order:2}.hamburger{display:flex;order:3;margin-left:.5rem}.navbar-links{order:4;width:100%;flex-direction:column;align-items:stretch;gap:.125rem;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,border-color .3s;border-top:1px solid transparent}.navbar-links.open{max-height:600px;padding:.625rem 0;border-top-color:var(--border-color);margin-top:.625rem}.nav-link{padding:.75rem 1rem;border-radius:8px;font-size:.9375rem}}@media(max-width:480px){.navbar{padding:.75rem 1rem}.btn-logout span{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:1rem}.login-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:var(--card-shadow)}.login-header{text-align:center;margin-bottom:2rem}.login-icon{font-size:2.5rem}.login-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:.5rem 0 .25rem}.login-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-error{background:var(--delete-btn-bg);color:var(--error-color);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:.75rem 1rem;font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.95rem;padding:.65rem .9rem;transition:border-color .2s;outline:none}.form-group input:focus{border-color:var(--primary-color)}.login-btn{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:.25rem;padding:.75rem;transition:background .2s,opacity .2s;width:100%}.login-btn:hover:not(:disabled){background:var(--primary-color-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.dashboard h1{margin:0;color:var(--text-primary);font-size:2rem}.dashboard h2{margin-bottom:1rem;color:var(--text-primary);font-size:1.25rem}.help-tip-btn{width:18px;height:18px;border-radius:50%;background:var(--border-color);color:var(--text-secondary);border:none;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.help-tip-popup{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:10px 14px;font-size:.8rem;color:var(--text-secondary);width:260px;z-index:9999;box-shadow:0 4px 12px #00000026;line-height:1.45;pointer-events:none}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:1rem}.card{position:relative;overflow:visible}.card:has(.help-tip-container:hover){z-index:1000}.card>.help-tip-container{position:absolute;top:12px;right:12px}.dashboard-filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.dashboard-filters select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:140px}.dashboard-filters select:focus{outline:none;border-color:var(--primary-color)}.btn-clear-filters{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background:var(--item-bg-hover);color:var(--text-primary)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:1.5rem;overflow:visible}.secondary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;overflow:visible}.secondary-cards .card{padding:1.25rem}.secondary-cards .card .amount{font-size:1.5rem}.card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.card h3{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.card .amount{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.card .amount.positive{color:#22c55e}.card .amount.negative{color:#ef4444}.card .amount.income-amount{color:#22c55e}.card .count{font-size:.875rem;color:var(--text-secondary)}.card .change{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;display:inline-block;margin-top:.25rem}.card .change.increase{color:#ef4444;background:#ef44441a}.card .change.decrease{color:#22c55e;background:#22c55e1a}.total-card{border-left:4px solid #6366f1}.income-card{border-left:4px solid #22c55e}.savings-card{border-left:4px solid #10b981}.avg-card{border-left:4px solid #f59e0b}.month-card{border-left:4px solid #3b82f6}.avg-transaction-card{border-left:4px solid #ec4899}.highest-day-card{border-left:4px solid #ef4444}.categories-card{border-left:4px solid #8b5cf6}.current-balance-section{margin-bottom:1.5rem}.current-balance-card{background:linear-gradient(135deg,var(--card-bg) 0%,rgba(59,130,246,.05) 100%);border:2px solid #3b82f6;border-radius:16px;padding:2rem;text-align:center;position:relative}.current-balance-card h3{font-size:1.1rem;color:var(--text-secondary);margin-bottom:.75rem;font-weight:600}.current-balance-card .balance-amount{font-size:2.5rem;font-weight:800;margin:.5rem 0}.current-balance-card .balance-amount.positive{color:#22c55e}.current-balance-card .balance-amount.negative{color:#ef4444}.btn-edit-balance{background:transparent;border:1px solid var(--border-color);border-radius:8px;padding:.5rem 1rem;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s;margin-top:.75rem}.btn-edit-balance:hover{background:var(--item-bg-hover);color:var(--text-primary);border-color:#3b82f6}.balance-edit-form{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:.5rem}.balance-edit-form input{width:200px;padding:.75rem 1rem;font-size:1.5rem;text-align:center;border:2px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-weight:600}.balance-edit-form input:focus{outline:none;border-color:#3b82f6}.balance-edit-actions{display:flex;gap:.75rem}.balance-edit-actions .btn-save{background:#22c55e;color:#fff;border:none;border-radius:8px;padding:.5rem 1.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.balance-edit-actions .btn-save:hover{background:#16a34a}.balance-edit-actions .btn-cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem 1.5rem;font-size:.875rem;cursor:pointer;transition:all .2s}.balance-edit-actions .btn-cancel:hover{background:var(--item-bg-hover);color:var(--text-primary)}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));gap:1.5rem;margin-bottom:2rem}.chart-container{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color)}.recent-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color);margin-bottom:2rem}.recent-list{display:flex;flex-direction:column;gap:.75rem}.recent-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--item-bg);border-radius:8px;transition:background-color .2s}.recent-item:hover{background:var(--item-bg-hover)}.recent-info{display:flex;flex-direction:column;gap:.25rem}.recent-category{font-size:.75rem;color:var(--primary-color);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.recent-description{font-weight:500;color:var(--text-primary)}.recent-date{font-size:.875rem;color:var(--text-secondary)}.recent-amount{font-weight:600;font-size:1.125rem;color:var(--text-primary)}.top-categories-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color)}.category-bars{display:flex;flex-direction:column;gap:1rem}.category-bar-item{display:flex;flex-direction:column;gap:.5rem}.category-bar-header{display:flex;justify-content:space-between;align-items:center}.category-amount{font-weight:600;color:var(--text-secondary)}.category-bar-track{height:8px;background:var(--progress-track);border-radius:4px;overflow:hidden}.category-bar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;transition:width .5s ease}.category-percentage{font-size:.75rem;color:var(--text-secondary);align-self:flex-end}.day-of-week-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);border:1px solid var(--border-color);margin-bottom:2rem}.day-bars{display:flex;flex-direction:column;gap:.75rem}.day-bar-item{display:grid;grid-template-columns:50px 1fr 100px;align-items:center;gap:1rem}.day-name{font-weight:500;color:var(--text-primary);font-size:.875rem}.day-bar-track{height:12px;background:var(--progress-track);border-radius:6px;overflow:hidden}.day-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:6px;transition:width .5s ease}.day-amount{font-size:.875rem;color:var(--text-secondary);text-align:right}.loading{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.25rem;color:var(--text-secondary)}.no-data{display:flex;justify-content:center;align-items:center;height:200px;color:var(--text-secondary)}@media(max-width:768px){.dashboard{padding:1rem}.dashboard h1{font-size:1.5rem}.dashboard-header{gap:.75rem}.dashboard-filters{flex-direction:column;align-items:stretch}.dashboard-filters select{width:100%}.charts-section{grid-template-columns:1fr}.summary-cards,.secondary-cards{grid-template-columns:repeat(2,1fr)}.card .amount{font-size:1.5rem}.day-bar-item{grid-template-columns:40px 1fr 80px;gap:.5rem}.current-balance-card .balance-amount{font-size:2rem}.debt-analytics-section,.largest-transactions{grid-template-columns:1fr}}@media(max-width:480px){.summary-cards,.secondary-cards{grid-template-columns:1fr}.day-bar-item{grid-template-columns:35px 1fr 70px;gap:.5rem}.day-amount{font-size:.75rem}}.debt-summary-section{margin-top:2rem;padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.debt-summary-section h2{margin-bottom:1.5rem}.debt-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;overflow:visible}.debt-summary-cards .card{padding:1.25rem}.debt-owed-card{border-left:4px solid #ef4444}.debt-receivable-card{border-left:4px solid #22c55e}.debt-net-card{border-left:4px solid #8b5cf6}.entities-card{border-left:4px solid #0ea5e9}.active-debts-list{border-top:1px solid var(--border-color);padding-top:1.5rem}.active-debts-list h3{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.debt-items{display:flex;flex-direction:column;gap:.75rem}.debt-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--item-bg);border-radius:8px;transition:background .2s}.debt-item:hover{background:var(--item-bg-hover)}.debt-item.owed{border-left:3px solid #ef4444}.debt-item.receivable{border-left:3px solid #22c55e}.debt-item-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.debt-type-badge{font-size:1rem}.debt-person{font-weight:500;color:var(--text-primary)}.debt-desc{color:var(--text-secondary);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debt-item-amount{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.debt-item-amount .negative{color:#ef4444;font-weight:600}.debt-item-amount .positive{color:#22c55e;font-weight:600}.debt-progress-mini{width:60px;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-bar-mini{height:100%;background:var(--primary-color);border-radius:2px;transition:width .3s ease}.financial-health-section{margin-top:2rem;padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.health-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;overflow:visible}.health-card{border-left:4px solid var(--primary-color)}.health-card .amount.positive{color:#22c55e}.health-card .amount.warning{color:#f59e0b}.health-card .amount.negative{color:#ef4444}.weekend-weekday-split{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.split-item{display:flex;justify-content:space-between;font-size:.875rem}.split-label{color:var(--text-secondary)}.split-value{font-weight:500;color:var(--text-primary)}.largest-transactions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.largest-item{display:flex;flex-direction:column;gap:.25rem;padding:1rem;background:var(--item-bg);border-radius:8px}.largest-item.expense{border-left:3px solid #ef4444}.largest-item.income{border-left:3px solid #22c55e}.largest-label{font-size:.75rem;text-transform:uppercase;color:var(--text-secondary)}.largest-desc{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.largest-amount{font-weight:600;font-size:1.125rem}.largest-amount.negative{color:#ef4444}.largest-amount.positive{color:#22c55e}.debt-analytics-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.top-debtors,.upcoming-dues{padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.top-debtors h3,.upcoming-dues h3{font-size:1rem;margin-bottom:1rem;color:var(--text-primary)}.debtor-list,.due-list{display:flex;flex-direction:column;gap:.75rem}.debtor-item,.due-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--item-bg);border-radius:8px}.debtor-name,.due-person{font-weight:500;color:var(--text-primary)}.debtor-amounts{display:flex;gap:1rem;font-size:.875rem}.amount-owed{color:#ef4444}.amount-receivable{color:#22c55e}.due-info{display:flex;flex-direction:column;gap:.25rem}.due-date{font-size:.75rem;color:var(--text-secondary)}.due-item.overdue .due-date{color:#ef4444;font-weight:500}.due-item.urgent .due-date{color:#f59e0b;font-weight:500}.due-amount{font-weight:600}.due-amount.negative{color:#ef4444}.due-amount.positive{color:#22c55e}.cashflow-section{margin-top:2rem;padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.cashflow-bars{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.cashflow-item{padding:1rem;background:var(--item-bg);border-radius:8px}.cashflow-month{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:.875rem}.cashflow-details{display:flex;flex-direction:column;gap:.5rem}.cashflow-row{display:flex;justify-content:space-between;font-size:.8rem}.cashflow-row.net{padding-top:.5rem;border-top:1px solid var(--border-color);font-weight:600}.cf-label{color:var(--text-secondary)}.cf-value{font-weight:500}.cf-value.positive{color:#22c55e}.cf-value.negative{color:#ef4444}@media(max-width:768px){.help-tip-popup{left:auto;right:0;transform:none;width:220px}.help-tip-popup:before{left:auto;right:8px;transform:none}}.budget-progress-section{margin-bottom:2rem}.budget-progress-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.no-active-budgets{grid-column:1 / -1;text-align:center;padding:2rem;background:var(--card-bg);border-radius:12px;border:2px dashed var(--border-color);color:var(--text-secondary)}.no-active-budgets a{color:#3b82f6;text-decoration:none}.no-active-budgets a:hover{text-decoration:underline}.budget-progress-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform .2s}.budget-progress-card:hover{transform:translateY(-2px)}.budget-progress-card.on-track{border-left:4px solid #22c55e}.budget-progress-card.warning{border-left:4px solid #f59e0b}.budget-progress-card.exceeded{border-left:4px solid #ef4444}.budget-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.budget-period-label{font-weight:700;font-size:1rem;color:var(--text-primary)}.budget-category-tag{font-size:.7rem;padding:.2rem .5rem;background:var(--item-bg-hover);border-radius:12px;color:var(--text-secondary)}.budget-progress-card .budget-name{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem}.budget-amounts-row{display:flex;align-items:baseline;gap:.25rem;margin-bottom:.75rem}.budget-amounts-row .spent{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.budget-amounts-row .separator{color:var(--text-secondary)}.budget-amounts-row .total{font-size:.9rem;color:var(--text-secondary)}.budget-progress-bar{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:.75rem}.budget-progress-bar .progress-fill{height:100%;border-radius:4px;transition:width .3s}.budget-progress-bar .progress-fill.on-track{background:#22c55e}.budget-progress-bar .progress-fill.warning{background:#f59e0b}.budget-progress-bar .progress-fill.exceeded{background:#ef4444}.budget-progress-footer{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.budget-progress-footer .remaining{font-weight:500}.budget-progress-footer .remaining.positive{color:#22c55e}.budget-progress-footer .remaining.negative{color:#ef4444}.budget-progress-footer .percent{font-weight:700}.budget-progress-footer .percent.on-track{color:#22c55e}.budget-progress-footer .percent.warning{color:#f59e0b}.budget-progress-footer .percent.exceeded{color:#ef4444}.modal-backdrop,.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:var(--card-bg);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-close{width:32px;height:32px;border:none;background:transparent;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s}.modal-close:hover{background:var(--item-bg-hover);color:var(--text-primary)}.modal-content form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.875rem}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha)}.form-group input.error,.form-group select.error{border-color:var(--error-color)}.form-group input.error:focus,.form-group select.error:focus{box-shadow:0 0 0 3px var(--error-color-alpha)}.error-text{display:block;margin-top:.5rem;font-size:.75rem;color:var(--error-color)}.btn-link{background:none;border:none;color:var(--primary-color);font-size:.875rem;cursor:pointer;padding:.5rem 0;transition:color .2s}.btn-link:hover{color:var(--primary-color-dark);text-decoration:underline}.checkbox-group{margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.checkbox-label span{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.form-actions .btn-primary,.form-actions .btn-secondary{min-width:120px}.line-items-section{margin-top:1rem;padding:1rem;background:var(--card-bg, #1e1e1e);border-radius:8px;border:1px solid var(--border-color)}.line-items-section h4{margin:0 0 1rem;font-size:.95rem;color:var(--text-primary)}.line-items-table{display:flex;flex-direction:column;gap:.5rem}.line-items-header{display:grid;grid-template-columns:2fr 60px 80px 80px 36px;gap:.5rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);padding:.5rem .25rem;background:#ffffff0d;border-radius:4px;margin-bottom:.5rem}.line-items-table .line-item-row{display:grid;grid-template-columns:2fr 60px 80px 80px 36px;gap:.5rem;align-items:center;padding:.5rem .25rem;background:#ffffff08;border-radius:4px;margin-bottom:.25rem}.line-items-table .line-item-row input{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.85rem;background:var(--input-bg, #2a2a2a);color:var(--text-primary);width:100%;box-sizing:border-box}.line-items-table .line-item-row input:focus{outline:none;border-color:var(--primary-color)}.line-items-table .line-item-row input[type=number]{text-align:right}.line-items-table .line-item-row .item-total{text-align:right;font-weight:600;font-size:.85rem;color:var(--primary-color);padding-right:.25rem}.line-items-table .line-item-row .btn-icon{width:28px;height:28px;padding:0;font-size:.85rem;background:transparent;border:none;color:#ef4444;cursor:pointer;opacity:.7;transition:opacity .2s}.line-items-table .line-item-row .btn-icon:hover{opacity:1}.btn-add-item{margin-top:.75rem;padding:.5rem 1rem;background:none;border:1px dashed var(--border-color);border-radius:6px;color:var(--primary-color);font-size:.85rem;cursor:pointer;transition:all .2s}.btn-add-item:hover{background:var(--bg-hover, #f0f7ff);border-color:var(--primary-color)}.line-items-total{display:flex;justify-content:space-between;margin-top:1rem;padding-top:.75rem;border-top:2px solid var(--border-color);font-size:1rem}.line-items-total strong{color:var(--text-primary)}.line-items-total span{font-weight:600;color:var(--primary-color)}.hint-text{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.modal-content:has(.line-items-section){max-width:600px}.invoice-scanner-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.invoice-scanner-modal{background:var(--card-bg, #fff);border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.invoice-scanner-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e0e0e0);background:var(--header-bg, #f8f9fa)}.invoice-scanner-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #333)}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary, #666);padding:.25rem .5rem;line-height:1}.close-btn:hover{color:var(--text-primary, #333)}.invoice-scanner-content{padding:1.5rem;overflow-y:auto;flex:1}.error-message{background:#fee;border:1px solid #f88;color:#c00;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.upload-section{display:flex;flex-direction:column;gap:1rem}.drop-zone{border:2px dashed var(--border-color, #ccc);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--bg-light, #fafafa)}.drop-zone:hover{border-color:var(--primary-color, #4a90d9);background:var(--bg-hover, #f0f7ff)}.drop-zone.has-file{padding:1rem}.drop-icon{font-size:3rem;margin-bottom:1rem}.drop-zone p{margin:0 0 .5rem;color:var(--text-primary, #333);font-weight:500}.drop-zone .file-types{color:var(--text-secondary, #888);font-size:.85rem}.preview-image{max-width:100%;max-height:300px;border-radius:8px;object-fit:contain}.file-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-light, #f5f5f5);border-radius:6px}.file-info button{background:none;border:none;color:#c00;cursor:pointer;font-size:.9rem}.process-btn{background:var(--primary-color, #4a90d9);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.process-btn:hover:not(:disabled){background:var(--primary-hover, #3a7bc8);transform:translateY(-1px)}.process-btn:disabled{background:#ccc;cursor:not-allowed}.processing-section{text-align:center;padding:3rem}.spinner{width:60px;height:60px;border:4px solid var(--bg-light, #f0f0f0);border-top-color:var(--primary-color, #4a90d9);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.processing-section p{margin:0 0 .5rem;font-size:1.1rem;color:var(--text-primary, #333)}.processing-section span{color:var(--text-secondary, #888);font-size:.9rem}.review-section{display:flex;flex-direction:column;gap:1.5rem}.invoice-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-row{display:flex;flex-direction:column;gap:.25rem}.detail-row label{font-size:.85rem;font-weight:600;color:var(--text-secondary, #666)}.detail-row input,.detail-row select{padding:.5rem .75rem;border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:1rem;background:var(--input-bg, #fff);color:var(--text-primary, #333)}.items-table{background:var(--bg-light, #f8f9fa);border-radius:8px;padding:1rem}.items-table h3{margin:0 0 1rem;font-size:1rem;color:var(--text-primary, #333)}.items-table table{width:100%;border-collapse:collapse;font-size:.9rem}.items-table th{text-align:left;padding:.5rem;border-bottom:2px solid var(--border-color, #ddd);color:var(--text-secondary, #666);font-weight:600;font-size:.8rem}.items-table td{padding:.5rem;border-bottom:1px solid var(--border-color, #eee)}.items-table input,.items-table select{width:100%;padding:.4rem .5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.85rem;background:var(--input-bg, #fff);color:var(--text-primary, #333)}.items-table input[type=number]{width:70px}.items-table select{width:100px}.total-cell{font-weight:600;color:var(--text-primary, #333)}.remove-item-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;opacity:.6;transition:opacity .2s}.remove-item-btn:hover{opacity:1}.add-item-btn{background:none;border:1px dashed var(--border-color, #ccc);color:var(--primary-color, #4a90d9);padding:.5rem 1rem;border-radius:6px;cursor:pointer;margin-top:.5rem;font-size:.9rem}.add-item-btn:hover{background:var(--bg-hover, #f0f7ff);border-color:var(--primary-color, #4a90d9)}.totals-section{display:flex;flex-direction:column;gap:.5rem;max-width:300px;margin-left:auto}.total-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.total-row span:first-child{color:var(--text-secondary, #666)}.total-row input{width:100px;padding:.4rem .5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;text-align:right;font-size:.9rem}.grand-total{border-top:2px solid var(--border-color, #ddd);padding-top:.75rem;font-weight:700;font-size:1.1rem}.grand-total span{color:var(--text-primary, #333)!important}.review-actions{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #eee)}.back-btn{background:var(--bg-light, #f0f0f0);color:var(--text-primary, #333);border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.95rem}.back-btn:hover{background:var(--border-color, #ddd)}.confirm-btn{background:#28a745;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600}.confirm-btn:hover:not(:disabled){background:#218838}.confirm-btn:disabled{background:#ccc;cursor:not-allowed}.confirm-section{text-align:center;padding:3rem 2rem}.success-icon{font-size:4rem;margin-bottom:1rem}.confirm-section h3{margin:0 0 .5rem;color:#28a745;font-size:1.5rem}.confirm-section p{color:var(--text-secondary, #666);margin:0 0 2rem}.done-btn{background:var(--primary-color, #4a90d9);color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;font-size:1rem}.done-btn:hover{background:var(--primary-hover, #3a7bc8)}@media(max-width:600px){.invoice-scanner-modal{max-height:100vh;border-radius:0}.invoice-details{grid-template-columns:1fr}.items-table{overflow-x:auto}.items-table table{min-width:500px}}@media(prefers-color-scheme:dark){.invoice-scanner-modal{--card-bg: #1e1e1e;--header-bg: #252525;--border-color: #444;--text-primary: #e0e0e0;--text-secondary: #aaa;--bg-light: #2a2a2a;--bg-hover: #333;--input-bg: #2a2a2a}}.expense-list-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:2rem;color:var(--text-primary);margin:0}.filters-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color)}.search-box{margin-bottom:1rem}.search-box input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:1rem}.search-box input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha)}.filter-row{display:flex;gap:1rem;flex-wrap:wrap}.filter-row select{flex:1;min-width:150px;padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:.875rem;cursor:pointer}.filter-row select:focus{outline:none;border-color:var(--primary-color)}.list-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--card-bg);border-radius:8px;margin-bottom:1rem;border:1px solid var(--border-color)}.list-summary span{color:var(--text-secondary)}.list-summary .total-amount{font-weight:600;color:var(--text-primary);font-size:1.125rem}.table-container{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);overflow-x:auto}.expense-table{width:100%;border-collapse:collapse;table-layout:auto}.expense-table th,.expense-table td{padding:1rem 1.5rem;text-align:left;border-bottom:1px solid var(--border-color)}.expense-table th{background:var(--table-header-bg);font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.expense-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.expense-table th.sortable:hover{color:var(--primary-color)}.expense-table tbody tr{transition:background-color .2s}.expense-table tbody tr:hover{background:var(--item-bg-hover)}.expense-table tbody tr:last-child td{border-bottom:none}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.amount-col{text-align:right}.amount-cell{text-align:right;font-weight:600;font-family:Tabular Nums,monospace}.category-badge{display:inline-block;padding:.25rem .75rem;background:var(--badge-bg);color:var(--primary-color);border-radius:20px;font-size:.75rem;font-weight:500}.actions-cell{white-space:nowrap}.btn-icon{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .2s;margin-right:.5rem}.btn-icon.edit{background:var(--edit-btn-bg);color:var(--edit-btn-color)}.btn-icon.edit:hover{background:var(--edit-btn-bg-hover)}.btn-icon.delete{background:var(--delete-btn-bg);color:var(--delete-btn-color)}.btn-icon.delete:hover{background:var(--delete-btn-bg-hover)}.no-results{text-align:center;padding:3rem!important;color:var(--text-secondary)}.btn-primary{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:var(--primary-color-dark);transform:translateY(-1px)}.btn-secondary{padding:.625rem 1rem;background:var(--secondary-btn-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--secondary-btn-bg-hover)}@media(max-width:768px){.expense-list-page{padding:1rem}.page-header{flex-direction:column;gap:1rem;align-items:flex-start}.page-header h1{font-size:1.5rem}.filter-row{flex-direction:column}.filter-row select{width:100%}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.expense-table th,.expense-table td{padding:.75rem .875rem;font-size:.875rem}.description-cell{max-width:130px}.list-summary{flex-direction:column;gap:.5rem;align-items:flex-start}}.income-list-page .page-header h1{color:#22c55e}.btn-income{background:linear-gradient(135deg,#22c55e,#16a34a)!important}.btn-income:hover{background:linear-gradient(135deg,#16a34a,#15803d)!important}.income-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.income-summary-cards .summary-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem}.income-summary-cards .summary-card .label{font-size:.875rem;color:var(--text-secondary)}.income-summary-cards .summary-card .value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.income-summary-cards .income-card .value{color:#22c55e}.income-amount{color:#22c55e!important}.income-badge{background:#22c55e26!important;color:#22c55e!important}.income-table .amount-cell{color:#22c55e;font-weight:600}.income-modal .modal-header h2{color:#22c55e}.header-actions{display:flex;gap:.75rem}.has-items{cursor:pointer}.expand-btn{background:none;border:none;cursor:pointer;padding:.25rem;margin-right:.5rem;font-size:.75rem;color:var(--text-secondary)}.expand-btn:hover{color:var(--primary-color)}.items-badge{margin-left:.5rem;font-size:.75rem;color:var(--text-secondary);background:var(--bg-light, #f0f0f0);padding:.125rem .5rem;border-radius:10px}.line-item-row{background:var(--bg-secondary, #1e1e2e);border-left:3px solid var(--primary-color, #6366f1)}.line-item-row td{padding:.5rem 1.5rem!important;font-size:.9rem;color:var(--text-primary, #e2e8f0)}.line-item-date-cell{text-align:right;padding-right:.5rem!important}.line-item-indent{color:var(--primary-color, #6366f1);font-size:1rem}.line-item-name-cell{display:flex;align-items:center;gap:.5rem}.line-item-text{color:var(--text-primary, #e2e8f0);font-weight:500}.line-item-qty{color:var(--text-secondary, #94a3b8);font-size:.8rem;background:#6366f133;padding:.1rem .4rem;border-radius:4px}.line-item-row .amount-cell{font-weight:500}.category-badge.small{font-size:.7rem;padding:.125rem .375rem}@media(prefers-color-scheme:light){.line-item-row{background:#f1f5f9;border-left:3px solid #6366f1}.line-item-row td{color:#1e293b}.line-item-name{color:#334155}.line-item-indent{color:#6366f1}}.debt-list-page{padding:2rem;max-width:1200px;margin:0 auto}.btn-debt{background:linear-gradient(135deg,#f59e0b,#d97706)!important}.btn-debt:hover{background:linear-gradient(135deg,#d97706,#b45309)!important}.debt-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.debt-summary-cards .summary-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;text-align:center;border:1px solid var(--border-color)}.debt-summary-cards .label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.debt-summary-cards .value{font-size:1.5rem;font-weight:700}.debt-summary-cards .value.positive{color:#22c55e}.debt-summary-cards .value.negative{color:#ef4444}.owed-card{border-left:4px solid #ef4444}.receivable-card{border-left:4px solid #22c55e}.net-card{border-left:4px solid #6366f1}.debt-cards{display:flex;flex-direction:column;gap:1rem}.debt-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);transition:box-shadow .2s}.debt-card:hover{box-shadow:var(--card-shadow-hover)}.debt-card.owed{border-left:4px solid #ef4444}.debt-card.receivable{border-left:4px solid #22c55e}.debt-card.paid{opacity:.7}.debt-header{display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer;gap:1rem}.debt-info{flex:1}.debt-type-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;margin-bottom:.5rem}.debt-type-badge.owed{background:#ef44441a;color:#ef4444}.debt-type-badge.receivable{background:#22c55e1a;color:#22c55e}.debt-person{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.debt-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 .25rem}.debt-due{font-size:.75rem;color:var(--text-secondary)}.debt-amounts{text-align:right}.debt-total{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.debt-remaining{font-size:.875rem;color:var(--text-secondary)}.paid-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;background:#22c55e1a;color:#22c55e;margin-top:.25rem}.debt-progress{display:flex;align-items:center;gap:1rem;margin:1rem 0}.progress-track{flex:1;height:8px;background:var(--progress-track);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;transition:width .5s ease}.progress-text{font-size:.75rem;color:var(--text-secondary);min-width:60px;text-align:right}.debt-actions{display:flex;gap:.5rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-sm{padding:.4rem .75rem;font-size:.75rem;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.btn-payment{background:#22c55e;color:#fff}.btn-payment:hover{background:#16a34a}.btn-edit{background:var(--item-bg);color:var(--text-primary);border:1px solid var(--border-color)}.btn-edit:hover{background:var(--item-bg-hover)}.btn-delete{background:transparent;color:#ef4444;border:1px solid #ef4444}.btn-delete:hover{background:#ef44441a}.btn-expand{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);margin-left:auto}.btn-expand:hover{background:var(--item-bg)}.debt-payments{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.debt-payments h4{font-size:.875rem;color:var(--text-secondary);margin:0 0 .75rem}.payments-table{width:100%;border-collapse:collapse;font-size:.875rem}.payments-table th,.payments-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--border-color)}.payments-table th{color:var(--text-secondary);font-weight:500}.payments-table td{color:var(--text-primary)}.payments-table .btn-icon{padding:.25rem;font-size:.75rem}.payment-modal{max-width:400px}.payment-info{background:var(--item-bg);padding:1rem;border-radius:8px;margin-bottom:1rem}.payment-info p{margin:.25rem 0;font-size:.875rem}@media(max-width:768px){.debt-list-page{padding:1rem}.debt-header{flex-direction:column}.debt-amounts{text-align:left;margin-top:.5rem}.debt-actions{justify-content:flex-start}}.entity-list-page{padding:2rem;max-width:1200px;margin:0 auto}.btn-entity{background:linear-gradient(135deg,#8b5cf6,#7c3aed)!important}.btn-entity:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9)!important}.entity-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.entity-summary-cards .summary-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;text-align:center;border:1px solid var(--border-color)}.entity-summary-cards .label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.entity-summary-cards .value{font-size:1.5rem;font-weight:700}.entity-summary-cards .value.positive{color:#22c55e}.entity-summary-cards .value.negative{color:#ef4444}.entity-cards{display:flex;flex-direction:column;gap:1rem}.entity-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);transition:box-shadow .2s}.entity-card:hover{box-shadow:var(--card-shadow-hover)}.entity-card.person{border-left:4px solid #3b82f6}.entity-card.company{border-left:4px solid #8b5cf6}.entity-card.bank{border-left:4px solid #22c55e}.entity-card.government{border-left:4px solid #f59e0b}.entity-card.other{border-left:4px solid #6b7280}.entity-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer}.entity-icon{font-size:2rem;line-height:1}.entity-info{flex:1}.entity-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.entity-type-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;background:var(--item-bg);color:var(--text-secondary);margin-right:.5rem}.entity-email,.entity-phone{display:block;font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.entity-stats{text-align:right}.entity-stats .stat{margin-bottom:.25rem}.entity-stats .stat-label{display:block;font-size:.75rem;color:var(--text-secondary)}.entity-stats .stat-value{font-size:1.125rem;font-weight:600}.entity-stats .stat.owed .stat-value{color:#ef4444}.entity-stats .stat.receivable .stat-value{color:#22c55e}.entity-stats .stat.neutral .stat-label{color:var(--text-secondary)}.entity-actions{display:flex;gap:.5rem;flex-wrap:wrap;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--border-color)}.entity-details{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.entity-notes{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;padding:.75rem;background:var(--item-bg);border-radius:8px}.entity-debts h4{font-size:.875rem;color:var(--text-secondary);margin:0 0 .75rem}.mini-table{width:100%;border-collapse:collapse;font-size:.875rem}.mini-table th,.mini-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--border-color)}.mini-table th{color:var(--text-secondary);font-weight:500}.mini-table td{color:var(--text-primary)}.type-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .4rem;border-radius:4px}.type-badge.owed{background:#ef44441a;color:#ef4444}.type-badge.receivable{background:#22c55e1a;color:#22c55e}.status-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .4rem;border-radius:4px}.status-badge.paid{background:#22c55e1a;color:#22c55e}.status-badge.active{background:#f59e0b1a;color:#f59e0b}.no-debts{font-size:.875rem;color:var(--text-secondary);font-style:italic}@media(max-width:768px){.entity-list-page{padding:1rem}.entity-header{flex-direction:column}.entity-stats{text-align:left;margin-top:.5rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.budget-form-modal{background:var(--card-bg);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.btn-close{background:transparent;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1;transition:color .2s}.btn-close:hover{color:var(--text-primary)}.budget-form-modal form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical;min-height:80px}.form-hint{display:block;margin-top:.375rem;font-size:.75rem;color:var(--text-tertiary, #9ca3af);font-style:italic}.form-error{display:block;margin-top:.375rem;font-size:.75rem;color:#ef4444;font-weight:500}.form-group.has-error input,.form-group.has-error select{border-color:#ef4444}.form-group.has-error input:focus,.form-group.has-error select:focus{border-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.btn-cancel{background:transparent;border:1px solid var(--border-color);border-radius:8px;padding:.75rem 1.5rem;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--item-bg-hover);color:var(--text-primary)}.btn-submit{background:#3b82f6;border:none;border-radius:8px;padding:.75rem 1.5rem;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit:hover{background:#2563eb}@media(max-width:500px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%;text-align:center}}.budget-list{padding:2rem;max-width:1400px;margin:0 auto}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.budget-header h1{margin:0;color:var(--text-primary);font-size:2rem}.btn-add{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-add:hover{background:#2563eb;transform:translateY(-1px)}.budget-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);box-shadow:var(--card-shadow)}.summary-card h3{margin:0 0 .5rem;font-size:1rem;color:var(--text-secondary)}.summary-count{font-size:.875rem;color:var(--text-secondary);margin:0 0 .75rem}.summary-amounts{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.summary-amounts .budgeted{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.summary-amounts .spent{font-size:.875rem;color:var(--text-secondary)}.summary-progress{height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.summary-progress .progress-fill{height:100%;background:#22c55e;transition:width .3s}.summary-progress .progress-fill.exceeded{background:#ef4444}.budget-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.budget-filters select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:150px}.budget-filters select:focus{outline:none;border-color:#3b82f6}.group-toggle{display:flex;align-items:center;gap:.5rem;margin-left:auto}.group-label{font-size:.875rem;color:var(--text-secondary)}.group-btn{padding:.4rem .75rem;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s}.group-btn:first-of-type{border-radius:6px 0 0 6px}.group-btn:last-of-type{border-radius:0 6px 6px 0;border-left:none}.group-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.group-btn:hover:not(.active){background:var(--item-bg-hover);color:var(--text-primary)}.budget-groups{display:flex;flex-direction:column;gap:2rem}.budget-group{background:var(--card-bg);border-radius:16px;padding:1.5rem;border:1px solid var(--border-color)}.budget-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.budget-group-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.group-count{font-size:.875rem;color:var(--text-secondary);background:var(--item-bg-hover);padding:.25rem .75rem;border-radius:12px}.budget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.budget-grid.ungrouped{background:var(--card-bg);border-radius:16px;padding:1.5rem;border:1px solid var(--border-color)}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem;color:var(--text-secondary);background:var(--card-bg);border-radius:12px;border:2px dashed var(--border-color)}.budget-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform .2s,box-shadow .2s}.budget-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.budget-card.on-track{border-left:4px solid #22c55e}.budget-card.warning{border-left:4px solid #f59e0b}.budget-card.exceeded{border-left:4px solid #ef4444}.budget-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.budget-period{display:flex;flex-direction:column;gap:.25rem}.period-type{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600}.period-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.budget-actions{display:flex;gap:.25rem}.budget-actions button{background:transparent;border:none;cursor:pointer;font-size:.9rem;padding:.35rem;border-radius:6px;transition:all .2s;opacity:.7}.budget-actions button:hover{opacity:1;background:var(--item-bg-hover)}.budget-actions .btn-copy:hover{background:#3b82f626}.budget-actions .btn-edit:hover{background:#f59e0b26}.budget-actions .btn-delete:hover{background:#ef444426}.budget-actions button:hover{background:var(--item-bg-hover)}.budget-category{display:inline-block;background:var(--item-bg-hover);padding:.25rem .75rem;border-radius:20px;font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem}.budget-name{font-weight:600;color:var(--text-primary);margin-bottom:1rem}.budget-amounts{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.amount-row{display:flex;justify-content:space-between;font-size:.9rem}.amount-row .label{color:var(--text-secondary)}.amount-row .value{font-weight:600;color:var(--text-primary)}.amount-row .value.positive{color:#22c55e}.amount-row .value.negative{color:#ef4444}.amount-row.remaining{padding-top:.5rem;border-top:1px solid var(--border-color)}.budget-progress{margin-bottom:.75rem}.progress-bar{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;border-radius:4px;transition:width .3s}.progress-fill.on-track{background:#22c55e}.progress-fill.warning{background:#f59e0b}.progress-fill.exceeded{background:#ef4444}.progress-text{font-size:.8rem;font-weight:600}.progress-text.on-track{color:#22c55e}.progress-text.warning{color:#f59e0b}.progress-text.exceeded{color:#ef4444}.budget-notes{font-size:.8rem;color:var(--text-secondary);font-style:italic;padding-top:.75rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.budget-list{padding:1rem}.budget-header{flex-direction:column;gap:1rem;align-items:stretch}.btn-add{text-align:center}.budget-grid{grid-template-columns:1fr}.budget-filters{flex-direction:column}.budget-filters select{width:100%}}.budget-card-wrapper{display:flex;flex-direction:column}.budget-card-wrapper.is-sub-budget{margin-left:1.5rem;padding-left:1rem;border-left:2px dashed var(--border-color)}.sub-budgets-container{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.budget-card.sub-budget{background:var(--item-bg-hover);border:1px dashed var(--border-color);padding:1.25rem}.budget-card.sub-budget .period-type{font-size:.7rem}.budget-card.sub-budget .period-value{font-size:1rem}.sub-budget-indicator{font-weight:700;color:var(--text-secondary);margin-right:.25rem}.budget-parent-info{font-size:.75rem;color:var(--text-secondary);background:#3b82f61a;padding:.25rem .75rem;border-radius:12px;margin-bottom:.75rem;display:inline-block}.sub-budget-count{font-size:.8rem;color:var(--text-secondary);margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.sub-budget-toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.75rem;margin-top:.75rem;background:var(--item-bg-hover);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .2s}.sub-budget-toggle:hover,.sub-budget-toggle.expanded{background:#3b82f61a;border-color:#3b82f6;color:#3b82f6}.toggle-icon{font-size:.7rem;transition:transform .2s}.toggle-text{flex:1;text-align:left;font-weight:500}.sub-budget-total{font-weight:600;color:var(--text-primary)}.sub-budget-toggle:hover .sub-budget-total,.sub-budget-toggle.expanded .sub-budget-total{color:#3b82f6}.card-collapse-btn{background:transparent;border:none;cursor:pointer;font-size:.65rem;color:var(--text-secondary);padding:.25rem;margin-right:.25rem;border-radius:4px;transition:all .2s}.card-collapse-btn:hover{background:var(--item-bg-hover);color:#3b82f6}.budget-card.collapsed{padding:.75rem 1rem}.budget-card.collapsed .budget-card-header{margin-bottom:0}.collapsed-summary{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.collapsed-name{flex:1;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collapsed-amount{font-weight:600;color:var(--text-primary)}.collapsed-status{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;min-width:3rem;text-align:center}.collapsed-status.on-track{background:#22c55e26;color:#22c55e}.collapsed-status.warning{background:#f59e0b26;color:#f59e0b}.collapsed-status.exceeded{background:#ef444426;color:#ef4444}@media(max-width:768px){.budget-card-wrapper.is-sub-budget{margin-left:.75rem;padding-left:.5rem}}.savings-list{max-width:1200px;margin:0 auto;padding:24px 32px}.savings-header{text-align:center;margin-bottom:30px}.savings-header h1{font-size:2rem;margin-bottom:8px;color:var(--text-primary)}.savings-header p{color:var(--text-secondary);font-size:1.1rem}.savings-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.savings-overview .overview-card{background:var(--card-bg);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.savings-overview .overview-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.savings-overview .card-icon{font-size:2rem}.savings-overview .card-content{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.savings-overview .card-label{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.savings-overview .card-value{font-size:1.1rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.savings-overview .overview-card.total .card-value{color:#22c55e}.savings-overview .overview-card.progress .card-value{color:#3b82f6}.savings-actions{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.action-btn.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.action-btn.deposit{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.action-btn.deposit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.action-btn.withdraw{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color)}.action-btn.withdraw:hover{background:var(--border-color)}.action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.accounts-grid{display:flex;flex-direction:column;gap:16px}.empty-state{background:var(--card-bg);border-radius:16px;padding:60px 40px;text-align:center;border:2px dashed var(--border-color)}.empty-state .empty-icon{font-size:4rem;display:block;margin-bottom:16px}.empty-state h3{margin:0 0 8px;color:var(--text-primary)}.empty-state p{margin:0 0 20px;color:var(--text-secondary)}.account-card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;transition:box-shadow .2s}.account-card:hover{box-shadow:0 4px 12px #0000001a}.account-card.expanded{border-color:var(--accent-color, #3b82f6)}.account-header{display:flex;align-items:center;padding:20px;cursor:pointer;gap:20px}.account-info{flex:1}.account-info h3{margin:0 0 4px;font-size:1.2rem;color:var(--text-primary);display:flex;align-items:center;gap:8px}.primary-badge{font-size:1rem;filter:drop-shadow(0 0 2px rgba(245,158,11,.5))}.account-balance{font-size:1.5rem;font-weight:700;color:var(--accent-color, #22c55e)}.account-target{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:150px}.target-label{font-size:.85rem;color:var(--text-secondary)}.progress-bar{width:150px;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-color, #22c55e);border-radius:4px;transition:width .3s}.progress-percent{font-size:.9rem;font-weight:600;color:var(--accent-color, #22c55e)}.expand-icon{font-size:.8rem;color:var(--text-secondary)}.account-details{padding:0 20px 20px;border-top:1px solid var(--border-color)}.account-actions{display:flex;gap:10px;padding:16px 0;flex-wrap:wrap}.account-actions button{padding:8px 16px;border-radius:8px;border:1px solid var(--border-color);background:var(--item-bg);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s}.account-actions button:hover{background:var(--border-color)}.account-actions button.danger{border-color:#ef44444d;color:#ef4444}.account-actions button.danger:hover{background:#ef44441a}.account-actions button:disabled{opacity:.5;cursor:not-allowed}.deposits-list h4{margin:0 0 12px;font-size:1rem;color:var(--text-primary)}.no-deposits{color:var(--text-secondary);font-style:italic}.deposits-table{display:flex;flex-direction:column;gap:4px}.deposit-row{display:flex;align-items:center;gap:16px;padding:10px 12px;background:var(--item-bg);border-radius:8px}.dep-date{font-size:.85rem;color:var(--text-secondary);min-width:90px}.dep-desc{flex:1;font-size:.9rem;color:var(--text-primary)}.dep-amount{font-weight:600;font-size:.95rem}.dep-amount.positive{color:#22c55e}.dep-amount.negative{color:#ef4444}.dep-delete{width:24px;height:24px;border:none;background:transparent;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.dep-delete:hover{background:#ef44441a;color:#ef4444}.more-deposits{text-align:center;font-size:.85rem;color:var(--text-secondary);margin:8px 0 0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--card-bg);border-radius:16px;padding:24px;width:100%;max-width:450px;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 24px;font-size:1.5rem;color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:10px;background:var(--item-bg);color:var(--text-primary);font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.helper-text{display:block;margin-top:6px;font-size:.85rem;color:var(--text-secondary)}.color-picker{display:flex;gap:10px}.color-option{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--text-primary)}.form-actions{display:flex;gap:12px;margin-top:24px}.btn-cancel{flex:1;padding:12px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);border-radius:10px;font-size:1rem;cursor:pointer}.btn-cancel:hover{background:var(--item-bg)}.btn-submit{flex:1;padding:12px;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-submit.withdraw{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-submit.withdraw:hover{box-shadow:0 4px 12px #f59e0b66}@media(max-width:768px){.savings-list{padding:16px}.savings-header h1{font-size:1.5rem}.savings-overview{grid-template-columns:repeat(2,1fr)}.account-header{flex-wrap:wrap}.account-target{width:100%;align-items:flex-start;margin-top:12px}.progress-bar{width:100%}.deposit-row{flex-wrap:wrap}.dep-date{min-width:auto}}.reports-page{padding:2rem;max-width:1400px;margin:0 auto}.reports-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.reports-header h1{margin:0;color:var(--text-primary)}.view-tabs{display:flex;gap:.5rem;background:var(--card-bg);padding:.5rem;border-radius:12px;width:fit-content}.view-tabs button{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.view-tabs button:hover{color:var(--text-primary);background:var(--item-bg-hover)}.view-tabs button.active{background:var(--primary-color);color:#fff}.period-selector{display:flex;align-items:center;gap:1rem}.period-selector button{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .2s}.period-selector button:hover:not(:disabled){background:var(--item-bg-hover);border-color:var(--primary-color)}.period-selector button:disabled{opacity:.5;cursor:not-allowed}.current-period{font-size:1.25rem;font-weight:600;color:var(--text-primary);min-width:200px;text-align:center}.report-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.report-card{padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.report-card h3{margin:0 0 .5rem;font-size:.875rem;color:var(--text-secondary);font-weight:500}.report-card .amount{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.report-card .amount.positive{color:#22c55e}.report-card .amount.negative{color:#ef4444}.report-card .change{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}.report-card .change.positive{color:#22c55e}.report-card .change.negative{color:#ef4444}.report-card .vs-text{color:var(--text-secondary);font-weight:400}.report-card .count{font-size:.875rem;color:var(--text-secondary)}.report-card.expenses{border-left:4px solid #ef4444}.report-card.income{border-left:4px solid #22c55e}.report-card.savings{border-left:4px solid #8b5cf6}.report-card.rate{border-left:4px solid #0ea5e9}.comparison-section{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;margin-bottom:2rem}.comparison-section h2{margin:0 0 1.5rem;font-size:1.125rem;color:var(--text-primary)}.comparison-grid{display:flex;flex-direction:column;gap:.75rem}.comparison-header,.comparison-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:1rem;padding:.75rem 1rem;align-items:center}.comparison-header{background:var(--item-bg);border-radius:8px;font-weight:600;font-size:.875rem;color:var(--text-secondary)}.comparison-row{border-bottom:1px solid var(--border-color)}.comparison-row:last-child{border-bottom:none}.row-label{font-weight:500;color:var(--text-primary)}.comparison-row .positive{color:#22c55e;font-weight:500}.comparison-row .negative{color:#ef4444;font-weight:500}.trend-section{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;margin-bottom:2rem}.trend-section h2{margin:0 0 1.5rem;font-size:1.125rem;color:var(--text-primary)}.trend-chart{display:flex;justify-content:space-around;align-items:flex-end;height:200px;padding:1rem 0;gap:.5rem}.trend-bar-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.bars{display:flex;gap:4px;align-items:flex-end;height:180px}.bar{width:24px;border-radius:4px 4px 0 0;transition:height .3s ease;cursor:pointer}.bar:hover{opacity:.8}.expense-bar{background:linear-gradient(to top,#ef4444,#f87171)}.income-bar{background:linear-gradient(to top,#22c55e,#4ade80)}.trend-label{font-size:.75rem;color:var(--text-secondary);text-align:center}.trend-legend{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.legend-color{width:12px;height:12px;border-radius:3px}.legend-color.expense{background:#ef4444}.legend-color.income{background:#22c55e}.category-breakdown-section{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;margin-bottom:2rem}.category-breakdown-section h2{margin:0 0 1.5rem;font-size:1.125rem;color:var(--text-primary)}.category-breakdown{display:flex;flex-direction:column;gap:1rem}.category-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.category-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.category-name{font-weight:500;color:var(--text-primary)}.category-bar-track{height:8px;background:var(--item-bg);border-radius:4px;overflow:hidden}.category-bar-fill{height:100%;background:linear-gradient(to right,var(--primary-color),#8b5cf6);border-radius:4px;transition:width .3s ease}.category-values{display:flex;gap:1rem;align-items:center}.category-amount{font-weight:600;color:var(--text-primary);min-width:100px;text-align:right}.category-percent{color:var(--text-secondary);font-size:.875rem;min-width:50px}.category-change{font-size:.75rem;font-weight:500;min-width:50px}.category-change.positive{color:#22c55e}.category-change.negative{color:#ef4444}.budget-performance-section{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem;margin-bottom:1.5rem}.budget-performance-section h2{margin:0 0 1.5rem;font-size:1.125rem;color:var(--text-primary)}.budget-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.budget-summary-card{padding:1rem;background:var(--item-bg);border-radius:8px;text-align:center}.budget-summary-card h4{margin:0 0 .5rem;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.budget-summary-card p{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.budget-summary-card p.positive{color:#22c55e}.budget-summary-card p.negative{color:#ef4444}.budget-summary-card.status-card{display:flex;align-items:center;justify-content:center}.status-counts{display:flex;gap:1rem}.status-count{font-size:.875rem;font-weight:600}.status-count.on-track{color:#22c55e}.status-count.warning{color:#f59e0b}.status-count.exceeded{color:#ef4444}.budget-progress-list{display:flex;flex-direction:column;gap:1rem}.budget-progress-item{padding:1rem;background:var(--item-bg);border-radius:8px;border-left:4px solid #22c55e}.budget-progress-item.warning{border-left-color:#f59e0b}.budget-progress-item.exceeded{border-left-color:#ef4444}.budget-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.budget-name{font-weight:600;color:var(--text-primary)}.budget-category{font-size:.75rem;color:var(--text-secondary);background:var(--item-bg-hover);padding:.25rem .5rem;border-radius:4px}.budget-progress-bar-container{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.budget-progress-bar{flex:1;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.budget-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.budget-progress-fill.on-track{background:#22c55e}.budget-progress-fill.warning{background:#f59e0b}.budget-progress-fill.exceeded{background:#ef4444}.budget-percentage{font-size:.875rem;font-weight:600;min-width:3rem;text-align:right;color:var(--text-primary)}.budget-progress-values{display:flex;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.budget-progress-values .spent{color:var(--text-primary)}.budget-progress-values .of{color:var(--text-secondary)}.budget-progress-values .budgeted{color:var(--text-primary)}.budget-progress-values .remaining{margin-left:auto}.budget-progress-values .remaining.negative{color:#ef4444}.sub-budget-progress-list{margin-top:1rem;padding-top:.75rem;border-top:1px dashed var(--border-color);display:flex;flex-direction:column;gap:.5rem}.sub-budget-progress-item{padding:.5rem .75rem;background:var(--card-bg);border-radius:6px;border-left:3px solid #22c55e}.sub-budget-progress-item.warning{border-left-color:#f59e0b}.sub-budget-progress-item.exceeded{border-left-color:#ef4444}.sub-budget-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.sub-budget-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.sub-budget-category{font-size:.7rem;color:var(--text-secondary)}.sub-budget-bar-container{display:flex;align-items:center;gap:.5rem}.sub-budget-bar{flex:1;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.sub-budget-fill{height:100%;border-radius:3px}.sub-budget-fill.on-track{background:#22c55e}.sub-budget-fill.warning{background:#f59e0b}.sub-budget-fill.exceeded{background:#ef4444}.sub-budget-values{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.debt-summary-report{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:1.5rem}.debt-summary-report h2{margin:0 0 1.5rem;font-size:1.125rem;color:var(--text-primary)}.debt-report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.debt-report-card{padding:1rem;background:var(--item-bg);border-radius:8px;text-align:center}.debt-report-card h4{margin:0 0 .5rem;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.debt-report-card p{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.debt-report-card p.positive{color:#22c55e}.debt-report-card p.negative{color:#ef4444}@media(max-width:768px){.reports-page{padding:1rem}.view-tabs{width:100%;justify-content:space-between}.view-tabs button{padding:.5rem 1rem;flex:1}.period-selector{flex-wrap:wrap;justify-content:center}.current-period{width:100%;order:-1}.comparison-header,.comparison-row{grid-template-columns:1fr 1fr;gap:.5rem}.comparison-header span:nth-child(1),.comparison-header span:nth-child(4),.comparison-row span:nth-child(3),.comparison-row span:nth-child(4){display:none}.bar{width:16px}}.advisor-page{max-width:1200px;margin:0 auto;padding:20px}.advisor-header{text-align:center;margin-bottom:30px}.advisor-header h1{font-size:2rem;margin-bottom:8px;color:var(--text-primary)}.advisor-subtitle{color:var(--text-secondary);font-size:1.1rem}.date-range-filter{display:flex;align-items:center;justify-content:center;gap:15px;margin-top:20px;padding:15px;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color)}.date-range-filter label{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:.9rem;color:var(--text-secondary);font-weight:500}.date-range-filter input[type=date]{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.9rem;min-width:140px}.date-range-filter input[type=date]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.period-info{font-size:.9rem;color:var(--text-secondary);font-weight:500;padding:8px 12px;background:var(--bg-secondary);border-radius:6px}.help-tip-container{position:relative;display:inline-flex}.help-tip-container:hover{z-index:9999}.help-tip-btn{width:20px;height:20px;border-radius:50%;background:var(--border-color);color:var(--text-secondary);border:none;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.help-tip-btn:hover{background:#3b82f6;color:#fff}.help-tip-popup{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;font-size:.85rem;color:var(--text-secondary);width:280px;z-index:9999;box-shadow:0 4px 12px #00000026;line-height:1.5;pointer-events:none}.help-tip-popup:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid var(--border-color)}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.section-header h2{margin-bottom:0}.health-score-section{position:relative;display:flex;align-items:center;gap:40px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:30px;margin-bottom:30px}.health-score-section>.help-tip-container{position:absolute;top:16px;right:16px}.score-circle{position:relative;width:160px;height:160px;flex-shrink:0}.score-circle svg{transform:rotate(-90deg);width:100%;height:100%}.score-bg{fill:none;stroke:var(--border-color);stroke-width:8}.score-progress{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dasharray .5s ease}.score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score-number{display:block;font-size:2.5rem;font-weight:700;color:var(--text-primary)}.score-label{font-size:.9rem;font-weight:600;text-transform:uppercase}.score-details h2{font-size:1.5rem;margin-bottom:8px;color:var(--text-primary)}.score-details>p{color:var(--text-secondary);margin-bottom:20px}.score-factors{display:flex;gap:30px}.factor{display:flex;flex-direction:column;gap:4px}.factor-label{font-size:.85rem;color:var(--text-secondary)}.factor .positive{color:#22c55e;font-weight:600}.factor .negative{color:#ef4444;font-weight:600}.advice-section{margin-bottom:30px}.advice-section h2{font-size:1.3rem;margin-bottom:16px;color:var(--text-primary)}.advice-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px}.advice-card{display:flex;gap:16px;padding:16px;border-radius:12px;background:var(--card-bg);border:1px solid var(--border-color)}.advice-card.warning{border-left:4px solid #f59e0b;background:#f59e0b0d}.advice-card.achievement{border-left:4px solid #22c55e;background:#22c55e0d}.advice-card.tip{border-left:4px solid #3b82f6;background:#3b82f60d}.advice-icon{font-size:1.5rem;flex-shrink:0}.advice-content h3{font-size:1rem;margin-bottom:6px;color:var(--text-primary)}.advice-content p{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.action-items-section{margin-bottom:30px}.action-items-section h2{font-size:1.3rem;margin-bottom:16px;color:var(--text-primary)}.action-list{display:flex;flex-direction:column;gap:12px}.action-item{display:flex;gap:16px;padding:16px;border-radius:12px;background:var(--card-bg);border:1px solid var(--border-color)}.action-item.priority-high{border-left:4px solid #ef4444}.action-item.priority-medium{border-left:4px solid #f59e0b}.action-item.priority-low{border-left:4px solid #22c55e}.action-priority{font-size:1.2rem;flex-shrink:0}.action-content h4{font-size:1rem;margin-bottom:4px;color:var(--text-primary)}.action-content p{font-size:.85rem;color:var(--text-secondary)}.quick-stats-section{margin-bottom:30px}.quick-stats-section h2{font-size:1.3rem;margin-bottom:16px;color:var(--text-primary)}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:16px;text-align:center}.stat-label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.stat-value{display:block;font-size:1.3rem;font-weight:600;color:var(--text-primary)}.stat-value.positive{color:#22c55e}.stat-value.negative{color:#ef4444}.top-spending-section{margin-bottom:30px}.top-spending-section h2{font-size:1.3rem;margin-bottom:16px;color:var(--text-primary)}.spending-breakdown{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px}.spending-item{margin-bottom:16px}.spending-item:last-child{margin-bottom:0}.spending-header{display:flex;justify-content:space-between;margin-bottom:8px}.spending-category{font-weight:500;color:var(--text-primary)}.spending-amount{color:var(--text-secondary);font-size:.9rem}.spending-bar{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:4px}.spending-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:4px;transition:width .3s ease}.spending-percent{font-size:.8rem;color:var(--text-secondary)}@media(max-width:768px){.health-score-section{flex-direction:column;text-align:center;gap:20px;padding:20px}.score-factors{justify-content:center;flex-wrap:wrap;gap:20px}.advice-cards{grid-template-columns:1fr}.quick-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.advisor-header h1{font-size:1.5rem}.score-circle{width:140px;height:140px}.score-number{font-size:2rem}.quick-stats,.cost-tips-grid{grid-template-columns:1fr}.help-tip-popup{left:auto;right:0;transform:none}.help-tip-popup:before{left:auto;right:10px;transform:none}}.cost-reduction-section{margin-bottom:30px}.cost-reduction-section h2{font-size:1.3rem;color:var(--text-primary)}.savings-potential{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.3);border-radius:12px;padding:16px 20px;margin-bottom:20px}.savings-potential span{color:var(--text-secondary);font-size:1rem}.savings-potential strong{font-size:1.5rem;color:#22c55e}.cost-tips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.cost-tip-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.cost-tip-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.cost-tip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cost-tip-header h3{font-size:1.1rem;color:var(--text-primary);margin:0}.cost-tip-amount{font-size:1rem;font-weight:600;color:var(--text-primary)}.cost-tip-meta{display:flex;gap:12px;font-size:.85rem;color:var(--text-secondary);margin-bottom:16px}.cost-tip-meta .positive{color:#22c55e}.cost-tip-meta .negative{color:#ef4444}.cost-suggestions{list-style:none;padding:0;margin:0 0 16px}.cost-suggestions li{padding:8px 0;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);line-height:1.4}.cost-suggestions li:last-child{border-bottom:none}.potential-saving{display:flex;justify-content:space-between;align-items:center;background:#22c55e14;border-radius:8px;padding:10px 12px;margin-top:12px}.potential-saving span{font-size:.85rem;color:var(--text-secondary)}.potential-saving strong{color:#22c55e;font-size:1rem}.cost-tip-card.fixed-expense{border-color:#6b7280;background:var(--item-bg)}.cost-tip-card.fixed-expense:hover{transform:none;box-shadow:none}.fixed-badge{background:#6b7280;color:#fff;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase}.fixed-expense-note{display:flex;align-items:center;background:#6b72801a;border-radius:8px;padding:10px 12px;margin-top:12px}.fixed-expense-note span{font-size:.85rem;color:var(--text-secondary)}.expense-planner{max-width:1200px;margin:0 auto;padding:20px}.planner-header{text-align:center;margin-bottom:30px}.planner-header h1{font-size:2rem;margin-bottom:8px;color:var(--text-primary)}.planner-header p{color:var(--text-secondary);font-size:1.1rem}.spending-overview{background:var(--card-bg);border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid var(--border-color)}.spending-overview h2{margin:0 0 20px;font-size:1.25rem;color:var(--text-primary)}.overview-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.overview-card{background:var(--item-bg);border-radius:12px;padding:16px;text-align:center}.overview-card.highlight{background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border:1px solid rgba(59,130,246,.3)}.card-label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.card-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.card-value.positive{color:#22c55e}.card-value.negative{color:#ef4444}.category-selection{background:var(--card-bg);border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid var(--border-color)}.category-selection h2{margin:0 0 8px;font-size:1.25rem;color:var(--text-primary)}.category-selection p{margin:0 0 16px;color:var(--text-secondary);font-size:.9rem}.category-chips{display:flex;flex-wrap:wrap;gap:10px}.category-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:12px;border:2px solid var(--border-color);background:var(--item-bg);cursor:pointer;transition:all .2s;min-width:120px}.category-chip:hover{border-color:#3b82f6;background:#3b82f60d}.category-chip.selected{border-color:#3b82f6;background:#3b82f61a}.chip-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.chip-amount{font-size:.8rem;color:var(--text-secondary)}.reduction-target{background:var(--card-bg);border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid var(--border-color)}.reduction-target h2{margin:0 0 20px;font-size:1.25rem;color:var(--text-primary)}.target-slider{display:flex;flex-direction:column;gap:16px}.target-slider input[type=range]{width:100%;height:8px;-webkit-appearance:none;background:var(--border-color);border-radius:4px;outline:none}.target-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:#3b82f6;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #3b82f666}.target-display{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}.target-percentage{font-size:2.5rem;font-weight:700;color:#3b82f6}.target-amount{font-size:1.25rem;font-weight:600;color:#22c55e}.target-yearly{font-size:1rem;color:var(--text-secondary)}.reduction-plan{background:var(--card-bg);border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid var(--border-color)}.reduction-plan h2{margin:0 0 20px;font-size:1.25rem;color:var(--text-primary)}.no-plan{text-align:center;color:var(--text-secondary);padding:40px}.plan-cards{display:grid;gap:20px}.plan-card{background:var(--item-bg);border-radius:12px;padding:20px;border:1px solid var(--border-color)}.plan-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:12px}.plan-card-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.plan-targets{display:flex;align-items:center;gap:8px;font-size:.9rem}.plan-targets .current,.plan-targets .arrow{color:var(--text-secondary)}.plan-targets .target{color:#22c55e;font-weight:600}.plan-savings{display:flex;align-items:center;gap:12px;margin-bottom:16px}.save-badge{background:#22c55e1a;color:#22c55e;padding:6px 12px;border-radius:20px;font-weight:600;font-size:.9rem}.reduction-pct{color:var(--text-secondary);font-size:.85rem}.strategies-list{border-top:1px solid var(--border-color);padding-top:16px}.strategies-list h4{margin:0 0 12px;font-size:.9rem;color:var(--text-primary)}.strategy-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-color)}.strategy-item:last-child{border-bottom:none}.strategy-action{flex:1;font-size:.9rem;color:var(--text-primary)}.strategy-savings{font-size:.85rem;color:#22c55e;font-weight:500}.difficulty-badge{font-size:.7rem;padding:3px 8px;border-radius:10px;text-transform:uppercase;font-weight:600}.difficulty-badge.easy{background:#22c55e1a;color:#22c55e}.difficulty-badge.medium{background:#f59e0b1a;color:#f59e0b}.difficulty-badge.hard{background:#ef44441a;color:#ef4444}.ai-section{background:linear-gradient(135deg,var(--card-bg),rgba(59,130,246,.05));border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid rgba(59,130,246,.2)}.ai-section h2{margin:0 0 8px;font-size:1.25rem;color:var(--text-primary)}.ai-section>p{margin:0 0 16px;color:var(--text-secondary);font-size:.9rem}.api-key-notice{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:12px;padding:16px;margin-bottom:20px}.api-key-notice h4{margin:0 0 12px;color:#f59e0b;font-size:1rem}.api-key-notice p{margin:0 0 12px;color:var(--text-secondary);font-size:.9rem}.api-key-notice ol{margin:0;padding-left:20px;color:var(--text-secondary);font-size:.9rem;line-height:1.8}.api-key-notice a{color:#3b82f6;text-decoration:none}.api-key-notice a:hover{text-decoration:underline}.api-key-notice code{background:var(--item-bg);padding:2px 6px;border-radius:4px;font-size:.85rem}.ai-how-to{background:#3b82f61a;border-radius:12px;padding:16px;margin-bottom:20px}.ai-how-to h4{margin:0 0 12px;color:var(--text-primary);font-size:.95rem}.ai-how-to ol{margin:0;padding-left:20px;color:var(--text-secondary);font-size:.9rem;line-height:1.8}.ai-how-to kbd{background:var(--item-bg);border:1px solid var(--border-color);border-radius:4px;padding:2px 6px;font-size:.8rem;font-family:monospace}.ai-prompt-area{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.ai-prompt-area textarea{width:100%;padding:14px;border:1px solid var(--border-color);border-radius:12px;background:var(--item-bg);color:var(--text-primary);font-size:.95rem;resize:vertical;font-family:inherit}.ai-prompt-area textarea:focus{outline:none;border-color:#3b82f6}.ai-buttons{display:flex;gap:12px;flex-wrap:wrap}.ai-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.ai-button.primary{flex:1;min-width:200px}.ai-button.secondary{background:var(--item-bg);color:var(--text-primary);border:1px solid var(--border-color)}.ai-button.secondary:hover{background:var(--border-color);transform:none;box-shadow:none}.ai-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.ai-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.ai-response{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:12px;padding:16px;margin-bottom:16px}.ai-response.warning{background:#f59e0b1a;border-color:#f59e0b4d}.ai-response p{margin:0;color:#22c55e;font-size:.95rem}.ai-response.warning p{color:#f59e0b}.ai-plan-result{background:var(--card-bg);border:2px solid rgba(59,130,246,.3);border-radius:16px;padding:24px;margin-bottom:20px}.ai-plan-result h3{margin:0 0 20px;font-size:1.2rem;color:var(--text-primary);display:flex;align-items:center;gap:8px}.ai-plan-content{color:var(--text-primary);line-height:1.8}.ai-plan-content h4{margin:20px 0 12px;font-size:1.1rem;color:#3b82f6;border-bottom:1px solid var(--border-color);padding-bottom:8px}.ai-plan-content h4:first-child{margin-top:0}.ai-plan-content p{margin:0 0 12px;font-size:.95rem}.ai-plan-content li{margin:8px 0;padding-left:8px;font-size:.95rem;list-style-position:inside}.ai-plan-content li.numbered{list-style-type:decimal}.ai-plan-content li:not(.numbered){list-style-type:disc}.toggle-context-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:10px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;margin-bottom:16px}.toggle-context-btn:hover{background:var(--item-bg);color:var(--text-primary)}.context-preview{background:var(--item-bg);border-radius:12px;padding:16px;margin-bottom:16px;max-height:400px;overflow-y:auto}.context-preview pre{margin:0;white-space:pre-wrap;font-size:.85rem;color:var(--text-primary);font-family:Monaco,Menlo,monospace}.ai-suggestions{margin-top:20px}.ai-suggestions h4{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary)}.suggestion-chips{display:flex;flex-wrap:wrap;gap:10px}.suggestion-chips button{padding:10px 16px;background:var(--item-bg);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s}.suggestion-chips button:hover{background:#3b82f61a;border-color:#3b82f6}.plan-summary{background:var(--card-bg);border-radius:16px;padding:24px;border:1px solid var(--border-color)}.plan-summary h2{margin:0 0 20px;font-size:1.25rem;color:var(--text-primary)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.summary-item{background:var(--item-bg);border-radius:12px;padding:16px;text-align:center}.summary-label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.summary-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.summary-value.positive{color:#22c55e}@media(max-width:768px){.expense-planner{padding:16px}.planner-header h1{font-size:1.5rem}.target-percentage{font-size:2rem}.plan-card-header{flex-direction:column}.strategy-item{flex-wrap:wrap}.strategy-savings{margin-left:auto}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;background:var(--bg-primary)}
