*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#e0e7ff;--danger:#ef4444;--danger-light:#fee2e2;--success:#22c55e;--success-light:#dcfce7;--warning:#f59e0b;--warning-light:#fef3c7;--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--radius:12px;--radius-sm:8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:inherit}.container{max-width:1100px;margin:0 auto;padding:0 20px}.page-wrapper{min-height:100vh;background:var(--bg)}.navbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-inner{justify-content:space-between;height:64px}.navbar-brand,.navbar-inner{display:flex;align-items:center}.navbar-brand{gap:10px;font-size:1.25rem;font-weight:700;color:var(--primary)}.navbar-brand span{font-size:1.5rem}.navbar-date{font-size:.875rem;color:var(--text-muted)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:20px;gap:20px;margin:30px 0}.summary-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--radius) var(--radius) 0 0}.summary-card.budget:before{background:var(--primary)}.summary-card.spent:before{background:var(--danger)}.summary-card.remaining:before{background:var(--success)}.summary-card.transactions:before{background:var(--warning)}.summary-icon{font-size:1.75rem}.summary-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.summary-value{font-size:1.75rem;font-weight:700;color:var(--text);line-height:1.2}.summary-value.danger{color:var(--danger)}.summary-value.success{color:var(--success)}.budget-progress{background:var(--surface);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:30px}.budget-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.budget-progress-title{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.budget-progress-pct{font-size:.875rem;font-weight:700;color:var(--text)}.progress-bar-bg{width:100%;height:10px;background:var(--border);border-radius:100px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:100px;transition:width .4s ease}.progress-bar-fill.safe{background:var(--success)}.progress-bar-fill.warning{background:var(--warning)}.progress-bar-fill.danger{background:var(--danger)}.main-layout{display:grid;grid-template-columns:1fr 380px;grid-gap:24px;gap:24px;padding-bottom:40px}@media (max-width:900px){.main-layout{grid-template-columns:1fr}}.panel{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.panel-header{padding:18px 24px;border-bottom:1px solid var(--border);justify-content:space-between}.panel-header,.panel-title{display:flex;align-items:center}.panel-title{font-size:1rem;font-weight:700;color:var(--text);gap:8px}.panel-body{padding:24px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.825rem;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;color:var(--text);background:var(--surface);transition:border-color .2s,box-shadow .2s;outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.15)}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:600;border:none;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;width:100%;padding:12px}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{background:transparent;color:var(--danger);border:1.5px solid var(--danger-light);padding:6px 10px;font-size:.8rem;border-radius:6px}.btn-danger:hover{background:var(--danger-light)}.btn-ghost{background:transparent;color:var(--text-muted);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--bg);color:var(--text)}.expense-list{display:flex;flex-direction:column;gap:12px;max-height:520px;overflow-y:auto;padding-right:4px}.expense-list::-webkit-scrollbar{width:4px}.expense-list::-webkit-scrollbar-track{background:var(--bg);border-radius:100px}.expense-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:100px}.expense-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);transition:box-shadow .2s}.expense-item:hover{box-shadow:var(--shadow)}.expense-category-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.expense-info{flex:1 1;min-width:0}.expense-desc{font-size:.9375rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-meta{font-size:.8rem;color:var(--text-muted);margin-top:2px}.expense-amount{font-size:1rem;font-weight:700;color:var(--danger);flex-shrink:0}.category-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:100px;font-size:.75rem;font-weight:600}.cat-food{background:#fef3c7;color:#92400e}.cat-transport{background:#e0e7ff;color:#3730a3}.cat-housing{background:#f0fdf4;color:#14532d}.cat-entertainment{background:#fdf4ff;color:#6b21a8}.cat-health{background:#fff1f2;color:#881337}.cat-shopping{background:#fff7ed;color:#7c2d12}.cat-utilities{background:#f0f9ff;color:#0c4a6e}.cat-other{background:#f8fafc;color:#334155}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:20px}.filter-select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text);background:var(--surface);outline:none;cursor:pointer}.filter-select:focus{border-color:var(--primary)}.search-input{flex:1 1;min-width:160px;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text);background:var(--surface);outline:none}.search-input:focus{border-color:var(--primary)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:12px}.empty-state-text{font-size:.9375rem}.chart-container{margin-top:0}.chart-bar-list{gap:14px}.chart-bar-item,.chart-bar-list{display:flex;flex-direction:column}.chart-bar-item{gap:6px}.chart-bar-header{display:flex;justify-content:space-between;align-items:center}.chart-bar-label{font-size:.85rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}.chart-bar-value{font-size:.85rem;font-weight:700;color:var(--text-muted)}.chart-bar-bg{width:100%;height:8px;background:var(--border);border-radius:100px;overflow:hidden}.chart-bar-fill{height:100%;border-radius:100px;transition:width .5s ease}.budget-setting-form{display:flex;gap:10px;align-items:flex-end}.budget-setting-form .form-group{flex:1 1;margin-bottom:0}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999}.toast{padding:12px 20px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;animation:slideIn .3s ease;max-width:320px}.toast.success{background:var(--success);color:#fff}.toast.error{background:var(--danger);color:#fff}.toast.info{background:var(--primary);color:#fff}@keyframes slideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:480px;overflow:hidden}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text)}.modal-close{background:none;border:none;font-size:1.25rem;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:color .2s}.modal-close:hover{color:var(--text)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.tabs{display:flex;gap:4px;background:var(--bg);border-radius:var(--radius-sm);padding:4px;margin-bottom:20px}.tab{flex:1 1;padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:.875rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s}.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow)}@media (max-width:600px){.form-row{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr 1fr}.navbar-date{display:none}}