.sidebar{background:var(--bg-sidebar);z-index:200;flex-direction:column;width:240px;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:24px 20px 20px}.sidebar-brand h1{color:#fff;letter-spacing:-.3px;font-size:18px;font-weight:700}.sidebar-brand p{color:#64748b;margin-top:2px;font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.nav-label{text-transform:uppercase;letter-spacing:1.2px;color:#475569;padding:12px 8px 6px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:#94a3b8;font-size:14px;font-weight:500;font-family:var(--font);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--bg-sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--accent);color:#fff}.nav-icon{text-align:center;width:22px;font-size:18px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-footer p{color:#475569;font-size:11px}@media (width<=768px){.sidebar{display:none}}.summary-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.summary-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px 22px;transition:box-shadow .2s;display:flex}.summary-card:hover{box-shadow:var(--shadow-md)}.card-top{justify-content:space-between;align-items:center;display:flex}.card-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.card-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.card-icon.balance{background:var(--accent-light)}.card-icon.income{background:var(--green-light)}.card-icon.expense{background:var(--red-light)}.card-amount{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:700}.card-amount.income-color{color:var(--green)}.card-amount.expense-color{color:var(--red)}.card-footer{color:var(--text-muted);border-top:1px solid var(--border);padding-top:4px;font-size:12px}@media (width<=900px){.summary-grid{grid-template-columns:1fr 1fr}}@media (width<=540px){.summary-grid{grid-template-columns:1fr}}.chart-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:20px 20px 12px}.chart-title{color:var(--text-primary);margin-bottom:2px;font-size:15px;font-weight:700}.chart-sub{color:var(--text-muted);margin-bottom:16px;font-size:12px}.chart-tooltip{color:#fff;background:#0f172a;border-radius:8px;padding:10px 14px;font-size:13px}.tooltip-label{color:#94a3b8;margin-bottom:4px;font-size:12px}.tooltip-value{font-size:14px;font-weight:700}.transactions-wrapper{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.filter-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:16px 20px;display:flex}.search-input,.filter-select{font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-main);color:var(--text-primary);outline:none;padding:8px 12px;font-size:13px;transition:border-color .15s}.search-input:focus,.filter-select:focus{border-color:var(--accent)}.search-input{flex:1;min-width:160px}.add-btn{font-family:var(--font);background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;margin-left:auto;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.add-btn:hover{background:var(--accent-dark)}.table-wrapper{overflow-x:auto}.transaction-table{border-collapse:collapse;width:100%;min-width:560px}.transaction-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:#f8fafc;padding:10px 20px;font-size:11px;font-weight:700}.transaction-table thead th:hover{color:var(--text-secondary)}.transaction-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .1s}.transaction-table tbody tr:hover{background:#f8fafc}.transaction-table tbody tr:last-child{border-bottom:none}.transaction-table td{color:var(--text-primary);padding:13px 20px;font-size:13px}.t-desc{font-weight:600}.t-date{color:var(--text-muted);font-size:12px}.t-amount-income{color:var(--green);font-weight:700}.t-amount-expense{color:var(--red);font-weight:700}.delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:color .15s}.delete-btn:hover{color:var(--red)}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px;font-size:15px}.table-footer{color:var(--text-muted);border-top:1px solid var(--border);background:#f8fafc;padding:10px 20px;font-size:12px}.modal-overlay{z-index:999;background:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:440px;padding:28px;box-shadow:0 20px 60px #0003}.modal-box h3{color:var(--text-primary);margin-bottom:20px;font-size:17px;font-weight:700}.form-row{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-row label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.form-input{font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);background:#fff;outline:none;padding:9px 12px;font-size:14px;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.btn-cancel{font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);background:0 0;padding:8px 16px;font-size:13px}.btn-save{font-family:var(--font);background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 20px;font-size:13px;font-weight:600;transition:background .15s}.btn-save:hover{background:var(--accent-dark)}@media (width<=600px){.filter-bar{flex-direction:column}.add-btn{width:100%;margin-left:0}}.insights-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.insight-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:22px;transition:box-shadow .2s}.insight-card:hover{box-shadow:var(--shadow-md)}.insight-card.full-width{grid-column:1/-1}.insight-card-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.insight-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.insight-icon.purple{background:#e0e7ff}.insight-icon.green{background:var(--green-light)}.insight-icon.amber{background:var(--yellow-light)}.insight-icon.red{background:var(--red-light)}.insight-card-header h3{color:var(--text-primary);font-size:14px;font-weight:700}.insight-card-header p{color:var(--text-muted);margin-top:1px;font-size:12px}.top-category-name{color:var(--text-primary);margin-bottom:4px;font-size:22px;font-weight:700}.top-category-amount{color:var(--red);margin-bottom:14px;font-size:14px;font-weight:600}.category-bar-bg{background:#f1f5f9;border-radius:99px;height:8px;overflow:hidden}.category-bar-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .5s}.category-bar-label{color:var(--text-muted);justify-content:space-between;margin-top:6px;font-size:12px;display:flex}.savings-rate-value{color:var(--green);margin-bottom:6px;font-size:36px;font-weight:700;line-height:1.1}.savings-rate-sub{color:var(--text-muted);margin-bottom:14px;font-size:12px}.savings-bar-bg{background:#f1f5f9;border-radius:99px;height:10px;overflow:hidden}.savings-bar-fill{background:var(--green);border-radius:99px;height:100%;transition:width .6s}.category-table{border-collapse:collapse;width:100%}.category-table th{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:8px 0;font-size:11px;font-weight:700}.category-table td{color:var(--text-primary);border-bottom:1px solid #f8fafc;padding:10px 0;font-size:13px}.category-table tr:last-child td{border-bottom:none}.cat-dot{border-radius:50%;width:10px;height:10px;margin-right:8px;display:inline-block}.cat-amount{color:var(--red);text-align:right;font-weight:600}.cat-percent{text-align:right;color:var(--text-muted);font-size:12px}@media (width<=768px){.insights-grid{grid-template-columns:1fr}.insight-card.full-width{grid-column:auto}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-main:#f0f2f8;--bg-card:#fff;--bg-sidebar:#0f172a;--bg-sidebar-hover:#1e293b;--accent:#6366f1;--accent-light:#e0e7ff;--accent-dark:#4338ca;--green:#22c55e;--green-light:#dcfce7;--red:#ef4444;--red-light:#fee2e2;--yellow:#f59e0b;--yellow-light:#fef3c7;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--shadow-sm:0 1px 3px #00000012;--shadow-md:0 4px 16px #00000014;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--font:"Plus Jakarta Sans", sans-serif}body{font-family:var(--font);background:var(--bg-main);color:var(--text-primary);font-size:14px;line-height:1.6}.app-layout{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;display:flex}.top-header{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;height:64px;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.top-header h2{color:var(--text-primary);font-size:18px;font-weight:700}.header-right{align-items:center;gap:10px;display:flex}.role-badge{color:var(--text-secondary);font-size:13px;font-weight:500}.role-select{font-family:var(--font);border-radius:var(--radius-sm);border:2px solid var(--accent);background:var(--accent-light);color:var(--accent-dark);cursor:pointer;outline:none;padding:6px 12px;font-size:13px;font-weight:600}.page-body{flex:1;padding:28px}.charts-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;display:grid}.badge{border-radius:99px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-income{background:var(--green-light);color:#15803d}.badge-expense{background:var(--red-light);color:#b91c1c}@media (width<=900px){.charts-grid{grid-template-columns:1fr}}@media (width<=768px){.main-content{margin-left:0}.page-body{padding:16px}}
