*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#111}@media (width<=768px){nav button[data-page=budget],nav button[data-page=triage],nav button[data-page=close],nav .nav-username{display:none}.dashboard{padding:1rem}.dashboard h1{font-size:1.2rem}.kpi-grid{grid-template-columns:1fr 1fr;gap:.6rem}.kpi-card{padding:.75rem}.kpi-card .value{font-size:1.1rem}.group-header{flex-direction:column;align-items:flex-start;gap:.4rem}.group-amounts{flex-direction:column;gap:.2rem}.cat-row{grid-template-rows:auto auto;grid-template-columns:1rem 1fr;gap:.25rem .5rem}.cat-amounts{flex-wrap:wrap;grid-column:2;gap:.4rem}.cat-bar-wrap{min-width:unset;grid-column:1/-1}.ing-stats{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.ing-card-stats{flex-direction:column;align-items:flex-end;gap:.15rem}.tx-row{gap:.4rem;font-size:.75rem}.close-page,.triage,.triage-table{padding:1rem;font-size:.82rem}.surplus-row{flex-direction:column}.surplus-arrow{align-self:center;transform:rotate(90deg)}}@supports (padding:env(safe-area-inset-bottom)){body{padding-bottom:env(safe-area-inset-bottom)}nav{padding-left:max(2rem, env(safe-area-inset-left));padding-right:max(2rem, env(safe-area-inset-right))}}.dashboard{color:#e0e0e0;background:#111;max-width:1100px;min-height:100vh;margin:0 auto;padding:2rem;font-family:system-ui,sans-serif}.dashboard h1{color:#00ff41;margin-bottom:.25rem;font-size:1.6rem}.month-label{color:#555;margin-bottom:2rem;font-size:.85rem}.month-label span{color:#888}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.kpi-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;padding:1rem 1.2rem}.kpi-card .label{color:#555;text-transform:uppercase;margin-bottom:.4rem;font-size:.75rem}.kpi-card .value{font-size:1.4rem;font-weight:700}.kpi-card .sub{color:#555;margin-top:.25rem;font-size:.75rem}.warning{color:#fa0}.groups{flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex}.group-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;padding:1rem 1.2rem}.group-header{justify-content:space-between;align-items:baseline;margin-bottom:.6rem;display:flex}.group-name{color:#ccc;font-size:.9rem;font-weight:600}.group-amounts{color:#666;gap:1.5rem;font-size:.82rem;display:flex}.group-amounts .actual{color:#e0e0e0;font-weight:600}.group-amounts .planned{color:#555}.group-amounts .remaining-pos{color:#00ff41}.group-amounts .remaining-neg{color:#f44}.group-chevron{color:#444;width:1rem;margin-right:.25rem;font-size:.75rem;display:inline-block}.group-card-open{border-color:#333}.cat-list{border-top:1px solid #1e1e1e;margin-top:.75rem;padding-top:.5rem}.cat-row-wrap{border-bottom:1px solid #1a1a1a}.cat-row-wrap:last-child{border-bottom:none}.cat-row{cursor:pointer;border-radius:3px;grid-template-columns:1rem 1fr auto 120px;align-items:center;gap:.75rem;padding:.45rem .2rem;display:grid}.cat-row:hover{background:#1e1e1e}.cat-chevron{color:#444;text-align:center;font-size:.7rem}.cat-amounts{white-space:nowrap;gap:.6rem;font-size:.78rem;display:flex}.cat-actual{color:#ccc;font-weight:600}.cat-planned{color:#444}.cat-rem-pos{color:#00aa30}.cat-rem-neg{color:#c33}.cat-bar-wrap{min-width:80px}.tx-list{border-left:1px solid #222;margin:.1rem 0 .5rem 1.2rem;padding-left:.75rem}.tx-row{border-bottom:1px solid #191919;align-items:baseline;gap:.6rem;padding:.3rem 0;font-size:.8rem;display:flex}.tx-row:last-child{border-bottom:none}.tx-date{color:#444;white-space:nowrap;min-width:2.5rem}.tx-label{color:#888;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.tx-amount{white-space:nowrap;font-weight:600}.tx-neg{color:#bbb}.tx-pos{color:#00ff41}.tx-loading,.tx-empty{color:#444;padding:.4rem 0 .4rem 1.2rem;font-size:.78rem}.progress-bar-bg{background:#2a2a2a;border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%;transition:width .3s}.fill-ok{background:#00ff41}.fill-warn{background:#fa0}.fill-over{background:#f44}.ing-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;margin-bottom:2rem;padding:1rem 1.2rem}.ing-top-row{flex-wrap:wrap;align-items:baseline;gap:1.5rem;margin-bottom:.2rem;display:flex}.ing-top-row h2{color:#ccc;margin-bottom:.8rem;font-size:.9rem;font-weight:600}.ing-stats{flex-wrap:wrap;gap:2rem;display:flex}.ing-cards-section{border-top:1px solid #1e1e1e;margin-top:.8rem;padding-top:.5rem}.ing-card-row-wrap{border-bottom:1px solid #1a1a1a}.ing-card-row-wrap:last-child{border-bottom:none}.ing-card-row{cursor:pointer;border-radius:3px;align-items:center;gap:.75rem;padding:.45rem .2rem;display:flex}.ing-card-row:hover{background:#1e1e1e}.ing-card-label{color:#aaa;flex:1;font-size:.82rem}.ing-card-stats{white-space:nowrap;gap:1rem;font-size:.78rem;display:flex}.ing-cr-received{color:#00aa30}.ing-cr-spent{color:#888}.ing-cr-net.pos{color:#00ff41}.ing-cr-net.neg{color:#f44}.ing-cat-list{border-left:1px solid #222;margin:.1rem 0 .5rem 1.2rem;padding-left:.75rem}.ing-stats .item .label{color:#555;text-transform:uppercase;font-size:.75rem}.ing-stats .item .value{font-size:1.1rem;font-weight:700}.triage-badge{color:#fa0;background:#2a1a00;border:1px solid #fa0;border-radius:3px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.4rem .8rem;font-size:.85rem;display:inline-flex}.month-title{color:#00ff41;font-weight:600}.data-age{color:#444;text-align:right;margin-top:1rem;font-size:.75rem}.error-msg{color:#f44;padding:2rem}.budget-plan{color:#e0e0e0;background:#111;max-width:1100px;min-height:100vh;margin:0 auto;padding:2rem;font-family:system-ui,sans-serif}h1{color:#00ff41;margin-bottom:.5rem;font-size:1.6rem}.year-bar{align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.year-bar button{color:#00ff41;cursor:pointer;background:#1a1a1a;border:1px solid #00ff41;padding:.4rem 1rem;font-size:1rem}.year-bar button:hover{background:#00ff4122}.month-tabs{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.month-tabs button{color:#aaa;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:3px;padding:.35rem .75rem;font-size:.85rem}.month-tabs button.active{color:#00ff41;background:#00ff4122;border-color:#00ff41}.month-tabs button.has-data{color:#ccc;border-color:#555}.month-tabs button:hover{border-color:#00ff41}.month-editor{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;padding:1.5rem}.month-editor h2{color:#00ff41;margin-bottom:1.2rem;font-size:1.1rem}.income-row{border-bottom:1px solid #2a2a2a;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.income-row label{color:#00ff41;min-width:160px;font-weight:600}.line-items-table{border-collapse:collapse;width:100%;margin-bottom:1.5rem}.line-items-table th{text-align:left;color:#666;text-transform:uppercase;border-bottom:1px solid #2a2a2a;padding:.4rem .5rem;font-size:.8rem}.line-items-table td{border-bottom:1px solid #1e1e1e;padding:.4rem .5rem}.line-items-table tr:hover td{background:#222}.cat-name{color:#ccc;font-size:.9rem}.cat-badge{color:#666;background:#2a2a2a;border-radius:2px;padding:.1rem .4rem;font-size:.7rem}input[type=number]{color:#e0e0e0;text-align:right;background:#111;border:1px solid #333;border-radius:2px;width:120px;padding:.3rem .5rem;font-size:.9rem}input[type=number]:focus{border-color:#00ff41;outline:none}.summary-bar{background:#111;border:1px solid #2a2a2a;border-radius:4px;gap:2rem;margin-bottom:1.2rem;padding:1rem;font-size:.9rem;display:flex}.summary-bar .item label{color:#666;font-size:.75rem;display:block}.summary-bar .item span{font-size:1rem;font-weight:600}.positive{color:#00ff41}.negative{color:#f44}.neutral{color:#e0e0e0}.actions{align-items:center;gap:1rem;display:flex}.btn-save{color:#000;cursor:pointer;background:#00ff41;border:none;border-radius:3px;padding:.5rem 1.5rem;font-size:.95rem;font-weight:700}.btn-save:hover{background:#0c3}.btn-save:disabled{color:#666;cursor:not-allowed;background:#333}.saved-msg{color:#00ff41;font-size:.85rem}.error-msg{color:#f44;font-size:.85rem}.loading{color:#666;padding:2rem}.triage{color:#e0e0e0;background:#111;max-width:1100px;min-height:100vh;margin:0 auto;padding:2rem;font-family:system-ui,sans-serif}.triage h1{color:#00ff41;margin-bottom:.25rem;font-size:1.6rem}.triage-sub{color:#666;margin-bottom:1.5rem;font-size:.85rem}.triage-loading{color:#666;padding:2rem}.triage-table{border-collapse:collapse;width:100%;font-size:.85rem}.triage-table th{text-align:left;color:#555;text-transform:uppercase;border-bottom:1px solid #2a2a2a;padding:.4rem .6rem;font-size:.75rem}.triage-table td{vertical-align:middle;border-bottom:1px solid #1a1a1a;padding:.5rem .6rem}.triage-table tr:hover td{background:#161616}.date-col{color:#666;white-space:nowrap}.acct-col{color:#888;font-size:.8rem}.party-col{color:#ccc;text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.ref-col{color:#888;text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.amount-col{text-align:right;white-space:nowrap;font-weight:600}.amount-col.pos{color:#00ff41}.amount-col.neg{color:#e0e0e0}.empty{color:#444;font-style:normal}.triage-table select{color:#e0e0e0;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:3px;min-width:160px;padding:.3rem .5rem;font-size:.82rem}.triage-table select:focus{border-color:#00ff41;outline:1px solid #00ff41}.save-btn{color:#000;cursor:pointer;white-space:nowrap;background:#00ff41;border:none;border-radius:3px;padding:.3rem .8rem;font-size:.8rem;font-weight:700}.save-btn:disabled{color:#444;cursor:not-allowed;background:#1a1a1a}.close-page{color:#e0e0e0;background:#111;max-width:900px;min-height:100vh;margin:0 auto;padding:2rem;font-family:system-ui,sans-serif}.close-page h1{color:#00ff41;margin-bottom:.25rem;font-size:1.6rem}.close-month-label{color:#666;margin-bottom:2rem;font-size:.85rem}.close-loading{color:#666;padding:2rem}.close-error{color:#f44;padding:2rem}.not-ready-banner{color:#66a;background:#0a0a1a;border:1px solid #2a2a55;border-radius:4px;margin-bottom:1.5rem;padding:.7rem 1rem;font-size:.82rem}.already-closed-banner{color:#aa0;background:#1a1a00;border:1px solid #440;border-radius:4px;margin-bottom:1.5rem;padding:.7rem 1rem;font-size:.82rem}.surplus-row{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.surplus-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;flex:1;min-width:180px;padding:1rem 1.2rem}.surplus-card.highlight{border-color:#333}.surplus-arrow{color:#333;flex-shrink:0;font-size:1.2rem}.sc-label{color:#555;text-transform:uppercase;margin-bottom:.3rem;font-size:.72rem}.sc-value{font-size:1.3rem;font-weight:700}.sc-value.pos{color:#00ff41}.sc-value.neg{color:#f44}.sc-sub{color:#555;margin-top:.25rem;font-size:.72rem}.delta-badge{border-radius:3px;padding:.15rem .4rem;font-size:.85rem;font-weight:600;display:inline-block}.delta-pos{color:#00ff41}.delta-neg{color:#f44}.breakdown-section{margin-bottom:2rem}.section-title{text-transform:uppercase;color:#555;letter-spacing:.05em;margin-bottom:.75rem;font-size:.75rem}.breakdown-table{border-collapse:collapse;width:100%;font-size:.85rem}.breakdown-table th{text-align:left;color:#555;text-transform:uppercase;border-bottom:1px solid #2a2a2a;padding:.4rem .6rem;font-size:.72rem}.breakdown-table th.num-col{text-align:right}.breakdown-table td{border-bottom:1px solid #1a1a1a;padding:.45rem .6rem}.breakdown-table tr:hover td{background:#161616}.breakdown-table tfoot tr td{border-top:1px solid #333;border-bottom:none;padding-top:.6rem;font-weight:600}.num-col{text-align:right;white-space:nowrap}.muted{color:#555}.totals-row td{color:#ccc}.close-form{background:#141414;border:1px solid #2a2a2a;border-radius:4px;padding:1.5rem}.form-row{margin-bottom:1.2rem}.form-row label{color:#aaa;margin-bottom:.25rem;font-size:.8rem;display:block}.input-hint{color:#555;margin-bottom:.4rem;font-size:.75rem}.form-row input,.form-row textarea{color:#e0e0e0;box-sizing:border-box;background:#1a1a1a;border:1px solid #333;border-radius:3px;width:100%;padding:.5rem .7rem;font-size:.9rem}.form-row input:focus,.form-row textarea:focus{border-color:#00ff41;outline:1px solid #00ff41}.form-row textarea{resize:vertical;font-family:inherit}.confirm-btn{color:#000;cursor:pointer;background:#00ff41;border:none;border-radius:3px;margin-top:.5rem;padding:.6rem 1.5rem;font-size:.9rem;font-weight:700}.confirm-btn:disabled{color:#363;cursor:not-allowed;background:#1a3a1a}.close-success{text-align:center;padding:4rem 2rem}.success-icon{color:#00ff41;margin-bottom:1rem;font-size:3rem}.success-label{color:#ccc;margin-bottom:.5rem;font-size:1.3rem}.success-sub{color:#666;font-size:.9rem}.import-page{max-width:640px;margin:2rem auto;padding:0 1.5rem}.import-title{color:#00ff41;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .4rem;font-size:1.1rem;font-weight:700}.import-hint{color:#555;margin:0 0 1.8rem;font-size:.82rem}.import-list{flex-direction:column;gap:1rem;display:flex}.import-card{background:#111;border:1px solid #1e1e1e;border-radius:6px;flex-direction:column;gap:.5rem;padding:1.1rem 1.3rem;display:flex}.import-card-header{align-items:center;gap:.7rem;display:flex}.import-account-name{color:#ccc;font-size:.92rem;font-weight:600}.import-format-badge{color:#555;letter-spacing:.04em;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:3px;padding:.1rem .45rem;font-size:.72rem}.import-iban{color:#333;font-family:monospace;font-size:.78rem}.import-row{align-items:center;gap:.7rem;margin-top:.3rem;display:flex}.import-file-label{cursor:pointer;flex:1}.import-file-input{display:none}.import-file-btn{color:#666;white-space:nowrap;text-overflow:ellipsis;background:#0d0d0d;border:1px solid #2a2a2a;border-radius:4px;padding:.45rem .8rem;font-size:.82rem;transition:border-color .15s;display:block;overflow:hidden}.import-file-label:hover .import-file-btn{color:#999;border-color:#444}.import-upload-btn{color:#00ff41;cursor:pointer;white-space:nowrap;background:#003d0f;border:1px solid #00ff41;border-radius:4px;padding:.45rem 1rem;font-size:.82rem;transition:background .15s}.import-upload-btn:hover:not(:disabled){background:#005c17}.import-upload-btn:disabled{opacity:.35;cursor:not-allowed}.import-status{border-radius:4px;padding:.35rem .7rem;font-size:.8rem}.import-status--ok{color:#00ff41;background:#0a1f0a;border:1px solid #1a3a1a}.import-status--err{color:#f44;background:#1f0a0a;border:1px solid #3a1a1a}.login-wrap{background:#111;justify-content:center;align-items:center;min-height:100vh;font-family:system-ui,sans-serif;display:flex}.login-box{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;width:100%;max-width:340px;padding:2.5rem 2rem}.login-title{color:#00ff41;margin-bottom:.25rem;font-size:1.2rem;font-weight:700}.login-sub{color:#555;margin-bottom:2rem;font-size:.82rem}.login-field{margin-bottom:1rem}.login-field label{color:#888;margin-bottom:.3rem;font-size:.78rem;display:block}.login-field input{color:#e0e0e0;box-sizing:border-box;background:#111;border:1px solid #333;border-radius:4px;width:100%;padding:.55rem .75rem;font-size:.95rem}.login-field input:focus{border-color:#00ff41;outline:none}.login-error{color:#f44;background:#1a0000;border:1px solid #400;border-radius:3px;margin-bottom:1rem;padding:.5rem .75rem;font-size:.8rem}.login-btn{color:#000;cursor:pointer;background:#00ff41;border:none;border-radius:4px;width:100%;margin-top:.5rem;padding:.65rem;font-size:.95rem;font-weight:700}.login-btn:disabled{color:#363;cursor:not-allowed;background:#1a3a1a}
