*,*:before,*:after{box-sizing:border-box}body{margin:0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg2: #161b27;--bg3: #1e2535;--border: #2a3249;--accent: #4f8ef7;--accent-hover: #3a78e8;--income: #34d399;--expense: #f87171;--neutral: #a3adc7;--text: #e8ecf5;--text-muted: #6b7a9e;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.35);font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:15px;color:var(--text);background:var(--bg)}body{min-height:100vh;background:var(--bg)}#root{min-height:100vh;display:flex;flex-direction:column}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.text-income{color:var(--income)}.text-expense{color:var(--expense)}.text-muted{color:var(--text-muted)}.text-right{text-align:right}.empty-msg{color:var(--text-muted);font-size:.9rem;padding:.5rem 0}button{cursor:pointer;border:none;border-radius:7px;font-size:.9rem;font-family:inherit;transition:background .15s,opacity .15s}button:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;padding:.55em 1.25em;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border);padding:.5em 1.1em}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-muted);padding:.5em 1em}.btn-ghost:hover{color:var(--text)}.btn-full{width:100%}.btn-icon{background:transparent;color:var(--text-muted);padding:.2em .5em;font-size:.8rem;border-radius:5px}.btn-icon:hover{color:var(--expense);background:#f871711a}.btn-danger{color:var(--expense)}.btn-sm{padding:.4em .85em;font-size:.82rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.78rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.form-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:flex-end}.form-group.flex-2{flex:2}.form-group{flex:1;min-width:140px}.form-actions{display:flex;gap:.6rem;margin-top:.75rem}input[type=text],input[type=number],input[type=url],input[type=date],select{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:.5em .75em;font-size:.9rem;font-family:inherit;outline:none;width:100%}input:focus,select:focus{border-color:var(--accent)}.checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--text-muted);cursor:pointer;padding-bottom:.3rem}.checkbox-label input{width:auto}.inline-form{margin-bottom:1rem}.badge{display:inline-block;padding:.2em .65em;border-radius:20px;font-size:.75rem;font-weight:600}.badge-income{background:#34d39926;color:var(--income)}.badge-expense{background:#f8717126;color:var(--expense)}.badge-withdrawal{background:#fbbf2426;color:#fbbf24}.badge-done{background:#34d39933;color:var(--income)}.badge-upcoming{background:#4f8ef726;color:var(--accent)}.badge-past{background:#6b7a9e26;color:var(--text-muted)}.badge-recurring{background:#a78bfa26;color:#a78bfa}.badge-auto{background:#fbbf241f;color:#fbbf24;margin-left:.4rem;font-size:.7rem}.entry-row.auto-generated td{opacity:.75}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}.section-header h2,.section-header h3{font-size:1.05rem;font-weight:700}.section-total{font-size:.85rem;font-weight:500}.login-panel{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 60% 30%,#1a2444 0%,var(--bg) 70%);padding:1.5rem}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:440px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.1rem}.login-logo{font-size:2.8rem;text-align:center}.login-card h1{text-align:center;font-size:1.7rem}.login-subtitle{text-align:center;color:var(--text-muted);font-size:.9rem;line-height:1.5}.login-note{text-align:center;font-size:.78rem;color:var(--text-muted);line-height:1.5}.error-msg{color:var(--expense);font-size:.85rem}.app-header{background:var(--bg2);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:.6rem}.header-logo{font-size:1.4rem}.header-title{font-weight:700;font-size:1.05rem}.header-right{display:flex;align-items:center;gap:1rem}.header-user{font-size:.85rem;color:var(--text-muted)}.app-body{display:flex;flex:1;height:calc(100vh - 52px);overflow:hidden}.app-sidebar{width:260px;min-width:200px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1.5rem;flex-shrink:0}.app-main{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.nav-tabs{display:flex;gap:.3rem;background:var(--bg3);border-radius:8px;padding:.3rem;flex-wrap:wrap}.nav-tab{flex:1;padding:.5em .7em;border-radius:6px;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;text-align:center;min-width:80px}.nav-tab.active{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px #0000004d}.nav-tab:hover:not(.active){color:var(--text)}.budget-manager{display:flex;flex-direction:column;gap:.9rem}.budget-list{display:flex;flex-direction:column;gap:.4rem}.budget-chip-wrap{display:flex;align-items:stretch;gap:.3rem}.budget-chip-wrap .btn-duplicate,.budget-chip-wrap .btn-danger{opacity:0;transition:opacity .15s;font-size:1rem;padding:0 .5rem;background:var(--bg3);border:1px solid var(--border);border-radius:8px;flex-shrink:0}.budget-chip-wrap:hover .btn-duplicate,.budget-chip-wrap:hover .btn-danger{opacity:1}.budget-chip-wrap.active .btn-duplicate,.budget-chip-wrap.active .btn-danger{opacity:.6}.budget-chip-wrap.active:hover .btn-duplicate,.budget-chip-wrap.active:hover .btn-danger{opacity:1}.budget-chip{flex:1;display:flex;align-items:center;justify-content:space-between;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:.6em .9em;text-align:left;color:var(--text);font-size:.9rem;transition:border-color .15s}.budget-chip:hover,.budget-chip.active{border-color:var(--accent)}.budget-chip.active{background:#4f8ef71a}.budget-chip-name{font-weight:500}.budget-chip-type{font-size:.72rem;border-radius:20px;padding:.15em .55em}.type-weekly{background:#34d39926;color:var(--income)}.type-monthly{background:#4f8ef726;color:var(--accent)}.type-yearly{background:#a78bfa26;color:#a78bfa}.cashflow-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.cashflow-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.3rem}.balance-card{border-top:3px solid var(--accent)}.balance-card .cashflow-amount{color:var(--accent)}.income-card{border-top:3px solid var(--income)}.expense-card{border-top:3px solid var(--expense)}.net-card.positive{border-top:3px solid var(--income)}.net-card.negative{border-top:3px solid var(--expense)}.current-balance-card.positive{border-top:3px solid var(--income)}.current-balance-card.negative{border-top:3px solid var(--expense)}.cashflow-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:flex;align-items:center;gap:.35rem}.cashflow-amount{font-size:1.45rem;font-weight:700}.income-card .cashflow-amount{color:var(--income)}.expense-card .cashflow-amount{color:var(--expense)}.net-card.positive .cashflow-amount{color:var(--income)}.net-card.negative .cashflow-amount{color:var(--expense)}.current-balance-card.positive .cashflow-amount{color:var(--income)}.current-balance-card.negative .cashflow-amount{color:var(--expense)}.btn-edit{font-size:.8rem;padding:.1em .3em;opacity:.55;line-height:1}.btn-edit:hover{opacity:1}.btn-sm{padding:.25rem .6rem;font-size:.8rem}.balance-edit{display:flex;align-items:center;gap:.4rem;margin-top:.15rem}.balance-edit input{width:100px;padding:.3rem .5rem;font-size:.9rem}.category-breakdown{margin-bottom:1rem}.category-breakdown h3{font-size:.95rem;margin-bottom:.75rem}.category-list{display:flex;flex-direction:column;gap:.4rem}.category-row{display:flex;align-items:center;gap:.75rem;font-size:.88rem;padding:.35rem 0;border-bottom:1px solid var(--border)}.cat-name{flex:1}.cat-income{color:var(--income);font-weight:500}.cat-expense{color:var(--expense);font-weight:500}.entry-table-wrap{overflow-x:auto}.entry-table{width:100%;border-collapse:collapse;font-size:.88rem}.entry-table th{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.entry-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}.entry-row:hover td{background:#ffffff05}.savings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.savings-card{display:flex;flex-direction:column;gap:.65rem}.goal-complete{border-color:var(--income)}.savings-card-header{display:flex;align-items:center;gap:.5rem}.savings-name{flex:1;font-weight:600;font-size:1rem}.savings-amounts{font-size:1.1rem}.savings-current{font-weight:700;color:var(--accent)}.savings-sep,.savings-target{color:var(--text-muted)}.progress-bar-wrap{height:8px;background:var(--bg3);border-radius:9999px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:9999px;background:linear-gradient(90deg,var(--accent),var(--income));transition:width .4s}.progress-label{font-size:.78rem;color:var(--text-muted);text-align:right}.savings-deadline{font-size:.82rem;color:var(--text-muted)}.overdue{color:var(--expense)}.savings-deposit{margin-top:.25rem}.deposit-input{max-width:120px;flex:none!important;min-width:80px!important}.pay-date-list,.withdrawal-list{display:flex;flex-direction:column;gap:.55rem}.pay-date-item,.withdrawal-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem}.pay-date-info,.withdrawal-info{flex:1;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.pay-date-label,.withdrawal-desc{font-weight:500}.pay-date-date,.withdrawal-date{font-size:.82rem;color:var(--text-muted)}.pay-date-amount,.withdrawal-amount{font-weight:700;font-size:1rem;white-space:nowrap}.withdrawal-cat{background:var(--bg3);color:var(--text-muted);font-weight:400}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.save-indicator{position:fixed;bottom:1.25rem;right:1.5rem;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:.5rem 1rem;font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow)}.save-indicator.saved{color:var(--income)}.save-indicator.saving{color:var(--accent)}.save-indicator.error{color:var(--expense)}.no-budget{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.75rem;color:var(--text-muted)}.no-budget-icon{font-size:3rem}@media(max-width:768px){.app-body{flex-direction:column;height:auto}.app-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding:1rem}.cashflow-summary,.savings-grid{grid-template-columns:1fr}}
