*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F6F3EE;--surface: #FFFFFF;--surface2: #F0EDE6;--surface3: #E8E3DA;--g-dark: #3D5240;--g-mid: #5F7A5F;--g-light: #8FAB89;--g-pale: #C8D9C4;--sand: #D6C8A8;--sand-l: #EDE5D4;--rose: #C4A090;--rose-l: #E8D5CC;--text: #2A2A2A;--text-mid: #5C5C5C;--text-muted: #8E8E8E;--border: #DDD8D0;--radius: 14px;--radius-sm: 8px;--danger: #C0392B;--warn: #E67E22;--ok: #3D5240;--nav-h: 52px}[data-theme=dark]{--bg: #1A1D1A;--surface: #242824;--surface2: #2C312C;--surface3: #343A34;--g-dark: #8FAB89;--g-mid: #6E9B6E;--g-light: #5F7A5F;--g-pale: #3D5240;--sand: #8B7355;--sand-l: #3D3528;--rose: #C4A090;--rose-l: #3D2820;--text: #E8E6E0;--text-mid: #B0ADA6;--text-muted: #6E6C66;--border: #3A3E3A;--danger: #E05C4B;--warn: #E8903A;--ok: #8FAB89}body{font-family:Nunito,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;transition:background .2s,color .2s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.topnav{background:var(--g-dark);display:flex;align-items:center;padding:0 28px;height:var(--nav-h);gap:4px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #00000026}.nav-brand{font-family:Playfair Display,serif;color:#fff;font-size:18px;margin-right:auto;letter-spacing:-.5px}.nav-links{display:flex;gap:2px}.nav-btn{background:transparent;border:none;color:#fff9;font-family:Nunito,sans-serif;font-size:13px;font-weight:600;padding:6px 14px;border-radius:20px;cursor:pointer;transition:.2s;letter-spacing:.5px}.nav-btn:hover{color:#fff;background:#ffffff1a}.nav-btn.active{color:#fff;background:#ffffff2e}.nav-user{font-size:12px;color:#ffffff80;margin-left:12px;padding-left:12px;border-left:1px solid rgba(255,255,255,.15)}.page{padding:28px 28px 60px;max-width:1160px;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}.page-header h1{font-family:Playfair Display,serif;font-size:36px;color:var(--g-dark);letter-spacing:-1px}.page-header p{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);margin-top:3px}.budget-alert{background:var(--rose-l);border:1px solid var(--rose);border-left:4px solid var(--danger);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px;display:flex;align-items:flex-start;gap:12px}.budget-alert-icon{font-size:18px;flex-shrink:0;margin-top:1px}.budget-alert-body{flex:1}.budget-alert-title{font-size:13px;font-weight:700;color:var(--danger);margin-bottom:4px}.budget-alert-items{font-size:12px;color:var(--text-mid);display:flex;flex-wrap:wrap;gap:6px}.budget-alert-item{background:var(--rose-l);border:1px solid var(--rose);border-radius:10px;padding:2px 8px;color:var(--danger);font-weight:600}.month-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px;align-items:center}.month-pill{background:transparent;border:1.5px solid var(--border);color:var(--text-mid);border-radius:20px;padding:5px 13px;font-size:12px;font-weight:700;cursor:pointer;font-family:Nunito,sans-serif;transition:.2s}.month-pill.active{background:var(--g-dark);border-color:var(--g-dark);color:#fff}.month-pill:hover:not(.active){border-color:var(--g-mid);color:var(--g-dark)}.year-label{font-size:12px;color:var(--text-muted);font-weight:700;margin-right:4px}.btn-icon{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px;cursor:pointer;color:var(--text-mid);font-family:Nunito,sans-serif;font-weight:600;transition:.2s;margin-left:auto}.btn-icon:hover{border-color:var(--g-mid);color:var(--g-dark)}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px 22px;min-width:0}.card-sm{padding:14px 16px}.card-title{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kpi{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px 18px;position:relative;overflow:hidden}.kpi-accent{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0}.kpi-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.kpi-value{font-family:Playfair Display,serif;font-size:24px;color:var(--g-dark);font-weight:700;line-height:1.1}.kpi-sub{font-size:11px;color:var(--text-muted);margin-top:4px}.kpi-sub b{color:var(--g-mid)}.kpi-sub b.neg{color:var(--rose)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:16px}.mb16{margin-bottom:16px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;display:block;width:100%}.fin-table{width:100%;border-collapse:collapse;min-width:520px}.fin-table th{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-weight:700;padding:6px 8px;text-align:left;border-bottom:1.5px solid var(--border)}.fin-table td{padding:9px 8px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.fin-table tr:last-child td{border-bottom:none}.fin-table td.num{text-align:right;font-weight:600;font-family:Playfair Display,serif;font-size:14px}.fin-table td.pct{text-align:right;font-size:12px;color:var(--text-muted)}.fin-table tr.total td{font-weight:700;background:var(--sand-l);color:var(--g-dark)}.fin-table tr:hover:not(.total) td{background:var(--surface2)}.fin-table td.editable{cursor:pointer}.fin-table td.editable:hover{background:var(--sand-l)}.prog-wrap{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;min-width:80px}.prog-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}.goal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}.goal-card-accent{position:absolute;top:0;left:0;right:0;height:4px}.goal-name{font-family:Playfair Display,serif;font-size:18px;color:var(--g-dark);margin-bottom:4px}.goal-amounts{font-size:13px;color:var(--text-muted);margin-bottom:12px}.goal-amounts b{color:var(--text);font-size:15px}.goal-deadline{font-size:11px;color:var(--text-muted);margin-top:10px}.goal-months-left{font-size:12px;font-weight:700;color:var(--g-mid)}.badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}.badge-ok{background:var(--g-pale);color:var(--g-dark)}.badge-warn{background:#fff3cd;color:#856404}.badge-danger{background:var(--rose-l);color:var(--danger)}.btn-primary{background:var(--g-dark);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 20px;font-family:Nunito,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:.2s}.btn-primary:hover{background:var(--g-mid)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text-mid);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 18px;font-family:Nunito,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:.2s}.btn-secondary:hover{border-color:var(--g-mid);color:var(--g-dark)}.btn-del{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 4px;transition:.2s}.btn-del:hover{color:var(--danger)}.btn-add{background:var(--surface);border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:10px;text-align:center;font-size:12px;color:var(--text-muted);cursor:pointer;transition:.2s;font-weight:600;font-family:Nunito,sans-serif;width:100%}.btn-add:hover{border-color:var(--g-mid);color:var(--g-dark)}.form-group{margin-bottom:14px}.form-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-bottom:6px;display:block}.form-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;font-family:Nunito,sans-serif;font-size:13px;color:var(--text);outline:none;transition:.2s}.form-input:focus{border-color:var(--g-mid);background:var(--surface)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border-radius:var(--radius);padding:28px;width:480px;max-width:calc(100vw - 32px);max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal h2{font-family:Playfair Display,serif;font-size:22px;color:var(--g-dark);margin-bottom:20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.view-tabs{display:flex;gap:2px;background:var(--surface2);border-radius:20px;padding:3px;margin-bottom:20px;width:fit-content}.view-tab{background:none;border:none;border-radius:17px;padding:6px 16px;font-size:12px;font-weight:700;color:var(--text-muted);cursor:pointer;font-family:Nunito,sans-serif;transition:.2s}.view-tab.active{background:var(--surface);color:var(--g-dark)}.settings-section{margin-bottom:28px}.settings-section h3{font-size:13px;font-weight:700;color:var(--g-dark);margin-bottom:14px;padding-bottom:8px;border-bottom:1.5px solid var(--border)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:13px;color:var(--text)}.toggle{position:relative;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:11px;cursor:pointer;transition:.3s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.3s}input:checked+.toggle-slider{background:var(--g-mid)}input:checked+.toggle-slider:before{transform:translate(18px)}.cat-list{display:flex;flex-direction:column;gap:8px}.cat-item{display:flex;align-items:center;gap:10px;background:var(--surface2);border-radius:var(--radius-sm);padding:10px 12px}.cat-item input[type=text]{flex:1;background:transparent;border:none;border-bottom:1px solid var(--border);font-family:Nunito,sans-serif;font-size:13px;color:var(--text);padding:2px 0;outline:none}.cat-item input[type=text]:focus{border-color:var(--g-mid)}.cat-color{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);cursor:pointer;flex-shrink:0;padding:0}.bill-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}.bill-item:last-child{border-bottom:none}.bill-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;font-size:11px;color:transparent}.bill-check.done{background:var(--g-mid);border-color:var(--g-mid);color:#fff}.bill-name{flex:1;font-size:13px}.bill-name.done{text-decoration:line-through;color:var(--text-muted)}.bill-amt{font-size:13px;font-weight:700;color:var(--g-dark)}.debt-item{padding:12px 0;border-bottom:1px solid var(--border)}.debt-item:last-child{border-bottom:none}.debt-row1{display:flex;align-items:center;gap:10px;margin-bottom:6px}.debt-icon{width:30px;height:30px;border-radius:8px;background:var(--sand-l);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.debt-name{font-size:13px;font-weight:600;flex:1}.debt-amount{font-size:13px;font-weight:700;color:var(--rose)}.debt-row2{display:flex;align-items:center;gap:8px}.debt-progress-wrap{flex:1;height:5px;background:var(--surface2);border-radius:3px;overflow:hidden}.debt-progress-fill{height:100%;border-radius:3px;background:var(--sand)}.ring-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.ring-main{font-family:Playfair Display,serif;font-size:22px;color:var(--g-dark);font-weight:700}.ring-sub{font-size:11px;color:var(--text-muted);text-align:center}.pie-section{display:flex;align-items:center;gap:20px}.pie-legend{display:flex;flex-direction:column;gap:8px;flex:1}.pie-leg-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-mid)}.pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.mini-bars{display:flex;align-items:flex-end;gap:6px;height:80px}.mini-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.mini-bar-wrap{width:100%;display:flex;gap:2px;align-items:flex-end;height:64px}.mini-bar{flex:1;border-radius:3px 3px 0 0;min-height:2px;transition:height .7s}.mini-label{font-size:9px;color:var(--text-muted)}.bar-h{display:flex;align-items:center;gap:10px;margin-bottom:8px}.bar-h-label{font-size:12px;color:var(--text-mid);width:110px;flex-shrink:0}.bar-h-track{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}.bar-h-fill{height:100%;border-radius:4px;transition:width .7s}.bar-h-val{font-size:12px;font-weight:600;color:var(--text-mid);width:80px;text-align:right;flex-shrink:0}.report-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}.rep-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}.rep-card-val{font-family:Playfair Display,serif;font-size:28px;color:var(--g-dark);font-weight:700}.rep-card-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-top:4px}.rep-card-delta{font-size:12px;font-weight:700;margin-top:6px}.delta-pos{color:var(--g-mid)}.delta-neg{color:var(--danger)}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999}.auth-box{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:40px;width:380px;max-width:calc(100vw - 32px);box-shadow:0 8px 32px #00000014}.auth-title{font-family:Playfair Display,serif;font-size:28px;color:var(--g-dark);margin-bottom:6px}.auth-sub{font-size:12px;color:var(--text-muted);margin-bottom:28px}.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--border)}.auth-tab{background:none;border:none;font-family:Nunito,sans-serif;font-size:13px;font-weight:700;color:var(--text-muted);cursor:pointer;padding:8px 16px 10px;position:relative;transition:.2s}.auth-tab.active{color:var(--g-dark)}.auth-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--g-dark)}.auth-error{background:var(--rose-l);color:var(--danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;margin-bottom:14px}.empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-icon{font-size:36px;margin-bottom:12px}.empty-text{font-size:14px}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted);font-size:14px;gap:10px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--g-mid);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{background:var(--g-dark);color:#fff;border-radius:var(--radius-sm);padding:12px 18px;font-size:13px;font-weight:600;box-shadow:0 4px 16px #0003;animation:slideIn .2s ease}.toast.error{background:var(--danger)}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:none;opacity:1}}.inline-input{width:90px;border:1px solid var(--g-mid);border-radius:4px;padding:2px 6px;font-family:Nunito,sans-serif;font-size:13px;background:var(--surface);color:var(--text);outline:none}.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:8px}.nav-hamburger span{display:block;width:22px;height:2px;background:#fffc;border-radius:2px;transition:.2s}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu{position:absolute;top:0;right:0;bottom:0;width:260px;background:var(--g-dark);padding:60px 0 32px;display:flex;flex-direction:column}.mobile-menu-user{font-size:12px;color:#ffffff73;padding:0 24px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}.mobile-menu-item{display:flex;align-items:center;gap:12px;background:none;border:none;color:#ffffffb3;font-family:Nunito,sans-serif;font-size:15px;font-weight:600;padding:14px 24px;cursor:pointer;text-align:left;transition:.2s}.mobile-menu-item.active,.mobile-menu-item:hover{color:#fff;background:#ffffff1a}.mobile-menu-icon{font-size:18px;width:24px;text-align:center;opacity:.7}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--surface);border-top:1px solid var(--border);z-index:100;box-shadow:0 -4px 12px #0000000f}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;padding:6px 0;color:var(--text-muted);transition:.15s}.bottom-nav-item.active{color:var(--g-dark)}.bottom-nav-icon{font-size:18px;line-height:1}.bottom-nav-label{font-size:10px;font-weight:700;font-family:Nunito,sans-serif;letter-spacing:.3px}.month-bar-mobile{display:none;margin-bottom:24px}.month-bar-desktop{display:flex}.month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}.month-grid .month-pill{width:100%;margin:0;text-align:center;justify-content:center}.year-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;border-top:1px solid var(--border);padding-top:10px;margin-top:4px}.year-nav-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:8px 16px;font-size:13px;font-weight:700;color:var(--text-mid);cursor:pointer;font-family:Nunito,sans-serif;transition:.2s;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:6px}.year-nav-btn:hover{border-color:var(--g-mid);color:var(--g-dark)}.year-nav-current{font-size:17px;font-weight:700;color:var(--g-dark);text-align:center;font-family:Playfair Display,serif;flex:1}@media (max-width: 768px){.nav-links,.nav-user{display:none}.nav-hamburger,.bottom-nav{display:flex}.month-bar-desktop{display:none}.month-bar-mobile{display:block}.page{padding:16px 16px 80px}.topnav{padding:0 16px}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-value{font-size:18px}.grid-2,.grid-2-1,.grid-3{grid-template-columns:1fr}.report-summary{grid-template-columns:1fr 1fr;gap:10px}.form-row,.form-row-3{grid-template-columns:1fr}.card{padding:14px}.modal{padding:20px}.page-header h1{font-size:26px}.month-bar{gap:4px}.month-pill{padding:4px 10px;font-size:11px}.rep-card-val{font-size:20px}}@media (max-width: 420px){.kpi-grid{grid-template-columns:1fr 1fr}.report-summary{grid-template-columns:1fr}.auth-box{padding:28px 20px}}.receipt-panel{transition:margin-right .25s}.receipt-detail-open .page{margin-right:400px}
