
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{--bg:#0f0f11;--surface:#18181c;--surface2:#222228;--border:#2e2e38;--accent:#e8c547;--accent2:#4facfe;--danger:#ff6b6b;--success:#6bcb77;--text:#e8e8f0;--muted:#7a7a90;--radius:14px;}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at 60% 40%,#1a1a2e,#0f0f11 60%);}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:380px;text-align:center;box-shadow:0 32px 80px rgba(0,0,0,.6);}
.login-logo{font-family:'DM Serif Display',serif;font-size:2.2rem;color:var(--accent);margin-bottom:6px;}
.login-sub{color:var(--muted);font-size:.85rem;margin-bottom:36px;}
.login-box input[type=password]{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 18px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:1rem;outline:none;text-align:center;letter-spacing:4px;transition:border-color .2s;}
.login-box input:focus{border-color:var(--accent);}
.login-btn{width:100%;margin-top:16px;background:var(--accent);color:#111;border:none;border-radius:10px;padding:14px;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;cursor:pointer;}
.login-err{color:var(--danger);font-size:.85rem;margin-top:12px;}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;display:flex;align-items:center;gap:12px;height:62px;position:sticky;top:0;z-index:100;}
.topbar-logo{font-family:'DM Serif Display',serif;font-size:1.25rem;color:var(--accent);white-space:nowrap;}
.nav-tabs{display:flex;gap:3px;flex:1;overflow-x:auto;}
.nav-tab{padding:7px 13px;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--muted);border:none;background:transparent;white-space:nowrap;transition:all .15s;}
.nav-tab:hover{background:var(--surface2);color:var(--text);}
.nav-tab.active{background:var(--accent);color:#111;}
.year-select{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.88rem;outline:none;cursor:pointer;}
.logout-btn{padding:7px 12px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted);font-size:.8rem;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all .15s;}
.logout-btn:hover{border-color:var(--danger);color:var(--danger);}
.content{padding:24px;max-width:1300px;margin:0 auto;}
.page{display:none;}.page.active{display:block;}
.cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:24px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;}
.card-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;}
.card-val{font-family:'DM Serif Display',serif;font-size:1.7rem;letter-spacing:-.5px;}
.card-val.green{color:var(--success);}.card-val.red{color:var(--danger);}.card-val.yellow{color:var(--accent);}.card-val.blue{color:var(--accent2);}
.section-title{font-family:'DM Serif Display',serif;font-size:1.2rem;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px;}
table{width:100%;border-collapse:collapse;}
thead th{background:var(--surface2);padding:11px 14px;text-align:left;font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:500;}
tbody tr{border-top:1px solid var(--border);transition:background .1s;}
tbody tr:hover{background:rgba(255,255,255,.03);}
td{padding:10px 14px;font-size:.87rem;}
.summary-row{background:var(--surface2);border-top:1px solid var(--accent);}
.summary-row td{font-weight:700;}
.summary-row span{color:var(--muted);font-size:.76rem;font-weight:500;margin-left:8px;}
.tag{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.74rem;font-weight:500;background:#33333322;color:#aaa;border:1px solid #aaa4;}
.tag-income{color:var(--success);border-color:#6bcb7744;background:#6bcb7715;}
.tag-expense{color:var(--danger);border-color:#ff6b6b44;background:#ff6b6b15;}
.booking-pending{opacity:.48;}
.booking-pending:hover{opacity:.82;}
.btn-booked{background:var(--success);color:#08120a;font-size:.76rem;padding:4px 10px;}
.booking-status{display:inline-block;color:var(--muted);font-size:.76rem;}
.booking-status-ok{color:var(--success);}
.month-select-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px;}
.month-btn{padding:6px 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);font-size:.82rem;cursor:pointer;transition:all .15s;}
.month-btn:hover{border-color:var(--accent);color:var(--text);}
.month-btn.active{background:var(--accent);border-color:var(--accent);color:#111;font-weight:600;}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:14px;}
.form-group label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:5px;}
.form-group input,.form-group select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:9px 13px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.88rem;outline:none;transition:border-color .2s;}
.form-group input:focus,.form-group select:focus{border-color:var(--accent);}
.form-group input[type=color]{padding:4px 6px;height:38px;cursor:pointer;}
select option{background:#222;}
.btn{padding:9px 20px;border-radius:9px;border:none;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s;}
.btn:hover{opacity:.85;}
.btn-primary{background:var(--accent);color:#111;}
.btn-danger{background:var(--danger);color:#fff;font-size:.76rem;padding:4px 10px;}
.btn-edit{background:var(--surface2);color:var(--text);border:1px solid var(--border);font-size:.76rem;padding:4px 10px;}
.btn-sm{padding:6px 14px;font-size:.82rem;}
.btn-mini{font-size:.76rem;padding:4px 10px;}
.inline-amount-input{width:120px;background:var(--surface2);border:1px solid var(--accent2);border-radius:7px;padding:5px 8px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.84rem;outline:none;}
.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:24px;}
.charts-2col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px;}
@media(max-width:700px){.charts-2col{grid-template-columns:1fr;}}
.savings-accounts{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:24px;}
.savings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;}
.savings-card-name{font-size:.8rem;color:var(--muted);margin-bottom:3px;}
.savings-card-amount{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--accent2);margin-bottom:10px;}

.savings-total-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:18px;flex-wrap:wrap;}
.prog-bar-wrap{flex:1;min-width:180px;}
.prog-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted);margin-bottom:7px;}
.prog-bar{background:var(--surface2);border-radius:20px;height:9px;overflow:hidden;}
.prog-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent2),var(--accent));border-radius:20px;transition:width .5s;}
.filter-row{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:14px;align-items:center;}
.filter-row select,.filter-row input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:7px 11px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.84rem;outline:none;}
.info-pill{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 11px;font-size:.78rem;color:var(--muted);}
.amt-pos{color:var(--success);font-weight:600;}.amt-neg{color:var(--danger);font-weight:600;}
.toast{position:fixed;bottom:22px;right:22px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:13px 18px;font-size:.86rem;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:999;opacity:0;transform:translateY(10px);transition:all .3s;}
.toast.show{opacity:1;transform:translateY(0);}
.toast.ok{border-color:var(--success);color:var(--success);}
.toast.err{border-color:var(--danger);color:var(--danger);}
.loading{text-align:center;padding:36px;color:var(--muted);}
.empty-state{text-align:center;padding:36px;color:var(--muted);font-size:.88rem;}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:200;align-items:center;justify-content:center;}
.modal-bg.open{display:flex;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:28px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;}
.modal h3{font-family:'DM Serif Display',serif;font-size:1.25rem;margin-bottom:18px;}
.modal-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;}
.color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px;vertical-align:middle;}
.tab-bar{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--border);padding-bottom:0;}
.tab-btn{padding:8px 16px;border:none;background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:.86rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);}
.tab-content{display:none;}.tab-content.active{display:block;}
